2016-02-08 16:12:30 +01:00
|
|
|
/*
|
|
|
|
* This file is part of the coreboot project.
|
|
|
|
*
|
|
|
|
* Copyright (C) 2007-2008 coresystems GmbH
|
|
|
|
* Copyright (C) 2014 Google Inc.
|
2017-03-06 17:59:23 +01:00
|
|
|
* Copyright (C) 2015-2017 Intel Corporation.
|
2016-02-08 16:12:30 +01:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _SOC_CHIP_H_
|
|
|
|
#define _SOC_CHIP_H_
|
|
|
|
|
|
|
|
#include <stdint.h>
|
2016-03-04 00:30:48 +01:00
|
|
|
#include <fsp/util.h>
|
2016-02-08 16:12:30 +01:00
|
|
|
#include <soc/pci_devs.h>
|
|
|
|
#include <soc/pm.h>
|
|
|
|
|
2016-06-19 03:52:43 +02:00
|
|
|
///
|
|
|
|
/// MRC Flags bits
|
|
|
|
///
|
|
|
|
#define MRC_FLAG_ECC_EN BIT0
|
|
|
|
#define MRC_FLAG_SCRAMBLE_EN BIT1
|
|
|
|
#define MRC_FLAG_MEMTEST_EN BIT2
|
|
|
|
|
|
|
|
/* 0b DDR "fly-by" topology else 1b DDR "tree" topology */
|
|
|
|
#define MRC_FLAG_TOP_TREE_EN BIT3
|
|
|
|
|
|
|
|
/* If set ODR signal is asserted to DRAM devices on writes */
|
|
|
|
#define MRC_FLAG_WR_ODT_EN BIT4
|
|
|
|
|
2016-02-08 16:12:30 +01:00
|
|
|
struct soc_intel_quark_config {
|
2016-03-04 00:30:48 +01:00
|
|
|
/*
|
|
|
|
* MemoryInit:
|
|
|
|
*
|
|
|
|
* The following fields come from FspUpdVpd.h and are defined as PCDs
|
2017-03-06 17:59:23 +01:00
|
|
|
* for the FSP binary. Data for these fields comes from the board's
|
2016-03-04 00:30:48 +01:00
|
|
|
* devicetree.cb file which gets processed into static.c and then
|
|
|
|
* built into the coreboot image. The fields below contain retain
|
|
|
|
* the FSP PCD field name.
|
|
|
|
*/
|
2016-06-19 03:52:43 +02:00
|
|
|
|
2016-07-21 18:17:10 +02:00
|
|
|
uint32_t FspReservedMemoryLength; /* FSP reserved memory in bytes */
|
2016-06-19 03:52:43 +02:00
|
|
|
|
2016-07-21 18:17:10 +02:00
|
|
|
uint32_t Flags; /* Bitmap of MRC_FLAG_XXX defs above */
|
|
|
|
uint32_t tRAS; /* ACT to PRE command period in picoseconds */
|
2016-06-19 03:52:43 +02:00
|
|
|
|
|
|
|
/* Delay from start of internal write transaction to internal read
|
|
|
|
* command in picoseconds
|
|
|
|
*/
|
2016-07-21 18:17:10 +02:00
|
|
|
uint32_t tWTR;
|
2016-06-19 03:52:43 +02:00
|
|
|
|
|
|
|
/* ACT to ACT command period (JESD79 specific to page size 1K/2K) in
|
|
|
|
* picoseconds
|
|
|
|
*/
|
2016-07-21 18:17:10 +02:00
|
|
|
uint32_t tRRD;
|
2016-06-19 03:52:43 +02:00
|
|
|
|
|
|
|
/* Four activate window (JESD79 specific to page size 1K/2K) in
|
|
|
|
* picoseconds
|
|
|
|
*/
|
2016-07-21 18:17:10 +02:00
|
|
|
uint32_t tFAW;
|
|
|
|
uint8_t DramWidth; /* 0=x8, 1=x16, others=RESERVED */
|
2016-06-19 03:52:43 +02:00
|
|
|
|
|
|
|
/* 0=DDRFREQ_800, 1=DDRFREQ_1066, others=RESERVED. Only 533MHz SKU
|
|
|
|
* support 1066 memory
|
|
|
|
*/
|
2016-07-21 18:17:10 +02:00
|
|
|
uint8_t DramSpeed;
|
|
|
|
uint8_t DramType; /* 0=DDR3,1=DDR3L, others=RESERVED */
|
2016-06-19 03:52:43 +02:00
|
|
|
|
|
|
|
/* bit[0] RANK0_EN, bit[1] RANK1_EN, others=RESERVED */
|
2016-07-21 18:17:10 +02:00
|
|
|
uint8_t RankMask;
|
|
|
|
uint8_t ChanMask; /* bit[0] CHAN0_EN, others=RESERVED */
|
|
|
|
uint8_t ChanWidth; /* 1=x16, others=RESERVED */
|
2016-06-19 03:52:43 +02:00
|
|
|
|
|
|
|
/* 0, 1, 2 (mode 2 forced if ecc enabled), others=RESERVED */
|
2016-07-21 18:17:10 +02:00
|
|
|
uint8_t AddrMode;
|
2016-06-19 03:52:43 +02:00
|
|
|
|
|
|
|
/* 1=1.95us, 2=3.9us, 3=7.8us, others=RESERVED. REFRESH_RATE */
|
2016-07-21 18:17:10 +02:00
|
|
|
uint8_t SrInt;
|
|
|
|
uint8_t SrTemp; /* 0=normal, 1=extended, others=RESERVED */
|
2016-06-19 03:52:43 +02:00
|
|
|
|
|
|
|
/* 0=34ohm, 1=40ohm, others=RESERVED. RON_VALUE Select MRS1.DIC driver
|
|
|
|
* impedance control.
|
|
|
|
*/
|
2016-07-21 18:17:10 +02:00
|
|
|
uint8_t DramRonVal;
|
2017-03-06 17:59:23 +01:00
|
|
|
uint8_t DramRttNomVal; /* 0=40ohm, 1=60ohm, 2=120ohm, others=RSVD */
|
2016-07-21 18:17:10 +02:00
|
|
|
uint8_t DramRttWrVal; /* 0=off others=RESERVED */
|
2016-06-19 03:52:43 +02:00
|
|
|
|
|
|
|
/* 0=off, 1=60ohm, 2=120ohm, 3=180ohm, others=RESERVED */
|
2016-07-21 18:17:10 +02:00
|
|
|
uint8_t SocRdOdtVal;
|
|
|
|
uint8_t SocWrRonVal; /* 0=27ohm, 1=32ohm, 2=40ohm, others=RESERVED */
|
|
|
|
uint8_t SocWrSlewRate; /* 0=2.5V/ns, 1=4V/ns, others=RESERVED */
|
2016-06-19 03:52:43 +02:00
|
|
|
|
|
|
|
/* 0=512Mb, 1=1Gb, 2=2Gb, 3=4Gb, others=RESERVED */
|
2016-07-21 18:17:10 +02:00
|
|
|
uint8_t DramDensity;
|
|
|
|
uint8_t tCL; /* DRAM CAS Latency in clocks */
|
2016-06-19 03:52:43 +02:00
|
|
|
|
|
|
|
/* ECC scrub interval in miliseconds 1..255 (0 works as feature
|
|
|
|
* disable)
|
|
|
|
*/
|
2016-07-21 18:17:10 +02:00
|
|
|
uint8_t EccScrubInterval;
|
2016-06-19 03:52:43 +02:00
|
|
|
|
|
|
|
/* Number of 32B blocks read for ECC scrub 2..16 */
|
2016-07-21 18:17:10 +02:00
|
|
|
uint8_t EccScrubBlkSize;
|
2016-06-19 03:52:43 +02:00
|
|
|
|
2016-07-21 18:17:10 +02:00
|
|
|
uint8_t SmmTsegSize; /* SMM size in MiB */
|
2016-02-08 16:12:30 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
extern struct chip_operations soc_ops;
|
|
|
|
|
|
|
|
#endif
|