| /* |
| * This file is part of the coreboot project. |
| * |
| * Copyright (C) 2010 Advanced Micro Devices, Inc. |
| * Copyright (C) 2015 Timothy Pearson <tpearson@raptorengineeringinc.com>, Raptor Engineering |
| * |
| * This program is free software; you can redistribute it and/or modify |
| * it under the terms of the GNU General Public License as published by |
| * the Free Software Foundation; version 2 of the License. |
| * |
| * 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. |
| */ |
| /* IBV defined Structure */ /* IBV Specific Options */ |
| #ifndef MWLC_D_H |
| #define MWLC_D_H |
| |
| #define MAX_TOTAL_DIMMS 8 /* Maximum Number of DIMMs in systems */ |
| /* (DCT0 + DCT1) */ |
| #define MAX_DIMMS 4 /* Maximum Number of DIMMs on each DCT */ |
| #define MAX_LDIMMS 4 /* Maximum number of Logical DIMMs per DCT */ |
| |
| /*MCT Max variables */ |
| #define MAX_ERRORS 32 /* Maximum number of Errors Reported */ |
| #define MAX_STATUS 32 /* Maximum number of Status variables*/ |
| #define MAX_BYTE_LANES (8+1) /* Maximum number of Byte Lanes - include ECC */ |
| |
| #define C_MAX_DIMMS 4 /* Maximum Number of DIMMs on each DCT */ |
| |
| /* STATUS Definition */ |
| #define DCT_STATUS_REGISTERED 3 /* Registered DIMMs support */ |
| #define DCT_STATUS_LOAD_REDUCED 4 /* Load-Reduced DIMMs support */ |
| #define DCT_STATUS_OnDimmMirror 24 /* OnDimmMirror support */ |
| |
| /* PCI Defintions */ |
| #define FUN_HT 0 /* Funtion 0 Access */ |
| #define FUN_MAP 1 /* Funtion 1 Access */ |
| #define FUN_DCT 2 /* Funtion 2 Access */ |
| #define FUN_MISC 3 /* Funtion 3 Access */ |
| #define FUN_ADD_DCT 0xF /* Funtion 2 Additional Register Access */ |
| #define BOTH_DCTS 2 /* The access is independent of DCTs */ |
| #define PCI_MIN_LOW 0 /* Lowest possible PCI register location */ |
| #define PCI_MAX_HIGH 31 /* Highest possible PCI register location */ |
| |
| /*Function 2 */ |
| /* #define DRAM_INIT 0x7C */ |
| #define DRAM_MRS_REGISTER 0x84 |
| #define DRAM_CONFIG_HIGH 0x94 |
| #define DRAM_CONTROLLER_ADD_DATA_OFFSET_REG 0x98 |
| #define DRAM_CONTROLLER_ADD_DATA_PORT_REG 0x9C |
| |
| /*Function 2 Additional DRAM control registers */ |
| #define DRAM_ADD_DCT_PHY_CONTROL_REG 0x8 |
| #define DRAM_CONT_ADD_DQS_TIMING_CTRL_BL_01 0x30 |
| #define DRAM_CONT_ADD_DQS_TIMING_CTRL_BL_45 0x40 |
| #define DRAM_CONT_ADD_PHASE_REC_CTRL_LOW 0x50 |
| #define DRAM_CONT_ADD_PHASE_REC_CTRL_HIGH 0x51 |
| #define DRAM_CONT_ADD_ECC_PHASE_REC_CTRL 0x52 |
| #define DRAM_CONT_ADD_WRITE_LEV_ERROR_REG 0x53 |
| |
| /* CPU Register defintions */ |
| |
| /* Register Bit Location */ |
| #define DctAccessDone 31 |
| #define DctAccessWrite 30 |
| #define RDqsEn 12 |
| #define TrDimmSelStart 4 |
| #define TrDimmSelEnd 5 |
| #define WrLvTrMode 1 |
| #define TrNibbleSel 2 |
| #define WrLvOdtEn 12 |
| #define WrLvErrStart 0 |
| #define WrLvErrEnd 8 |
| #define SendMrsCmd 26 |
| #define Qoff 12 |
| #define MRS_Level 7 |
| #define MrsAddressStartFam10 0 |
| #define MrsAddressEndFam10 15 |
| #define MrsAddressStartFam15 0 |
| #define MrsAddressEndFam15 17 |
| #define MrsBankStartFam10 16 |
| #define MrsBankEndFam10 18 |
| #define MrsBankStartFam15 18 |
| #define MrsBankEndFam15 20 |
| #define MrsChipSelStartFam10 20 |
| #define MrsChipSelEndFam10 22 |
| #define MrsChipSelStartFam15 21 |
| #define MrsChipSelEndFam15 23 |
| #define ASR 18 |
| #define SRT 19 |
| #define DramTermDynStart 10 |
| #define DramTermDynEnd 11 |
| #define WrtLvTrMode 1 |
| #define TrNibbleSel 2 |
| #define TrDimmSelStart 4 |
| #define TrDimmSelEnd 5 |
| #define WrtLvTrEn 0 |
| #define DrvImpCtrlStart 2 |
| #define DrvImpCtrlEnd 3 |
| #define DramTermNbStart 7 |
| #define DramTermNbEnd 9 |
| #define onDimmMirror 3 |
| |
| typedef struct _sMCTStruct |
| { |
| void (*AgesaDelay)(u32 delayval); /* IBV defined Delay Function */ |
| } sMCTStruct; |
| |
| /* DCT 0 and DCT 1 Data structure */ |
| typedef struct _sDCTStruct |
| { |
| u8 NodeId; /* Node ID */ |
| u8 DctTrain; /* Current DCT being trained */ |
| u8 CurrDct; /* Current DCT number (0 or 1) */ |
| u8 DctCSPresent; /* Current DCT CS mapping */ |
| uint8_t WrDqsGrossDlyBaseOffset; |
| int32_t WLSeedGrossDelay[MAX_BYTE_LANES*MAX_LDIMMS]; /* Write Levelization Seed Gross Delay */ |
| /* per byte Lane Per Logical DIMM*/ |
| int32_t WLSeedFineDelay[MAX_BYTE_LANES*MAX_LDIMMS]; /* Write Levelization Seed Fine Delay */ |
| /* per byte Lane Per Logical DIMM*/ |
| int32_t WLSeedPreGrossDelay[MAX_BYTE_LANES*MAX_LDIMMS]; /* Write Levelization Seed Pre-Gross Delay */ |
| /* per byte Lane Per Logical DIMM*/ |
| uint8_t WLSeedPreGrossPrevNibble[MAX_BYTE_LANES*MAX_LDIMMS]; |
| uint8_t WLSeedGrossPrevNibble[MAX_BYTE_LANES*MAX_LDIMMS]; |
| uint8_t WLSeedFinePrevNibble[MAX_BYTE_LANES*MAX_LDIMMS]; |
| /* per byte Lane Per Logical DIMM*/ |
| u8 WLGrossDelay[MAX_BYTE_LANES*MAX_LDIMMS]; /* Write Levelization Gross Delay */ |
| /* per byte Lane Per Logical DIMM*/ |
| u8 WLFineDelay[MAX_BYTE_LANES*MAX_LDIMMS]; /* Write Levelization Fine Delay */ |
| /* per byte Lane Per Logical DIMM*/ |
| u8 WLGrossDelayFirstPass[MAX_BYTE_LANES*MAX_LDIMMS]; /* First-Pass Write Levelization Gross Delay */ |
| /* per byte Lane Per Logical DIMM*/ |
| u8 WLFineDelayFirstPass[MAX_BYTE_LANES*MAX_LDIMMS]; /* First-Pass Write Levelization Fine Delay */ |
| /* per byte Lane Per Logical DIMM*/ |
| u8 WLGrossDelayPrevPass[MAX_BYTE_LANES*MAX_LDIMMS]; /* Previous Pass Write Levelization Gross Delay */ |
| /* per byte Lane Per Logical DIMM*/ |
| u8 WLFineDelayPrevPass[MAX_BYTE_LANES*MAX_LDIMMS]; /* Previous Pass Write Levelization Fine Delay */ |
| /* per byte Lane Per Logical DIMM*/ |
| u8 WLGrossDelayFinalPass[MAX_BYTE_LANES*MAX_LDIMMS]; /* Final-Pass Write Levelization Gross Delay */ |
| /* per byte Lane Per Logical DIMM*/ |
| u8 WLFineDelayFinalPass[MAX_BYTE_LANES*MAX_LDIMMS]; /* Final-Pass Write Levelization Fine Delay */ |
| /* per byte Lane Per Logical DIMM*/ |
| int32_t WLCriticalGrossDelayFirstPass; |
| int32_t WLCriticalGrossDelayPrevPass; |
| int32_t WLCriticalGrossDelayFinalPass; |
| uint16_t WLPrevMemclkFreq; |
| u16 RegMan1Present; |
| u8 DimmPresent[MAX_TOTAL_DIMMS];/* Indicates which DIMMs are present */ |
| /* from Total Number of DIMMs(per Node)*/ |
| u8 DimmX8Present[MAX_TOTAL_DIMMS]; /* Which DIMMs x8 devices */ |
| u8 Status[MAX_STATUS]; /* Status for DCT0 and 1 */ |
| u8 ErrCode[MAX_ERRORS]; /* Major Error codes for DCT0 and 1 */ |
| u8 ErrStatus[MAX_ERRORS]; /* Minor Error codes for DCT0 and 1 */ |
| u8 DimmValid[MAX_TOTAL_DIMMS]; /* Indicates which DIMMs are valid for */ |
| /* Total Number of DIMMs(per Node) */ |
| u8 WLTotalDelay[MAX_BYTE_LANES];/* Write Levelization Toral Delay */ |
| /* per byte lane */ |
| u8 MaxDimmsInstalled; /* Max Dimms Installed for current DCT */ |
| u8 DimmRanks[MAX_TOTAL_DIMMS]; /* Total Number of Ranks(per Dimm) */ |
| uint64_t LogicalCPUID; |
| u8 WLPass; |
| } sDCTStruct; |
| |
| #endif |