Merge tag 'nfs-for-3.14-3' of git://git.linux-nfs.org/projects/trondmy/linux-nfs
[platform/adaptation/renesas_rcar/renesas_kernel.git] / drivers / staging / rtl8821ae / rtl8821ae / pwrseqcmd.c
1 /******************************************************************************
2  *
3  * Copyright(c) 2009-2010  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 #include "pwrseq.h"
31
32
33 /*
34 *       Description:
35 *               This routine deal with the Power Configuration CMDs
36 *                parsing for RTL8723/RTL8188E Series IC.
37 *       Assumption:
38 *               We should follow specific format which was released from HW SD.
39 *
40 *       2011.07.07, added by Roger.
41 */
42 bool rtl_hal_pwrseqcmdparsing (struct rtl_priv* rtlpriv, u8 cut_version,
43                                                                                 u8 fab_version, u8 interface_type,
44                                                                                 struct wlan_pwr_cfg     pwrcfgcmd[])
45
46 {
47         struct wlan_pwr_cfg pwr_cfg_cmd = {0};
48         bool polling_bit = false;
49         u32 ary_idx=0;
50         u8 value = 0;
51         u32 offset = 0;
52         u32 polling_count = 0;
53         u32 max_polling_cnt = 5000;
54
55         do {
56                 pwr_cfg_cmd = pwrcfgcmd[ary_idx];
57                 RT_TRACE(COMP_INIT, DBG_TRACE,
58                         ("rtl_hal_pwrseqcmdparsing(): offset(%#x),cut_msk(%#x), fab_msk(%#x),"
59                         "interface_msk(%#x), base(%#x), cmd(%#x), msk(%#x), value(%#x)\n",
60                         GET_PWR_CFG_OFFSET(pwr_cfg_cmd), GET_PWR_CFG_CUT_MASK(pwr_cfg_cmd),
61                         GET_PWR_CFG_FAB_MASK(pwr_cfg_cmd), GET_PWR_CFG_INTF_MASK(pwr_cfg_cmd),
62                         GET_PWR_CFG_BASE(pwr_cfg_cmd), GET_PWR_CFG_CMD(pwr_cfg_cmd),
63                         GET_PWR_CFG_MASK(pwr_cfg_cmd), GET_PWR_CFG_VALUE(pwr_cfg_cmd)));
64
65                 if ((GET_PWR_CFG_FAB_MASK(pwr_cfg_cmd)&fab_version) &&
66                         (GET_PWR_CFG_CUT_MASK(pwr_cfg_cmd)&cut_version) &&
67                         (GET_PWR_CFG_INTF_MASK(pwr_cfg_cmd)&interface_type)) {
68                         switch (GET_PWR_CFG_CMD(pwr_cfg_cmd)) {
69                         case PWR_CMD_READ:
70                                 RT_TRACE(COMP_INIT, DBG_TRACE,
71                                         ("rtl_hal_pwrseqcmdparsing(): PWR_CMD_READ\n"));
72                                 break;
73
74                         case PWR_CMD_WRITE: {
75                                 RT_TRACE(COMP_INIT, DBG_TRACE,
76                                         ("rtl_hal_pwrseqcmdparsing(): PWR_CMD_WRITE\n"));
77                                 offset = GET_PWR_CFG_OFFSET(pwr_cfg_cmd);
78
79                                         /*Read the value from system register*/
80                                         value = rtl_read_byte(rtlpriv, offset);
81                                         value = value & (~(GET_PWR_CFG_MASK(pwr_cfg_cmd)));
82                                         value = value | (GET_PWR_CFG_VALUE(pwr_cfg_cmd)
83                                                         & GET_PWR_CFG_MASK(pwr_cfg_cmd));
84
85                                         /*Write the value back to sytem register*/
86                                         rtl_write_byte(rtlpriv, offset, value);
87                                 }
88                                 break;
89
90                         case PWR_CMD_POLLING:
91                                 RT_TRACE(COMP_INIT, DBG_TRACE,
92                                         ("rtl_hal_pwrseqcmdparsing(): PWR_CMD_POLLING\n"));
93                                 polling_bit = false;
94                                 offset = GET_PWR_CFG_OFFSET(pwr_cfg_cmd);
95
96                                 do {
97                                         value = rtl_read_byte(rtlpriv, offset);
98
99                                         value = value & GET_PWR_CFG_MASK(pwr_cfg_cmd);
100                                         if (value == (GET_PWR_CFG_VALUE(pwr_cfg_cmd)
101                                                         & GET_PWR_CFG_MASK(pwr_cfg_cmd)))
102                                                 polling_bit=true;
103                                         else
104                                                 udelay(10);
105
106                                         if (polling_count++ > max_polling_cnt) {
107                                                 return false;
108                                         }
109                                 } while (!polling_bit);
110
111                                 break;
112
113                         case PWR_CMD_DELAY:
114                                 RT_TRACE(COMP_INIT, DBG_TRACE,
115                                         ("rtl_hal_pwrseqcmdparsing(): PWR_CMD_DELAY\n"));
116                                 if (GET_PWR_CFG_VALUE(pwr_cfg_cmd) == PWRSEQ_DELAY_US)
117                                         udelay(GET_PWR_CFG_OFFSET(pwr_cfg_cmd));
118                                 else
119                                         mdelay(GET_PWR_CFG_OFFSET(pwr_cfg_cmd));
120                                 break;
121
122                         case PWR_CMD_END:
123                                 RT_TRACE(COMP_INIT, DBG_TRACE,
124                                         ("rtl_hal_pwrseqcmdparsing(): PWR_CMD_END\n"));
125                                 return true;
126                                 break;
127
128                         default:
129                                 RT_ASSERT(false,
130                                         ("rtl_hal_pwrseqcmdparsing(): Unknown CMD!!\n"));
131                                 break;
132                         }
133
134                 }
135
136                 ary_idx++;
137         } while (1);
138
139         return true;
140 }