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