13 { 0x0F, 0xF0, 0x00, 0xF0, 0x0F, 0xF0,
14 0x0F, 0x00, 0xFF, 0x00, 0xFF, 0x00 },
15 { 0x0F, 0xF0, 0x00, 0xF0, 0x0F, 0xF0,
16 0x0F, 0x00, 0xFF, 0x00, 0xFF, 0x00 } };
25 { 0, 1, 3, 2, 6, 5, 4, 7 },
26 { 2, 3, 0, 1, 6, 7, 4, 5 } };
34 const u16 RcompResistor[3] = { 200, 81, 162 };
35 memcpy(rcomp_ptr, RcompResistor,
36 sizeof(RcompResistor));
45 static const u16 RcompTarget[5] = {
46 100, 40, 40, 23, 40 };
49 static const u16 StrengthendRcompTarget[5] = {
50 100, 40, 40, 21, 40 };
53 memcpy(rcomp_strength_ptr, StrengthendRcompTarget,
54 sizeof(StrengthendRcompTarget));
56 memcpy(rcomp_strength_ptr, RcompTarget,
sizeof(RcompTarget));
71 spd_file =
cbfs_map(
"spd.bin", &spd_file_len);
73 die(
"SPD data not found.");
77 die(
"Missing SPD data.");
98 "Dual channel SPD detected writing second channel\n");
void * memcpy(void *dest, const void *src, size_t n)
static void * cbfs_map(const char *name, size_t *size_out)
#define printk(level,...)
void __noreturn die(const char *fmt,...)
void mainboard_fill_dq_map_data(void *dq_map_ptr)
void mainboard_fill_dqs_map_data(void *dqs_map_ptr)
void mainboard_fill_rcomp_res_data(void *rcomp_ptr)
void mainboard_fill_rcomp_strength_data(void *rcomp_strength_ptr)
#define K4E6E304EE_MEM_ID
static uint8_t get_spd_index(void)
uintptr_t mainboard_get_spd_data(void)
int mainboard_has_dual_channel_mem(void)
#define BIOS_INFO
BIOS_INFO - Expected events.
#define BIOS_ERR
BIOS_ERR - System in incomplete state.
static const int spd_index[32]
static const u8 dqs_map[][8]
static const u8 dq_map[][12]
#define SAMSUNG_SINGLE_CHAN
#define HYNIX_SINGLE_CHAN