summaryrefslogtreecommitdiff
path: root/drivers
diff options
context:
space:
mode:
authorVadim Bendebury <vbendeb@chromium.org>2011-11-29 10:16:14 -0800
committerVadim Bendebury <vbendeb@chromium.org>2011-12-08 11:27:22 -0800
commit9e3469de88449c1ca3af5f33a885890e9e931235 (patch)
treeea3c67e6f0eff4b08535f36f91134e295d5b8207 /drivers
parent04ed7a4e7f5e5fb60aead7855e7870068c0d6f23 (diff)
Make u-boot use the new PCH
New device ID range is included to allow the SPI driver to use the Panther Point based controller and a new device ID is checked when attaching the AHCI controller. BUG=chrome-os-partner:7112 TEST=manual After this change the top of the tree ChromeOS can be booted on IVB reworked Stumpy platforms. Change-Id: Ia41c17b58337cde2d041990b3d1c9da37c0cd92c Signed-off-by: Vadim Bendebury <vbendeb@chromium.org> Reviewed-on: https://gerrit.chromium.org/gerrit/12606
Diffstat (limited to 'drivers')
-rw-r--r--drivers/spi/ich.c31
1 files changed, 19 insertions, 12 deletions
diff --git a/drivers/spi/ich.c b/drivers/spi/ich.c
index 7a168e9310c..a602532acb1 100644
--- a/drivers/spi/ich.c
+++ b/drivers/spi/ich.c
@@ -275,11 +275,24 @@ void spi_free_slave(struct spi_slave *_slave)
free(slave);
}
-static inline int spi_is_cougarpoint_lpc(uint16_t device_id)
+/*
+ * Check if this device ID matches one of supported Intel PCH devices.
+ *
+ * Return the ICH version if there is a match, or zero otherwise.
+ */
+static inline int get_ich_version(uint16_t device_id)
{
- return device_id >= PCI_DEVICE_ID_INTEL_COUGARPOINT_LPC_MIN &&
- device_id <= PCI_DEVICE_ID_INTEL_COUGARPOINT_LPC_MAX;
-};
+ if (device_id == PCI_DEVICE_ID_INTEL_TGP_LPC)
+ return 7;
+
+ if ((device_id >= PCI_DEVICE_ID_INTEL_COUGARPOINT_LPC_MIN &&
+ device_id <= PCI_DEVICE_ID_INTEL_COUGARPOINT_LPC_MAX) ||
+ (device_id >= PCI_DEVICE_ID_INTEL_PANTHERPOINT_LPC_MIN &&
+ device_id <= PCI_DEVICE_ID_INTEL_PANTHERPOINT_LPC_MAX))
+ return 9;
+
+ return 0;
+}
void spi_init(void)
{
@@ -298,7 +311,7 @@ void spi_init(void)
return;
}
- for (bus = 0; bus <= last_bus; bus++) {
+ for (bus = 0; (bus <= last_bus) && !ich_version; bus++) {
uint32_t ids;
uint16_t vendor_id, device_id;
@@ -310,13 +323,7 @@ void spi_init(void)
if (vendor_id != PCI_VENDOR_ID_INTEL)
continue;
- if (device_id == PCI_DEVICE_ID_INTEL_TGP_LPC) {
- ich_version = 7;
- break;
- } else if (spi_is_cougarpoint_lpc(device_id)) {
- ich_version = 9;
- break;
- }
+ ich_version = get_ich_version(device_id);
}
if (!ich_version) {