blob: ac38ecf13c18103de520b66706877881aa62fd63 [file] [log] [blame]
Johannes Berg8ca151b2013-01-24 14:25:36 +01001/******************************************************************************
2 *
3 * This file is provided under a dual BSD/GPLv2 license. When using or
4 * redistributing this file, you may do so under either license.
5 *
6 * GPL LICENSE SUMMARY
7 *
8 * Copyright(c) 2012 - 2013 Intel Corporation. All rights reserved.
9 *
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of version 2 of the GNU General Public License as
12 * published by the Free Software Foundation.
13 *
14 * This program is distributed in the hope that it will be useful, but
15 * WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17 * General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110,
22 * USA
23 *
24 * The full GNU General Public License is included in this distribution
Emmanuel Grumbach410dc5a2013-02-18 09:22:28 +020025 * in the file called COPYING.
Johannes Berg8ca151b2013-01-24 14:25:36 +010026 *
27 * Contact Information:
28 * Intel Linux Wireless <ilw@linux.intel.com>
29 * Intel Corporation, 5200 N.E. Elam Young Parkway, Hillsboro, OR 97124-6497
30 *
31 * BSD LICENSE
32 *
33 * Copyright(c) 2012 - 2013 Intel Corporation. All rights reserved.
34 * All rights reserved.
35 *
36 * Redistribution and use in source and binary forms, with or without
37 * modification, are permitted provided that the following conditions
38 * are met:
39 *
40 * * Redistributions of source code must retain the above copyright
41 * notice, this list of conditions and the following disclaimer.
42 * * Redistributions in binary form must reproduce the above copyright
43 * notice, this list of conditions and the following disclaimer in
44 * the documentation and/or other materials provided with the
45 * distribution.
46 * * Neither the name Intel Corporation nor the names of its
47 * contributors may be used to endorse or promote products derived
48 * from this software without specific prior written permission.
49 *
50 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
51 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
52 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
53 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
54 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
55 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
56 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
57 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
58 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
59 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
60 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
61 *
62 *****************************************************************************/
63
64#ifndef __fw_api_power_h__
65#define __fw_api_power_h__
66
67/* Power Management Commands, Responses, Notifications */
68
69/**
Emmanuel Grumbach597b3892014-09-23 23:02:41 +030070 * enum iwl_ltr_config_flags - masks for LTR config command flags
71 * @LTR_CFG_FLAG_FEATURE_ENABLE: Feature operational status
72 * @LTR_CFG_FLAG_HW_DIS_ON_SHADOW_REG_ACCESS: allow LTR change on shadow
73 * memory access
74 * @LTR_CFG_FLAG_HW_EN_SHRT_WR_THROUGH: allow LTR msg send on ANY LTR
75 * reg change
76 * @LTR_CFG_FLAG_HW_DIS_ON_D0_2_D3: allow LTR msg send on transition from
77 * D0 to D3
78 * @LTR_CFG_FLAG_SW_SET_SHORT: fixed static short LTR register
79 * @LTR_CFG_FLAG_SW_SET_LONG: fixed static short LONG register
80 * @LTR_CFG_FLAG_DENIE_C10_ON_PD: allow going into C10 on PD
81 */
82enum iwl_ltr_config_flags {
83 LTR_CFG_FLAG_FEATURE_ENABLE = BIT(0),
84 LTR_CFG_FLAG_HW_DIS_ON_SHADOW_REG_ACCESS = BIT(1),
85 LTR_CFG_FLAG_HW_EN_SHRT_WR_THROUGH = BIT(2),
86 LTR_CFG_FLAG_HW_DIS_ON_D0_2_D3 = BIT(3),
87 LTR_CFG_FLAG_SW_SET_SHORT = BIT(4),
88 LTR_CFG_FLAG_SW_SET_LONG = BIT(5),
89 LTR_CFG_FLAG_DENIE_C10_ON_PD = BIT(6),
90};
91
92/**
93 * struct iwl_ltr_config_cmd - configures the LTR
94 * @flags: See %enum iwl_ltr_config_flags
95 */
96struct iwl_ltr_config_cmd {
97 __le32 flags;
98 __le32 static_long;
99 __le32 static_short;
100} __packed;
101
102/**
103 * enum iwl_power_flags - masks for power table command flags
Alexander Bondar83bdad52013-02-03 21:26:44 +0200104 * @POWER_FLAGS_POWER_SAVE_ENA_MSK: '1' Allow to save power by turning off
105 * receiver and transmitter. '0' - does not allow.
Johannes Berg8ca151b2013-01-24 14:25:36 +0100106 * @POWER_FLAGS_POWER_MANAGEMENT_ENA_MSK: '0' Driver disables power management,
107 * '1' Driver enables PM (use rest of parameters)
Alexander Bondarf4a3e2f2013-03-05 13:47:04 +0200108 * @POWER_FLAGS_SKIP_OVER_DTIM_MSK: '0' PM have to walk up every DTIM,
Johannes Berg8ca151b2013-01-24 14:25:36 +0100109 * '1' PM could sleep over DTIM till listen Interval.
Johannes Berg8ca151b2013-01-24 14:25:36 +0100110 * @POWER_FLAGS_ADVANCE_PM_ENA_MSK: Advanced PM (uAPSD) enable mask
Alexander Bondar83bdad52013-02-03 21:26:44 +0200111 * @POWER_FLAGS_LPRX_ENA_MSK: Low Power RX enable.
Johannes Berg8ca151b2013-01-24 14:25:36 +0100112*/
113enum iwl_power_flags {
Alexander Bondar83bdad52013-02-03 21:26:44 +0200114 POWER_FLAGS_POWER_SAVE_ENA_MSK = BIT(0),
115 POWER_FLAGS_POWER_MANAGEMENT_ENA_MSK = BIT(1),
Alexander Bondarf4a3e2f2013-03-05 13:47:04 +0200116 POWER_FLAGS_SKIP_OVER_DTIM_MSK = BIT(2),
Alexander Bondar83bdad52013-02-03 21:26:44 +0200117 POWER_FLAGS_ADVANCE_PM_ENA_MSK = BIT(9),
118 POWER_FLAGS_LPRX_ENA_MSK = BIT(11),
Johannes Berg8ca151b2013-01-24 14:25:36 +0100119};
120
Alexander Bondar83bdad52013-02-03 21:26:44 +0200121#define IWL_POWER_VEC_SIZE 5
122
Johannes Berg8ca151b2013-01-24 14:25:36 +0100123/**
124 * struct iwl_powertable_cmd - Power Table Command
125 * POWER_TABLE_CMD = 0x77 (command, has simple generic response)
126 *
Johannes Berg8ca151b2013-01-24 14:25:36 +0100127 * @flags: Power table command flags from POWER_FLAGS_*
128 * @keep_alive_seconds: Keep alive period in seconds. Default - 25 sec.
Alexander Bondare16cf7e2013-03-05 14:01:27 +0200129 * Minimum allowed:- 3 * DTIM. Keep alive period must be
130 * set regardless of power scheme or current power state.
131 * FW use this value also when PM is disabled.
Johannes Berg8ca151b2013-01-24 14:25:36 +0100132 * @rx_data_timeout: Minimum time (usec) from last Rx packet for AM to
133 * PSM transition - legacy PM
134 * @tx_data_timeout: Minimum time (usec) from last Tx packet for AM to
135 * PSM transition - legacy PM
Alexander Bondar83bdad52013-02-03 21:26:44 +0200136 * @sleep_interval: not in use
137 * @keep_alive_beacons: not in use
Johannes Berg8ca151b2013-01-24 14:25:36 +0100138 * @lprx_rssi_threshold: Signal strength up to which LP RX can be enabled.
139 * Default: 80dbm
Johannes Berg8ca151b2013-01-24 14:25:36 +0100140 */
141struct iwl_powertable_cmd {
Alexander Bondar83bdad52013-02-03 21:26:44 +0200142 /* PM_POWER_TABLE_CMD_API_S_VER_5 */
Johannes Berg8ca151b2013-01-24 14:25:36 +0100143 __le16 flags;
Alexander Bondar83bdad52013-02-03 21:26:44 +0200144 u8 keep_alive_seconds;
145 u8 debug_flags;
Johannes Berg8ca151b2013-01-24 14:25:36 +0100146 __le32 rx_data_timeout;
147 __le32 tx_data_timeout;
Alexander Bondar83bdad52013-02-03 21:26:44 +0200148 __le32 sleep_interval[IWL_POWER_VEC_SIZE];
149 __le32 keep_alive_beacons;
150 __le32 lprx_rssi_threshold;
Johannes Berg8ca151b2013-01-24 14:25:36 +0100151} __packed;
152
153#endif