2018-05-27 03:22:33 +02:00
|
|
|
/*
|
|
|
|
* This file is part of the coreboot project.
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
2011-10-21 21:57:59 +02:00
|
|
|
#ifndef RAMINIT_H
|
|
|
|
#define RAMINIT_H
|
|
|
|
|
|
|
|
#define MAX_DIMM_SOCKETS_PER_CHANNEL 4
|
|
|
|
#define MAX_NUM_CHANNELS 2
|
|
|
|
#define MAX_DIMM_SOCKETS (MAX_NUM_CHANNELS * MAX_DIMM_SOCKETS_PER_CHANNEL)
|
|
|
|
|
|
|
|
struct mem_controller {
|
2016-09-03 10:45:33 +02:00
|
|
|
pci_devfn_t d0, d0f1; // PCI bus/device/fcns of E7501 memory controller
|
2011-10-21 21:57:59 +02:00
|
|
|
|
|
|
|
// SMBus addresses of DIMM slots for each channel,
|
|
|
|
// in order from closest to MCH to furthest away
|
|
|
|
// 0 == not present
|
|
|
|
uint16_t channel0[MAX_DIMM_SOCKETS_PER_CHANNEL];
|
|
|
|
uint16_t channel1[MAX_DIMM_SOCKETS_PER_CHANNEL];
|
|
|
|
};
|
|
|
|
|
2012-04-18 19:33:35 +02:00
|
|
|
void e7505_mch_init(const struct mem_controller *memctrl);
|
|
|
|
void e7505_mch_scrub_ecc(unsigned long ret_addr);
|
|
|
|
void e7505_mch_done(const struct mem_controller *memctrl);
|
2012-04-18 20:13:33 +02:00
|
|
|
int e7505_mch_is_ready(void);
|
|
|
|
|
|
|
|
|
|
|
|
/* Mainboard exports this. */
|
2018-09-20 17:38:38 +02:00
|
|
|
int spd_read_byte(unsigned int device, unsigned int address);
|
2011-10-21 21:57:59 +02:00
|
|
|
|
|
|
|
#endif /* RAMINIT_H */
|