Blame view

kernel/linux-rt-4.4.41/drivers/net/wireless/iwlwifi/iwl-agn-hw.h 4.71 KB
5113f6f70   김현기   kernel add
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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
  /******************************************************************************
   *
   * This file is provided under a dual BSD/GPLv2 license.  When using or
   * redistributing this file, you may do so under either license.
   *
   * GPL LICENSE SUMMARY
   *
   * Copyright(c) 2007 - 2014 Intel Corporation. All rights reserved.
   *
   * This program is free software; you can redistribute it and/or modify
   * it under the terms of version 2 of the GNU General Public License as
   * published by the Free Software Foundation.
   *
   * This program is distributed in the hope that it will be useful, but
   * WITHOUT ANY WARRANTY; without even the implied warranty of
   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   * General Public License for more details.
   *
   * You should have received a copy of the GNU General Public License
   * along with this program; if not, write to the Free Software
   * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110,
   * USA
   *
   * The full GNU General Public License is included in this distribution
   * in the file called COPYING.
   *
   * Contact Information:
   *  Intel Linux Wireless <ilw@linux.intel.com>
   * Intel Corporation, 5200 N.E. Elam Young Parkway, Hillsboro, OR 97124-6497
   *
   * BSD LICENSE
   *
   * Copyright(c) 2005 - 2014 Intel Corporation. All rights reserved.
   * All rights reserved.
   *
   * Redistribution and use in source and binary forms, with or without
   * modification, are permitted provided that the following conditions
   * are met:
   *
   *  * Redistributions of source code must retain the above copyright
   *    notice, this list of conditions and the following disclaimer.
   *  * Redistributions in binary form must reproduce the above copyright
   *    notice, this list of conditions and the following disclaimer in
   *    the documentation and/or other materials provided with the
   *    distribution.
   *  * Neither the name Intel Corporation nor the names of its
   *    contributors may be used to endorse or promote products derived
   *    from this software without specific prior written permission.
   *
   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
   * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
   * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
   * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
   * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
   * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
   * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
   * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
   * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
   * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
   *
   *****************************************************************************/
  /*
   * Please use this file (iwl-agn-hw.h) only for hardware-related definitions.
   */
  
  #ifndef __iwl_agn_hw_h__
  #define __iwl_agn_hw_h__
  
  #define IWLAGN_RTC_INST_LOWER_BOUND		(0x000000)
  #define IWLAGN_RTC_INST_UPPER_BOUND		(0x020000)
  
  #define IWLAGN_RTC_DATA_LOWER_BOUND		(0x800000)
  #define IWLAGN_RTC_DATA_UPPER_BOUND		(0x80C000)
  
  #define IWLAGN_RTC_INST_SIZE (IWLAGN_RTC_INST_UPPER_BOUND - \
  				IWLAGN_RTC_INST_LOWER_BOUND)
  #define IWLAGN_RTC_DATA_SIZE (IWLAGN_RTC_DATA_UPPER_BOUND - \
  				IWLAGN_RTC_DATA_LOWER_BOUND)
  
  #define IWL60_RTC_INST_LOWER_BOUND		(0x000000)
  #define IWL60_RTC_INST_UPPER_BOUND		(0x040000)
  #define IWL60_RTC_DATA_LOWER_BOUND		(0x800000)
  #define IWL60_RTC_DATA_UPPER_BOUND		(0x814000)
  #define IWL60_RTC_INST_SIZE \
  	(IWL60_RTC_INST_UPPER_BOUND - IWL60_RTC_INST_LOWER_BOUND)
  #define IWL60_RTC_DATA_SIZE \
  	(IWL60_RTC_DATA_UPPER_BOUND - IWL60_RTC_DATA_LOWER_BOUND)
  
  /* RSSI to dBm */
  #define IWLAGN_RSSI_OFFSET	44
  
  #define IWLAGN_DEFAULT_TX_RETRY			15
  #define IWLAGN_MGMT_DFAULT_RETRY_LIMIT		3
  #define IWLAGN_RTS_DFAULT_RETRY_LIMIT		60
  #define IWLAGN_BAR_DFAULT_RETRY_LIMIT		60
  #define IWLAGN_LOW_RETRY_LIMIT			7
  
  /* Limit range of txpower output target to be between these values */
  #define IWLAGN_TX_POWER_TARGET_POWER_MIN	(0)	/* 0 dBm: 1 milliwatt */
  #define IWLAGN_TX_POWER_TARGET_POWER_MAX	(16)	/* 16 dBm */
  
  /* EEPROM */
  #define IWLAGN_EEPROM_IMG_SIZE		2048
  
  /* high blocks contain PAPD data */
  #define OTP_HIGH_IMAGE_SIZE_6x00        (6 * 512 * sizeof(u16)) /* 6 KB */
  #define OTP_HIGH_IMAGE_SIZE_1000        (0x200 * sizeof(u16)) /* 1024 bytes */
  #define OTP_MAX_LL_ITEMS_1000		(3)	/* OTP blocks for 1000 */
  #define OTP_MAX_LL_ITEMS_6x00		(4)	/* OTP blocks for 6x00 */
  #define OTP_MAX_LL_ITEMS_6x50		(7)	/* OTP blocks for 6x50 */
  #define OTP_MAX_LL_ITEMS_2x00		(4)	/* OTP blocks for 2x00 */
  
  
  #define IWLAGN_NUM_QUEUES		20
  
  #endif /* __iwl_agn_hw_h__ */