diff options
Diffstat (limited to 'drivers/net/wireless/rtlwifi/rtl8723ae/pwrseqcmd.h')
-rw-r--r-- | drivers/net/wireless/rtlwifi/rtl8723ae/pwrseqcmd.h | 98 |
1 files changed, 98 insertions, 0 deletions
diff --git a/drivers/net/wireless/rtlwifi/rtl8723ae/pwrseqcmd.h b/drivers/net/wireless/rtlwifi/rtl8723ae/pwrseqcmd.h new file mode 100644 index 000000000000..6e0f3ea37ec0 --- /dev/null +++ b/drivers/net/wireless/rtlwifi/rtl8723ae/pwrseqcmd.h | |||
@@ -0,0 +1,98 @@ | |||
1 | /****************************************************************************** | ||
2 | * | ||
3 | * Copyright(c) 2009-2012 Realtek Corporation. | ||
4 | * | ||
5 | * This program is free software; you can redistribute it and/or modify it | ||
6 | * under the terms of version 2 of the GNU General Public License as | ||
7 | * published by the Free Software Foundation. | ||
8 | * | ||
9 | * This program is distributed in the hope that it will be useful, but WITHOUT | ||
10 | * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | ||
11 | * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for | ||
12 | * more details. | ||
13 | * | ||
14 | * You should have received a copy of the GNU General Public License along with | ||
15 | * this program; if not, write to the Free Software Foundation, Inc., | ||
16 | * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA | ||
17 | * | ||
18 | * The full GNU General Public License is included in this distribution in the | ||
19 | * file called LICENSE. | ||
20 | * | ||
21 | * Contact Information: | ||
22 | * wlanfae <wlanfae@realtek.com> | ||
23 | * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park, | ||
24 | * Hsinchu 300, Taiwan. | ||
25 | * | ||
26 | * Larry Finger <Larry.Finger@lwfinger.net> | ||
27 | * | ||
28 | *****************************************************************************/ | ||
29 | |||
30 | #ifndef __RTL8723E_PWRSEQCMD_H__ | ||
31 | #define __RTL8723E_PWRSEQCMD_H__ | ||
32 | |||
33 | #include "../wifi.h" | ||
34 | /*--------------------------------------------- | ||
35 | * 3 The value of cmd: 4 bits | ||
36 | *--------------------------------------------- | ||
37 | */ | ||
38 | #define PWR_CMD_READ 0x00 | ||
39 | #define PWR_CMD_WRITE 0x01 | ||
40 | #define PWR_CMD_POLLING 0x02 | ||
41 | #define PWR_CMD_DELAY 0x03 | ||
42 | #define PWR_CMD_END 0x04 | ||
43 | |||
44 | /* define the base address of each block */ | ||
45 | #define PWR_BASEADDR_MAC 0x00 | ||
46 | #define PWR_BASEADDR_USB 0x01 | ||
47 | #define PWR_BASEADDR_PCIE 0x02 | ||
48 | #define PWR_BASEADDR_SDIO 0x03 | ||
49 | |||
50 | #define PWR_INTF_SDIO_MSK BIT(0) | ||
51 | #define PWR_INTF_USB_MSK BIT(1) | ||
52 | #define PWR_INTF_PCI_MSK BIT(2) | ||
53 | #define PWR_INTF_ALL_MSK (BIT(0)|BIT(1)|BIT(2)|BIT(3)) | ||
54 | |||
55 | #define PWR_FAB_TSMC_MSK BIT(0) | ||
56 | #define PWR_FAB_UMC_MSK BIT(1) | ||
57 | #define PWR_FAB_ALL_MSK (BIT(0)|BIT(1)|BIT(2)|BIT(3)) | ||
58 | |||
59 | #define PWR_CUT_TESTCHIP_MSK BIT(0) | ||
60 | #define PWR_CUT_A_MSK BIT(1) | ||
61 | #define PWR_CUT_B_MSK BIT(2) | ||
62 | #define PWR_CUT_C_MSK BIT(3) | ||
63 | #define PWR_CUT_D_MSK BIT(4) | ||
64 | #define PWR_CUT_E_MSK BIT(5) | ||
65 | #define PWR_CUT_F_MSK BIT(6) | ||
66 | #define PWR_CUT_G_MSK BIT(7) | ||
67 | #define PWR_CUT_ALL_MSK 0xFF | ||
68 | |||
69 | enum pwrseq_delay_unit { | ||
70 | PWRSEQ_DELAY_US, | ||
71 | PWRSEQ_DELAY_MS, | ||
72 | }; | ||
73 | |||
74 | struct wlan_pwr_cfg { | ||
75 | u16 offset; | ||
76 | u8 cut_msk; | ||
77 | u8 fab_msk:4; | ||
78 | u8 interface_msk:4; | ||
79 | u8 base:4; | ||
80 | u8 cmd:4; | ||
81 | u8 msk; | ||
82 | u8 value; | ||
83 | }; | ||
84 | |||
85 | #define GET_PWR_CFG_OFFSET(__PWR_CMD) (__PWR_CMD.offset) | ||
86 | #define GET_PWR_CFG_CUT_MASK(__PWR_CMD) (__PWR_CMD.cut_msk) | ||
87 | #define GET_PWR_CFG_FAB_MASK(__PWR_CMD) (__PWR_CMD.fab_msk) | ||
88 | #define GET_PWR_CFG_INTF_MASK(__PWR_CMD) (__PWR_CMD.interface_msk) | ||
89 | #define GET_PWR_CFG_BASE(__PWR_CMD) (__PWR_CMD.base) | ||
90 | #define GET_PWR_CFG_CMD(__PWR_CMD) (__PWR_CMD.cmd) | ||
91 | #define GET_PWR_CFG_MASK(__PWR_CMD) (__PWR_CMD.msk) | ||
92 | #define GET_PWR_CFG_VALUE(__PWR_CMD) (__PWR_CMD.value) | ||
93 | |||
94 | bool rtl_hal_pwrseqcmdparsing(struct rtl_priv *rtlpriv, u8 cut_version, | ||
95 | u8 fab_version, u8 interface_type, | ||
96 | struct wlan_pwr_cfg pwrcfgcmd[]); | ||
97 | |||
98 | #endif | ||