aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/iwlwifi/iwl-4965-hw.h
diff options
context:
space:
mode:
authorBen Cahill <ben.m.cahill@intel.com>2007-11-28 22:09:52 -0500
committerDavid S. Miller <davem@davemloft.net>2008-01-28 18:05:21 -0500
commit1fea8e8838d009545d94588ac41037d8f20f969d (patch)
tree576fbe812e443171701f8633fd44a630d4a4aa27 /drivers/net/wireless/iwlwifi/iwl-4965-hw.h
parentf7d09d7c453f197d802c50172b27170a43e1a816 (diff)
iwlwifi: Partially clean-up, add comments to iwl-*-hw.h
Partially clean-up, add comments to iwl-XXXX-hw.h Signed-off-by: Ben Cahill <ben.m.cahill@intel.com> Signed-off-by: Zhu Yi <yi.zhu@intel.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/iwlwifi/iwl-4965-hw.h')
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-4965-hw.h78
1 files changed, 51 insertions, 27 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-4965-hw.h b/drivers/net/wireless/iwlwifi/iwl-4965-hw.h
index f0371ad0a37f..e7bce8239357 100644
--- a/drivers/net/wireless/iwlwifi/iwl-4965-hw.h
+++ b/drivers/net/wireless/iwlwifi/iwl-4965-hw.h
@@ -64,7 +64,12 @@
64#ifndef __iwl_4965_hw_h__ 64#ifndef __iwl_4965_hw_h__
65#define __iwl_4965_hw_h__ 65#define __iwl_4965_hw_h__
66 66
67/* uCode queue management definitions */ 67/*
68 * uCode queue management definitions ...
69 * Queue #4 is the command queue for 3945 and 4965; map it to Tx FIFO chnl 4.
70 * The first queue used for block-ack aggregation is #7 (4965 only).
71 * All block-ack aggregation queues should map to Tx DMA/FIFO channel 7.
72 */
68#define IWL_CMD_QUEUE_NUM 4 73#define IWL_CMD_QUEUE_NUM 4
69#define IWL_CMD_FIFO_NUM 4 74#define IWL_CMD_FIFO_NUM 4
70#define IWL_BACK_QUEUE_FIRST_ID 7 75#define IWL_BACK_QUEUE_FIRST_ID 7
@@ -444,7 +449,20 @@ struct iwl4965_eeprom {
444#define CSR_GPIO_IN (CSR_BASE+0x018) /* read external chip pins */ 449#define CSR_GPIO_IN (CSR_BASE+0x018) /* read external chip pins */
445#define CSR_RESET (CSR_BASE+0x020) /* busmaster enable, NMI, etc*/ 450#define CSR_RESET (CSR_BASE+0x020) /* busmaster enable, NMI, etc*/
446#define CSR_GP_CNTRL (CSR_BASE+0x024) 451#define CSR_GP_CNTRL (CSR_BASE+0x024)
452
453/*
454 * Hardware revision info
455 * Bit fields:
456 * 31-8: Reserved
457 * 7-4: Type of device: 0x0 = 4965, 0xd = 3945
458 * 3-2: Revision step: 0 = A, 1 = B, 2 = C, 3 = D
459 * 1-0: "Dash" value, as in A-1, etc.
460 *
461 * NOTE: Revision step affects calculation of CCK txpower for 4965.
462 */
447#define CSR_HW_REV (CSR_BASE+0x028) 463#define CSR_HW_REV (CSR_BASE+0x028)
464
465/* EEPROM reads */
448#define CSR_EEPROM_REG (CSR_BASE+0x02c) 466#define CSR_EEPROM_REG (CSR_BASE+0x02c)
449#define CSR_EEPROM_GP (CSR_BASE+0x030) 467#define CSR_EEPROM_GP (CSR_BASE+0x030)
450#define CSR_GP_UCODE (CSR_BASE+0x044) 468#define CSR_GP_UCODE (CSR_BASE+0x044)
@@ -452,10 +470,13 @@ struct iwl4965_eeprom {
452#define CSR_UCODE_DRV_GP1_SET (CSR_BASE+0x058) 470#define CSR_UCODE_DRV_GP1_SET (CSR_BASE+0x058)
453#define CSR_UCODE_DRV_GP1_CLR (CSR_BASE+0x05c) 471#define CSR_UCODE_DRV_GP1_CLR (CSR_BASE+0x05c)
454#define CSR_UCODE_DRV_GP2 (CSR_BASE+0x060) 472#define CSR_UCODE_DRV_GP2 (CSR_BASE+0x060)
455#define CSR_LED_REG (CSR_BASE+0x094)
456#define CSR_DRAM_INT_TBL_CTL (CSR_BASE+0x0A0)
457#define CSR_GIO_CHICKEN_BITS (CSR_BASE+0x100) 473#define CSR_GIO_CHICKEN_BITS (CSR_BASE+0x100)
458#define CSR_ANA_PLL_CFG (CSR_BASE+0x20c) 474
475/*
476 * Indicates hardware rev, to determine CCK backoff for txpower calculation.
477 * Bit fields:
478 * 3-2: 0 = A, 1 = B, 2 = C, 3 = D step
479 */
459#define CSR_HW_REV_WA_REG (CSR_BASE+0x22C) 480#define CSR_HW_REV_WA_REG (CSR_BASE+0x22C)
460 481
461/* HW I/F configuration */ 482/* HW I/F configuration */
@@ -554,44 +575,47 @@ struct iwl4965_eeprom {
554#define CSR_GIO_CHICKEN_BITS_REG_BIT_L1A_NO_L0S_RX (0x00800000) 575#define CSR_GIO_CHICKEN_BITS_REG_BIT_L1A_NO_L0S_RX (0x00800000)
555#define CSR_GIO_CHICKEN_BITS_REG_BIT_DIS_L0S_EXIT_TIMER (0x20000000) 576#define CSR_GIO_CHICKEN_BITS_REG_BIT_DIS_L0S_EXIT_TIMER (0x20000000)
556 577
557/* CSR_ANA_PLL_CFG */
558#define CSR_ANA_PLL_CFG_SH (0x00880300)
559
560#define CSR_LED_REG_TRUN_ON (0x00000078)
561#define CSR_LED_REG_TRUN_OFF (0x00000038)
562#define CSR_LED_BSM_CTRL_MSK (0xFFFFFFDF)
563
564/* DRAM_INT_TBL_CTRL */
565#define CSR_DRAM_INT_TBL_CTRL_EN (1<<31)
566#define CSR_DRAM_INT_TBL_CTRL_WRAP_CHK (1<<27)
567
568/*=== HBUS (Host-side Bus) ===*/ 578/*=== HBUS (Host-side Bus) ===*/
569#define HBUS_BASE (0x400) 579#define HBUS_BASE (0x400)
570 580
581/*
582 * Registers for accessing device's internal SRAM memory (e.g. SCD SRAM
583 * structures, error log, event log, verifying uCode load).
584 * First write to address register, then read from or write to data register
585 * to complete the job. Once the address register is set up, accesses to
586 * data registers auto-increment the address by one dword.
587 * Bit usage for address registers (read or write):
588 * 0-31: memory address within device
589 */
571#define HBUS_TARG_MEM_RADDR (HBUS_BASE+0x00c) 590#define HBUS_TARG_MEM_RADDR (HBUS_BASE+0x00c)
572#define HBUS_TARG_MEM_WADDR (HBUS_BASE+0x010) 591#define HBUS_TARG_MEM_WADDR (HBUS_BASE+0x010)
573#define HBUS_TARG_MEM_WDAT (HBUS_BASE+0x018) 592#define HBUS_TARG_MEM_WDAT (HBUS_BASE+0x018)
574#define HBUS_TARG_MEM_RDAT (HBUS_BASE+0x01c) 593#define HBUS_TARG_MEM_RDAT (HBUS_BASE+0x01c)
594
595/*
596 * Registers for accessing device's internal peripheral registers
597 * (e.g. SCD, BSM, etc.). First write to address register,
598 * then read from or write to data register to complete the job.
599 * Bit usage for address registers (read or write):
600 * 0-15: register address (offset) within device
601 * 24-25: (# bytes - 1) to read or write (e.g. 3 for dword)
602 */
575#define HBUS_TARG_PRPH_WADDR (HBUS_BASE+0x044) 603#define HBUS_TARG_PRPH_WADDR (HBUS_BASE+0x044)
576#define HBUS_TARG_PRPH_RADDR (HBUS_BASE+0x048) 604#define HBUS_TARG_PRPH_RADDR (HBUS_BASE+0x048)
577#define HBUS_TARG_PRPH_WDAT (HBUS_BASE+0x04c) 605#define HBUS_TARG_PRPH_WDAT (HBUS_BASE+0x04c)
578#define HBUS_TARG_PRPH_RDAT (HBUS_BASE+0x050) 606#define HBUS_TARG_PRPH_RDAT (HBUS_BASE+0x050)
607
608/*
609 * Per-Tx-queue write pointer (index, really!) (3945 and 4965).
610 * Indicates index to next TFD that driver will fill (1 past latest filled).
611 * Bit usage:
612 * 0-7: queue write index (0-255)
613 * 11-8: queue selector (0-15)
614 */
579#define HBUS_TARG_WRPTR (HBUS_BASE+0x060) 615#define HBUS_TARG_WRPTR (HBUS_BASE+0x060)
580 616
581#define HBUS_TARG_MBX_C (HBUS_BASE+0x030) 617#define HBUS_TARG_MBX_C (HBUS_BASE+0x030)
582 618
583
584/* SCD (Scheduler) */
585#define SCD_BASE (CSR_BASE + 0x2E00)
586
587#define SCD_MODE_REG (SCD_BASE + 0x000)
588#define SCD_ARASTAT_REG (SCD_BASE + 0x004)
589#define SCD_TXFACT_REG (SCD_BASE + 0x010)
590#define SCD_TXF4MF_REG (SCD_BASE + 0x014)
591#define SCD_TXF5MF_REG (SCD_BASE + 0x020)
592#define SCD_SBYP_MODE_1_REG (SCD_BASE + 0x02C)
593#define SCD_SBYP_MODE_2_REG (SCD_BASE + 0x030)
594
595/*=== FH (data Flow Handler) ===*/ 619/*=== FH (data Flow Handler) ===*/
596#define FH_BASE (0x800) 620#define FH_BASE (0x800)
597 621