hc
2023-12-09 b22da3d8526a935aa31e086e63f60ff3246cb61c
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
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
// SPDX-License-Identifier: GPL-2.0
/******************************************************************************
 *
 * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
 *
 ******************************************************************************/
 
#include "pwrseq.h"
#include <rtl8188e_hal.h>
 
/* drivers should parse below arrays and do the corresponding actions */
 
/* 3 Power on  Array */
struct wl_pwr_cfg rtl8188E_power_on_flow[RTL8188E_TRANS_CARDEMU_TO_ACT_STEPS +
                    RTL8188E_TRANS_END_STEPS] = {
   RTL8188E_TRANS_CARDEMU_TO_ACT
   RTL8188E_TRANS_END
};
 
/* 3Radio off Array */
struct wl_pwr_cfg rtl8188E_radio_off_flow[RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS +
                     RTL8188E_TRANS_END_STEPS] = {
   RTL8188E_TRANS_ACT_TO_CARDEMU
   RTL8188E_TRANS_END
};
 
/* 3Card Disable Array */
struct wl_pwr_cfg rtl8188E_card_disable_flow
   [RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS +
    RTL8188E_TRANS_CARDEMU_TO_PDN_STEPS +
    RTL8188E_TRANS_END_STEPS] = {
       RTL8188E_TRANS_ACT_TO_CARDEMU
       RTL8188E_TRANS_CARDEMU_TO_CARDDIS
       RTL8188E_TRANS_END
};
 
/* 3 Card Enable Array */
struct wl_pwr_cfg rtl8188E_card_enable_flow
   [RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS +
    RTL8188E_TRANS_CARDEMU_TO_PDN_STEPS +
    RTL8188E_TRANS_END_STEPS] = {
       RTL8188E_TRANS_CARDDIS_TO_CARDEMU
       RTL8188E_TRANS_CARDEMU_TO_ACT
       RTL8188E_TRANS_END
};
 
/* 3Suspend Array */
struct wl_pwr_cfg rtl8188E_suspend_flow[RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS +
                   RTL8188E_TRANS_CARDEMU_TO_SUS_STEPS +
                   RTL8188E_TRANS_END_STEPS] = {
   RTL8188E_TRANS_ACT_TO_CARDEMU
   RTL8188E_TRANS_CARDEMU_TO_SUS
   RTL8188E_TRANS_END
};
 
/* 3 Resume Array */
struct wl_pwr_cfg rtl8188E_resume_flow[RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS +
                      RTL8188E_TRANS_CARDEMU_TO_SUS_STEPS +
                      RTL8188E_TRANS_END_STEPS] = {
   RTL8188E_TRANS_SUS_TO_CARDEMU
   RTL8188E_TRANS_CARDEMU_TO_ACT
   RTL8188E_TRANS_END
};
 
/* 3HWPDN Array */
struct wl_pwr_cfg rtl8188E_hwpdn_flow[RTL8188E_TRANS_ACT_TO_CARDEMU_STEPS +
                     RTL8188E_TRANS_CARDEMU_TO_PDN_STEPS +
                     RTL8188E_TRANS_END_STEPS] = {
   RTL8188E_TRANS_ACT_TO_CARDEMU
   RTL8188E_TRANS_CARDEMU_TO_PDN
   RTL8188E_TRANS_END
};
 
/* 3 Enter LPS */
struct wl_pwr_cfg rtl8188E_enter_lps_flow[RTL8188E_TRANS_ACT_TO_LPS_STEPS +
                     RTL8188E_TRANS_END_STEPS] = {
   /* FW behavior */
   RTL8188E_TRANS_ACT_TO_LPS
   RTL8188E_TRANS_END
};
 
/* 3 Leave LPS */
struct wl_pwr_cfg rtl8188E_leave_lps_flow[RTL8188E_TRANS_LPS_TO_ACT_STEPS +
                     RTL8188E_TRANS_END_STEPS] = {
   /* FW behavior */
   RTL8188E_TRANS_LPS_TO_ACT
   RTL8188E_TRANS_END
};