diff options
Diffstat (limited to 'drivers/net/wireless/ath9k/hw.h')
-rw-r--r-- | drivers/net/wireless/ath9k/hw.h | 135 |
1 files changed, 130 insertions, 5 deletions
diff --git a/drivers/net/wireless/ath9k/hw.h b/drivers/net/wireless/ath9k/hw.h index 02256c3ec076..a4d52850bdd0 100644 --- a/drivers/net/wireless/ath9k/hw.h +++ b/drivers/net/wireless/ath9k/hw.h | |||
@@ -448,6 +448,17 @@ struct ar5416Stats { | |||
448 | #define AR5416_EEP_TXGAIN_ORIGINAL 0 | 448 | #define AR5416_EEP_TXGAIN_ORIGINAL 0 |
449 | #define AR5416_EEP_TXGAIN_HIGH_POWER 1 | 449 | #define AR5416_EEP_TXGAIN_HIGH_POWER 1 |
450 | 450 | ||
451 | #define AR5416_EEP4K_START_LOC 64 | ||
452 | #define AR5416_EEP4K_NUM_2G_CAL_PIERS 3 | ||
453 | #define AR5416_EEP4K_NUM_2G_CCK_TARGET_POWERS 3 | ||
454 | #define AR5416_EEP4K_NUM_2G_20_TARGET_POWERS 3 | ||
455 | #define AR5416_EEP4K_NUM_2G_40_TARGET_POWERS 3 | ||
456 | #define AR5416_EEP4K_NUM_CTLS 12 | ||
457 | #define AR5416_EEP4K_NUM_BAND_EDGES 4 | ||
458 | #define AR5416_EEP4K_NUM_PD_GAINS 2 | ||
459 | #define AR5416_EEP4K_PD_GAINS_IN_MASK 4 | ||
460 | #define AR5416_EEP4K_PD_GAIN_ICEPTS 5 | ||
461 | #define AR5416_EEP4K_MAX_CHAINS 1 | ||
451 | 462 | ||
452 | enum eeprom_param { | 463 | enum eeprom_param { |
453 | EEP_NFTHRESH_5, | 464 | EEP_NFTHRESH_5, |
@@ -507,6 +518,25 @@ struct base_eep_header { | |||
507 | u8 futureBase_3[25]; | 518 | u8 futureBase_3[25]; |
508 | } __packed; | 519 | } __packed; |
509 | 520 | ||
521 | struct base_eep_header_4k { | ||
522 | u16 length; | ||
523 | u16 checksum; | ||
524 | u16 version; | ||
525 | u8 opCapFlags; | ||
526 | u8 eepMisc; | ||
527 | u16 regDmn[2]; | ||
528 | u8 macAddr[6]; | ||
529 | u8 rxMask; | ||
530 | u8 txMask; | ||
531 | u16 rfSilent; | ||
532 | u16 blueToothOptions; | ||
533 | u16 deviceCap; | ||
534 | u32 binBuildNumber; | ||
535 | u8 deviceType; | ||
536 | u8 futureBase[1]; | ||
537 | } __packed; | ||
538 | |||
539 | |||
510 | struct spur_chan { | 540 | struct spur_chan { |
511 | u16 spurChan; | 541 | u16 spurChan; |
512 | u8 spurRangeLow; | 542 | u8 spurRangeLow; |
@@ -559,11 +589,58 @@ struct modal_eep_header { | |||
559 | struct spur_chan spurChans[AR5416_EEPROM_MODAL_SPURS]; | 589 | struct spur_chan spurChans[AR5416_EEPROM_MODAL_SPURS]; |
560 | } __packed; | 590 | } __packed; |
561 | 591 | ||
592 | struct modal_eep_4k_header { | ||
593 | u32 antCtrlChain[AR5416_EEP4K_MAX_CHAINS]; | ||
594 | u32 antCtrlCommon; | ||
595 | u8 antennaGainCh[AR5416_EEP4K_MAX_CHAINS]; | ||
596 | u8 switchSettling; | ||
597 | u8 txRxAttenCh[AR5416_EEP4K_MAX_CHAINS]; | ||
598 | u8 rxTxMarginCh[AR5416_EEP4K_MAX_CHAINS]; | ||
599 | u8 adcDesiredSize; | ||
600 | u8 pgaDesiredSize; | ||
601 | u8 xlnaGainCh[AR5416_EEP4K_MAX_CHAINS]; | ||
602 | u8 txEndToXpaOff; | ||
603 | u8 txEndToRxOn; | ||
604 | u8 txFrameToXpaOn; | ||
605 | u8 thresh62; | ||
606 | u8 noiseFloorThreshCh[AR5416_EEP4K_MAX_CHAINS]; | ||
607 | u8 xpdGain; | ||
608 | u8 xpd; | ||
609 | u8 iqCalICh[AR5416_EEP4K_MAX_CHAINS]; | ||
610 | u8 iqCalQCh[AR5416_EEP4K_MAX_CHAINS]; | ||
611 | u8 pdGainOverlap; | ||
612 | u8 ob_01; | ||
613 | u8 db1_01; | ||
614 | u8 xpaBiasLvl; | ||
615 | u8 txFrameToDataStart; | ||
616 | u8 txFrameToPaOn; | ||
617 | u8 ht40PowerIncForPdadc; | ||
618 | u8 bswAtten[AR5416_EEP4K_MAX_CHAINS]; | ||
619 | u8 bswMargin[AR5416_EEP4K_MAX_CHAINS]; | ||
620 | u8 swSettleHt40; | ||
621 | u8 xatten2Db[AR5416_EEP4K_MAX_CHAINS]; | ||
622 | u8 xatten2Margin[AR5416_EEP4K_MAX_CHAINS]; | ||
623 | u8 db2_01; | ||
624 | u8 version; | ||
625 | u16 ob_234; | ||
626 | u16 db1_234; | ||
627 | u16 db2_234; | ||
628 | u8 futureModal[4]; | ||
629 | |||
630 | struct spur_chan spurChans[AR5416_EEPROM_MODAL_SPURS]; | ||
631 | } __packed; | ||
632 | |||
633 | |||
562 | struct cal_data_per_freq { | 634 | struct cal_data_per_freq { |
563 | u8 pwrPdg[AR5416_NUM_PD_GAINS][AR5416_PD_GAIN_ICEPTS]; | 635 | u8 pwrPdg[AR5416_NUM_PD_GAINS][AR5416_PD_GAIN_ICEPTS]; |
564 | u8 vpdPdg[AR5416_NUM_PD_GAINS][AR5416_PD_GAIN_ICEPTS]; | 636 | u8 vpdPdg[AR5416_NUM_PD_GAINS][AR5416_PD_GAIN_ICEPTS]; |
565 | } __packed; | 637 | } __packed; |
566 | 638 | ||
639 | struct cal_data_per_freq_4k { | ||
640 | u8 pwrPdg[AR5416_EEP4K_NUM_PD_GAINS][AR5416_EEP4K_PD_GAIN_ICEPTS]; | ||
641 | u8 vpdPdg[AR5416_EEP4K_NUM_PD_GAINS][AR5416_EEP4K_PD_GAIN_ICEPTS]; | ||
642 | } __packed; | ||
643 | |||
567 | struct cal_target_power_leg { | 644 | struct cal_target_power_leg { |
568 | u8 bChannel; | 645 | u8 bChannel; |
569 | u8 tPow2x[4]; | 646 | u8 tPow2x[4]; |
@@ -574,6 +651,7 @@ struct cal_target_power_ht { | |||
574 | u8 tPow2x[8]; | 651 | u8 tPow2x[8]; |
575 | } __packed; | 652 | } __packed; |
576 | 653 | ||
654 | |||
577 | #ifdef __BIG_ENDIAN_BITFIELD | 655 | #ifdef __BIG_ENDIAN_BITFIELD |
578 | struct cal_ctl_edges { | 656 | struct cal_ctl_edges { |
579 | u8 bChannel; | 657 | u8 bChannel; |
@@ -588,10 +666,15 @@ struct cal_ctl_edges { | |||
588 | 666 | ||
589 | struct cal_ctl_data { | 667 | struct cal_ctl_data { |
590 | struct cal_ctl_edges | 668 | struct cal_ctl_edges |
591 | ctlEdges[AR5416_MAX_CHAINS][AR5416_NUM_BAND_EDGES]; | 669 | ctlEdges[AR5416_MAX_CHAINS][AR5416_NUM_BAND_EDGES]; |
670 | } __packed; | ||
671 | |||
672 | struct cal_ctl_data_4k { | ||
673 | struct cal_ctl_edges | ||
674 | ctlEdges[AR5416_EEP4K_MAX_CHAINS][AR5416_EEP4K_NUM_BAND_EDGES]; | ||
592 | } __packed; | 675 | } __packed; |
593 | 676 | ||
594 | struct ar5416_eeprom { | 677 | struct ar5416_eeprom_def { |
595 | struct base_eep_header baseEepHeader; | 678 | struct base_eep_header baseEepHeader; |
596 | u8 custData[64]; | 679 | u8 custData[64]; |
597 | struct modal_eep_header modalHeader[2]; | 680 | struct modal_eep_header modalHeader[2]; |
@@ -620,6 +703,26 @@ struct ar5416_eeprom { | |||
620 | u8 padding; | 703 | u8 padding; |
621 | } __packed; | 704 | } __packed; |
622 | 705 | ||
706 | struct ar5416_eeprom_4k { | ||
707 | struct base_eep_header_4k baseEepHeader; | ||
708 | u8 custData[20]; | ||
709 | struct modal_eep_4k_header modalHeader; | ||
710 | u8 calFreqPier2G[AR5416_EEP4K_NUM_2G_CAL_PIERS]; | ||
711 | struct cal_data_per_freq_4k | ||
712 | calPierData2G[AR5416_EEP4K_MAX_CHAINS][AR5416_EEP4K_NUM_2G_CAL_PIERS]; | ||
713 | struct cal_target_power_leg | ||
714 | calTargetPowerCck[AR5416_EEP4K_NUM_2G_CCK_TARGET_POWERS]; | ||
715 | struct cal_target_power_leg | ||
716 | calTargetPower2G[AR5416_EEP4K_NUM_2G_20_TARGET_POWERS]; | ||
717 | struct cal_target_power_ht | ||
718 | calTargetPower2GHT20[AR5416_EEP4K_NUM_2G_20_TARGET_POWERS]; | ||
719 | struct cal_target_power_ht | ||
720 | calTargetPower2GHT40[AR5416_EEP4K_NUM_2G_40_TARGET_POWERS]; | ||
721 | u8 ctlIndex[AR5416_EEP4K_NUM_CTLS]; | ||
722 | struct cal_ctl_data_4k ctlData[AR5416_EEP4K_NUM_CTLS]; | ||
723 | u8 padding; | ||
724 | } __packed; | ||
725 | |||
623 | struct ar5416IniArray { | 726 | struct ar5416IniArray { |
624 | u32 *ia_array; | 727 | u32 *ia_array; |
625 | u32 ia_rows; | 728 | u32 ia_rows; |
@@ -687,9 +790,22 @@ struct hal_cal_list { | |||
687 | struct hal_cal_list *calNext; | 790 | struct hal_cal_list *calNext; |
688 | }; | 791 | }; |
689 | 792 | ||
793 | /* | ||
794 | * Enum to indentify the eeprom mappings | ||
795 | */ | ||
796 | enum hal_eep_map { | ||
797 | EEP_MAP_DEFAULT = 0x0, | ||
798 | EEP_MAP_4KBITS, | ||
799 | EEP_MAP_MAX | ||
800 | }; | ||
801 | |||
802 | |||
690 | struct ath_hal_5416 { | 803 | struct ath_hal_5416 { |
691 | struct ath_hal ah; | 804 | struct ath_hal ah; |
692 | struct ar5416_eeprom ah_eeprom; | 805 | union { |
806 | struct ar5416_eeprom_def def; | ||
807 | struct ar5416_eeprom_4k map4k; | ||
808 | } ah_eeprom; | ||
693 | struct ar5416Stats ah_stats; | 809 | struct ar5416Stats ah_stats; |
694 | struct ath9k_tx_queue_info ah_txq[ATH9K_NUM_TX_QUEUES]; | 810 | struct ath9k_tx_queue_info ah_txq[ATH9K_NUM_TX_QUEUES]; |
695 | void __iomem *ah_cal_mem; | 811 | void __iomem *ah_cal_mem; |
@@ -813,6 +929,8 @@ struct ath_hal_5416 { | |||
813 | struct ar5416IniArray ah_iniModesAdditional; | 929 | struct ar5416IniArray ah_iniModesAdditional; |
814 | struct ar5416IniArray ah_iniModesRxGain; | 930 | struct ar5416IniArray ah_iniModesRxGain; |
815 | struct ar5416IniArray ah_iniModesTxGain; | 931 | struct ar5416IniArray ah_iniModesTxGain; |
932 | /* To indicate EEPROM mapping used */ | ||
933 | enum hal_eep_map ah_eep_map; | ||
816 | }; | 934 | }; |
817 | #define AH5416(_ah) ((struct ath_hal_5416 *)(_ah)) | 935 | #define AH5416(_ah) ((struct ath_hal_5416 *)(_ah)) |
818 | 936 | ||
@@ -854,13 +972,20 @@ struct ath_hal_5416 { | |||
854 | (AR_SREV_9100(ah)) ? 0x1fff1000 : 0x503f1200 | 972 | (AR_SREV_9100(ah)) ? 0x1fff1000 : 0x503f1200 |
855 | #define AR5416_EEPROM_MAX 0xae0 | 973 | #define AR5416_EEPROM_MAX 0xae0 |
856 | #define ar5416_get_eep_ver(_ahp) \ | 974 | #define ar5416_get_eep_ver(_ahp) \ |
857 | (((_ahp)->ah_eeprom.baseEepHeader.version >> 12) & 0xF) | 975 | (((_ahp)->ah_eeprom.def.baseEepHeader.version >> 12) & 0xF) |
858 | #define ar5416_get_eep_rev(_ahp) \ | 976 | #define ar5416_get_eep_rev(_ahp) \ |
859 | (((_ahp)->ah_eeprom.baseEepHeader.version) & 0xFFF) | 977 | (((_ahp)->ah_eeprom.def.baseEepHeader.version) & 0xFFF) |
860 | #define ar5416_get_ntxchains(_txchainmask) \ | 978 | #define ar5416_get_ntxchains(_txchainmask) \ |
861 | (((_txchainmask >> 2) & 1) + \ | 979 | (((_txchainmask >> 2) & 1) + \ |
862 | ((_txchainmask >> 1) & 1) + (_txchainmask & 1)) | 980 | ((_txchainmask >> 1) & 1) + (_txchainmask & 1)) |
863 | 981 | ||
982 | /* EEPROM 4K bit map definations */ | ||
983 | #define ar5416_get_eep4k_ver(_ahp) \ | ||
984 | (((_ahp)->ah_eeprom.map4k.baseEepHeader.version >> 12) & 0xF) | ||
985 | #define ar5416_get_eep4k_rev(_ahp) \ | ||
986 | (((_ahp)->ah_eeprom.map4k.baseEepHeader.version) & 0xFFF) | ||
987 | |||
988 | |||
864 | #ifdef __BIG_ENDIAN | 989 | #ifdef __BIG_ENDIAN |
865 | #define AR5416_EEPROM_MAGIC 0x5aa5 | 990 | #define AR5416_EEPROM_MAGIC 0x5aa5 |
866 | #else | 991 | #else |