1*5113495bSYour Name /*
2*5113495bSYour Name * Copyright (c) 2017-2018 The Linux Foundation. All rights reserved.
3*5113495bSYour Name *
4*5113495bSYour Name * Permission to use, copy, modify, and/or distribute this software for
5*5113495bSYour Name * any purpose with or without fee is hereby granted, provided that the
6*5113495bSYour Name * above copyright notice and this permission notice appear in all
7*5113495bSYour Name * copies.
8*5113495bSYour Name *
9*5113495bSYour Name * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
10*5113495bSYour Name * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
11*5113495bSYour Name * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
12*5113495bSYour Name * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
13*5113495bSYour Name * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
14*5113495bSYour Name * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
15*5113495bSYour Name * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
16*5113495bSYour Name * PERFORMANCE OF THIS SOFTWARE.
17*5113495bSYour Name */
18*5113495bSYour Name /**
19*5113495bSYour Name * DOC: target_if_pmo_wow.c
20*5113495bSYour Name *
21*5113495bSYour Name * Target interface file for pmo component to
22*5113495bSYour Name * send wow related cmd and process event.
23*5113495bSYour Name */
24*5113495bSYour Name
25*5113495bSYour Name
26*5113495bSYour Name #include "target_if.h"
27*5113495bSYour Name #include "target_if_pmo.h"
28*5113495bSYour Name #include "wmi_unified_api.h"
29*5113495bSYour Name
target_if_pmo_enable_wow_wakeup_event(struct wlan_objmgr_vdev * vdev,uint32_t * bitmap)30*5113495bSYour Name QDF_STATUS target_if_pmo_enable_wow_wakeup_event(struct wlan_objmgr_vdev *vdev,
31*5113495bSYour Name uint32_t *bitmap)
32*5113495bSYour Name {
33*5113495bSYour Name uint8_t vdev_id;
34*5113495bSYour Name struct wlan_objmgr_psoc *psoc;
35*5113495bSYour Name QDF_STATUS status;
36*5113495bSYour Name wmi_unified_t wmi_handle;
37*5113495bSYour Name
38*5113495bSYour Name if (!vdev) {
39*5113495bSYour Name target_if_err("vdev ptr passed is NULL");
40*5113495bSYour Name return QDF_STATUS_E_INVAL;
41*5113495bSYour Name }
42*5113495bSYour Name
43*5113495bSYour Name psoc = wlan_vdev_get_psoc(vdev);
44*5113495bSYour Name vdev_id = wlan_vdev_get_id(vdev);
45*5113495bSYour Name if (!psoc) {
46*5113495bSYour Name target_if_err("psoc handle is NULL");
47*5113495bSYour Name return QDF_STATUS_E_INVAL;
48*5113495bSYour Name }
49*5113495bSYour Name
50*5113495bSYour Name wmi_handle = get_wmi_unified_hdl_from_psoc(psoc);
51*5113495bSYour Name if (!wmi_handle) {
52*5113495bSYour Name target_if_err("Invalid wmi handle");
53*5113495bSYour Name return QDF_STATUS_E_INVAL;
54*5113495bSYour Name }
55*5113495bSYour Name
56*5113495bSYour Name status = wmi_unified_add_wow_wakeup_event_cmd(wmi_handle, vdev_id,
57*5113495bSYour Name bitmap, true);
58*5113495bSYour Name if (status)
59*5113495bSYour Name target_if_err("Failed to config wow wakeup event");
60*5113495bSYour Name
61*5113495bSYour Name return status;
62*5113495bSYour Name }
63*5113495bSYour Name
target_if_pmo_disable_wow_wakeup_event(struct wlan_objmgr_vdev * vdev,uint32_t * bitmap)64*5113495bSYour Name QDF_STATUS target_if_pmo_disable_wow_wakeup_event(struct wlan_objmgr_vdev *vdev,
65*5113495bSYour Name uint32_t *bitmap)
66*5113495bSYour Name {
67*5113495bSYour Name uint8_t vdev_id;
68*5113495bSYour Name struct wlan_objmgr_psoc *psoc;
69*5113495bSYour Name QDF_STATUS status;
70*5113495bSYour Name wmi_unified_t wmi_handle;
71*5113495bSYour Name
72*5113495bSYour Name if (!vdev) {
73*5113495bSYour Name target_if_err("vdev ptr passed is NULL");
74*5113495bSYour Name return QDF_STATUS_E_INVAL;
75*5113495bSYour Name }
76*5113495bSYour Name
77*5113495bSYour Name psoc = wlan_vdev_get_psoc(vdev);
78*5113495bSYour Name vdev_id = wlan_vdev_get_id(vdev);
79*5113495bSYour Name if (!psoc) {
80*5113495bSYour Name target_if_err("psoc handle is NULL");
81*5113495bSYour Name return QDF_STATUS_E_INVAL;
82*5113495bSYour Name }
83*5113495bSYour Name
84*5113495bSYour Name wmi_handle = get_wmi_unified_hdl_from_psoc(psoc);
85*5113495bSYour Name if (!wmi_handle) {
86*5113495bSYour Name target_if_err("Invalid wmi handle");
87*5113495bSYour Name return QDF_STATUS_E_INVAL;
88*5113495bSYour Name }
89*5113495bSYour Name
90*5113495bSYour Name status = wmi_unified_add_wow_wakeup_event_cmd(wmi_handle, vdev_id,
91*5113495bSYour Name bitmap, false);
92*5113495bSYour Name if (status)
93*5113495bSYour Name target_if_err("Failed to config wow wakeup event");
94*5113495bSYour Name
95*5113495bSYour Name return status;
96*5113495bSYour Name }
97*5113495bSYour Name
target_if_pmo_send_wow_patterns_to_fw(struct wlan_objmgr_vdev * vdev,uint8_t ptrn_id,const uint8_t * ptrn,uint8_t ptrn_len,uint8_t ptrn_offset,const uint8_t * mask,uint8_t mask_len,bool user)98*5113495bSYour Name QDF_STATUS target_if_pmo_send_wow_patterns_to_fw(struct wlan_objmgr_vdev *vdev,
99*5113495bSYour Name uint8_t ptrn_id,
100*5113495bSYour Name const uint8_t *ptrn, uint8_t ptrn_len,
101*5113495bSYour Name uint8_t ptrn_offset, const uint8_t *mask,
102*5113495bSYour Name uint8_t mask_len, bool user)
103*5113495bSYour Name {
104*5113495bSYour Name uint8_t vdev_id;
105*5113495bSYour Name struct wlan_objmgr_psoc *psoc;
106*5113495bSYour Name QDF_STATUS status;
107*5113495bSYour Name wmi_unified_t wmi_handle;
108*5113495bSYour Name
109*5113495bSYour Name if (!vdev) {
110*5113495bSYour Name target_if_err("vdev ptr passed is NULL");
111*5113495bSYour Name return QDF_STATUS_E_INVAL;
112*5113495bSYour Name }
113*5113495bSYour Name
114*5113495bSYour Name psoc = wlan_vdev_get_psoc(vdev);
115*5113495bSYour Name vdev_id = wlan_vdev_get_id(vdev);
116*5113495bSYour Name if (!psoc) {
117*5113495bSYour Name target_if_err("psoc handle is NULL");
118*5113495bSYour Name return QDF_STATUS_E_INVAL;
119*5113495bSYour Name }
120*5113495bSYour Name
121*5113495bSYour Name wmi_handle = get_wmi_unified_hdl_from_psoc(psoc);
122*5113495bSYour Name if (!wmi_handle) {
123*5113495bSYour Name target_if_err("Invalid wmi handle");
124*5113495bSYour Name return QDF_STATUS_E_INVAL;
125*5113495bSYour Name }
126*5113495bSYour Name
127*5113495bSYour Name status = wmi_unified_wow_patterns_to_fw_cmd(wmi_handle,
128*5113495bSYour Name vdev_id, ptrn_id, ptrn,
129*5113495bSYour Name ptrn_len, ptrn_offset,
130*5113495bSYour Name mask, mask_len, user, 0);
131*5113495bSYour Name
132*5113495bSYour Name return status;
133*5113495bSYour Name }
134*5113495bSYour Name
target_if_pmo_del_wow_patterns_to_fw(struct wlan_objmgr_vdev * vdev,uint8_t ptrn_id)135*5113495bSYour Name QDF_STATUS target_if_pmo_del_wow_patterns_to_fw(struct wlan_objmgr_vdev *vdev,
136*5113495bSYour Name uint8_t ptrn_id)
137*5113495bSYour Name {
138*5113495bSYour Name uint8_t vdev_id;
139*5113495bSYour Name struct wlan_objmgr_psoc *psoc;
140*5113495bSYour Name QDF_STATUS status;
141*5113495bSYour Name wmi_unified_t wmi_handle;
142*5113495bSYour Name
143*5113495bSYour Name if (!vdev) {
144*5113495bSYour Name target_if_err("vdev ptr passed is NULL");
145*5113495bSYour Name return QDF_STATUS_E_INVAL;
146*5113495bSYour Name }
147*5113495bSYour Name
148*5113495bSYour Name psoc = wlan_vdev_get_psoc(vdev);
149*5113495bSYour Name vdev_id = wlan_vdev_get_id(vdev);
150*5113495bSYour Name if (!psoc) {
151*5113495bSYour Name target_if_err("psoc handle is NULL");
152*5113495bSYour Name return QDF_STATUS_E_INVAL;
153*5113495bSYour Name }
154*5113495bSYour Name
155*5113495bSYour Name wmi_handle = get_wmi_unified_hdl_from_psoc(psoc);
156*5113495bSYour Name if (!wmi_handle) {
157*5113495bSYour Name target_if_err("Invalid wmi handle");
158*5113495bSYour Name return QDF_STATUS_E_INVAL;
159*5113495bSYour Name }
160*5113495bSYour Name
161*5113495bSYour Name status = wmi_unified_wow_delete_pattern_cmd(wmi_handle, ptrn_id,
162*5113495bSYour Name vdev_id);
163*5113495bSYour Name
164*5113495bSYour Name return status;
165*5113495bSYour Name }
166*5113495bSYour Name
167