blob: 859b60b5335c2b87f3ce1359b13897834ef792e3 [file] [log] [blame]
Mohamed Abbas5da4b552008-04-21 15:41:51 -07001/******************************************************************************
2 *
Reinette Chatre01f81622009-01-08 10:20:02 -08003 * Copyright(c) 2007 - 2009 Intel Corporation. All rights reserved.
Mohamed Abbas5da4b552008-04-21 15:41:51 -07004 *
5 * Portions of this file are derived from the ipw3945 project, as well
6 * as portions of the ieee80211 subsystem header files.
7 *
8 * This program is free software; you can redistribute it and/or modify it
9 * under the terms of version 2 of the GNU General Public License as
10 * published by the Free Software Foundation.
11 *
12 * This program is distributed in the hope that it will be useful, but WITHOUT
13 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
14 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
15 * more details.
16 *
17 * You should have received a copy of the GNU General Public License along with
18 * this program; if not, write to the Free Software Foundation, Inc.,
19 * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
20 *
21 * The full GNU General Public License is included in this distribution in the
22 * file called LICENSE.
23 *
24 * Contact Information:
Winkler, Tomas759ef892008-12-09 11:28:58 -080025 * Intel Linux Wireless <ilw@linux.intel.com>
Mohamed Abbas5da4b552008-04-21 15:41:51 -070026 * Intel Corporation, 5200 N.E. Elam Young Parkway, Hillsboro, OR 97124-6497
27 *****************************************************************************/
28#ifndef __iwl_power_setting_h__
29#define __iwl_power_setting_h__
30
31#include <net/mac80211.h>
Tomas Winkler5a36ba02008-04-24 11:55:37 -070032#include "iwl-commands.h"
Mohamed Abbas5da4b552008-04-21 15:41:51 -070033
34struct iwl_priv;
35
Esti Kummer298df1f2008-07-18 13:52:58 +080036enum {
37 IWL_POWER_MODE_CAM, /* Continuously Aware Mode, always on */
38 IWL_POWER_INDEX_1,
39 IWL_POWER_INDEX_2,
40 IWL_POWER_INDEX_3,
41 IWL_POWER_INDEX_4,
42 IWL_POWER_INDEX_5,
43 IWL_POWER_AUTO,
44 IWL_POWER_MAX = IWL_POWER_AUTO,
Samuel Ortiz1125eff2008-12-19 10:37:14 +080045 IWL39_POWER_AC = IWL_POWER_AUTO, /* 0x06 */
Esti Kummer298df1f2008-07-18 13:52:58 +080046 IWL_POWER_AC,
Samuel Ortiz1125eff2008-12-19 10:37:14 +080047 IWL39_POWER_BATTERY = IWL_POWER_AC, /* 0x07 */
48 IWL39_POWER_LIMIT = IWL_POWER_AC,
Esti Kummer298df1f2008-07-18 13:52:58 +080049 IWL_POWER_BATTERY,
50};
51
52enum {
53 IWL_POWER_SYS_AUTO,
54 IWL_POWER_SYS_AC,
55 IWL_POWER_SYS_BATTERY,
56};
57
Mohamed Abbas5da4b552008-04-21 15:41:51 -070058#define IWL_POWER_LIMIT 0x08
59#define IWL_POWER_MASK 0x0F
60#define IWL_POWER_ENABLED 0x10
61
Samuel Ortiz1125eff2008-12-19 10:37:14 +080062#define IWL_POWER_RANGE_0 (0)
63#define IWL_POWER_RANGE_1 (1)
64
65#define IWL_POWER_LEVEL(x) ((x) & IWL_POWER_MASK)
66
Mohamed Abbas5da4b552008-04-21 15:41:51 -070067/* Power management (not Tx power) structures */
68
Winkler, Tomas3dae0c42009-01-19 15:30:30 -080069#define NOSLP __constant_cpu_to_le16(0), 0, 0
70#define SLP IWL_POWER_DRIVER_ALLOW_SLEEP_MSK, 0, 0
71#define SLP_TOUT(T) __constant_cpu_to_le32((T) * MSEC_TO_USEC)
72#define SLP_VEC(X0, X1, X2, X3, X4) {__constant_cpu_to_le32(X0), \
73 __constant_cpu_to_le32(X1), \
74 __constant_cpu_to_le32(X2), \
75 __constant_cpu_to_le32(X3), \
76 __constant_cpu_to_le32(X4)}
Mohamed Abbas5da4b552008-04-21 15:41:51 -070077struct iwl_power_vec_entry {
Mohamed Abbasca579612008-07-18 13:52:57 +080078 struct iwl_powertable_cmd cmd;
Mohamed Abbas5da4b552008-04-21 15:41:51 -070079 u8 no_dtim;
80};
81
82struct iwl_power_mgr {
83 spinlock_t lock;
Esti Kummer298df1f2008-07-18 13:52:58 +080084 struct iwl_power_vec_entry pwr_range_0[IWL_POWER_MAX];
85 struct iwl_power_vec_entry pwr_range_1[IWL_POWER_MAX];
86 struct iwl_power_vec_entry pwr_range_2[IWL_POWER_MAX];
Mohamed Abbas5da4b552008-04-21 15:41:51 -070087 u32 dtim_period;
88 /* final power level that used to calculate final power command */
89 u8 power_mode;
90 u8 user_power_setting; /* set by user through mac80211 or sysfs */
Emmanuel Grumbacha33c2f42008-09-03 11:26:56 +080091 u8 system_power_setting; /* set by kernel system tools */
Mohamed Abbas5da4b552008-04-21 15:41:51 -070092 u8 critical_power_setting; /* set if driver over heated */
93 u8 is_battery_active; /* DC/AC power */
94 u8 power_disabled; /* flag to disable using power saving level */
95};
96
Emmanuel Grumbachc90a74ba2008-09-03 11:26:50 +080097void iwl_setup_power_deferred_work(struct iwl_priv *priv);
98void iwl_power_cancel_timeout(struct iwl_priv *priv);
Grumbach, Emmanuel04816442008-09-03 11:26:53 +080099int iwl_power_update_mode(struct iwl_priv *priv, bool force);
Emmanuel Grumbachc90a74ba2008-09-03 11:26:50 +0800100int iwl_power_disable_management(struct iwl_priv *priv, u32 ms);
Mohamed Abbas5da4b552008-04-21 15:41:51 -0700101int iwl_power_enable_management(struct iwl_priv *priv);
102int iwl_power_set_user_mode(struct iwl_priv *priv, u16 mode);
103int iwl_power_set_system_mode(struct iwl_priv *priv, u16 mode);
104void iwl_power_initialize(struct iwl_priv *priv);
105int iwl_power_temperature_change(struct iwl_priv *priv);
106
107#endif /* __iwl_power_setting_h__ */