aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/edac
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/edac')
-rw-r--r--drivers/edac/i7core_edac.c39
1 files changed, 37 insertions, 2 deletions
diff --git a/drivers/edac/i7core_edac.c b/drivers/edac/i7core_edac.c
index e944b63d9f06..e525d571cb25 100644
--- a/drivers/edac/i7core_edac.c
+++ b/drivers/edac/i7core_edac.c
@@ -299,11 +299,30 @@ struct pci_id_descr pci_dev_descr_i7core[] = {
299 299
300}; 300};
301 301
302struct pci_id_descr pci_dev_descr_lynnfield[] = {
303 { PCI_DESCR( 3, 0, PCI_DEVICE_ID_INTEL_LYNNFIELD_MCR) },
304 { PCI_DESCR( 3, 1, PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_TAD) },
305 { PCI_DESCR( 3, 4, PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_TEST) },
306
307 { PCI_DESCR( 4, 0, PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH0_CTRL) },
308 { PCI_DESCR( 4, 1, PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH0_ADDR) },
309 { PCI_DESCR( 4, 2, PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH0_RANK) },
310 { PCI_DESCR( 4, 3, PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH0_TC) },
311
312 { PCI_DESCR( 4, 0, PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH1_CTRL) },
313 { PCI_DESCR( 4, 1, PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH1_ADDR) },
314 { PCI_DESCR( 4, 2, PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH1_RANK) },
315 { PCI_DESCR( 4, 3, PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH1_TC) },
316
317 { PCI_DESCR( 0, 0, PCI_DEVICE_ID_INTEL_LYNNFIELD_NONCORE) },
318};
319
302/* 320/*
303 * pci_device_id table for which devices we are looking for 321 * pci_device_id table for which devices we are looking for
304 */ 322 */
305static const struct pci_device_id i7core_pci_tbl[] __devinitdata = { 323static const struct pci_device_id i7core_pci_tbl[] __devinitdata = {
306 {PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_X58_HUB_MGMT)}, 324 {PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_X58_HUB_MGMT)},
325 {PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_LYNNFIELD_NONCORE)},
307 {0,} /* 0 terminated list. */ 326 {0,} /* 0 terminated list. */
308}; 327};
309 328
@@ -522,6 +541,9 @@ static int get_dimm_config(struct mem_ctl_info *mci, int *csrow)
522 for (i = 0; i < NUM_CHANS; i++) { 541 for (i = 0; i < NUM_CHANS; i++) {
523 u32 data, dimm_dod[3], value[8]; 542 u32 data, dimm_dod[3], value[8];
524 543
544 if (!pvt->pci_ch[i][0])
545 continue;
546
525 if (!CH_ACTIVE(pvt, i)) { 547 if (!CH_ACTIVE(pvt, i)) {
526 debugf0("Channel %i is not active\n", i); 548 debugf0("Channel %i is not active\n", i);
527 continue; 549 continue;
@@ -1001,6 +1023,9 @@ static ssize_t i7core_inject_enable_show(struct mem_ctl_info *mci,
1001 struct i7core_pvt *pvt = mci->pvt_info; 1023 struct i7core_pvt *pvt = mci->pvt_info;
1002 u32 injectmask; 1024 u32 injectmask;
1003 1025
1026 if (!pvt->pci_ch[pvt->inject.channel][0])
1027 return 0;
1028
1004 pci_read_config_dword(pvt->pci_ch[pvt->inject.channel][0], 1029 pci_read_config_dword(pvt->pci_ch[pvt->inject.channel][0],
1005 MC_CHANNEL_ERROR_INJECT, &injectmask); 1030 MC_CHANNEL_ERROR_INJECT, &injectmask);
1006 1031
@@ -1841,8 +1866,18 @@ static int __devinit i7core_probe(struct pci_dev *pdev,
1841 /* get the pci devices we want to reserve for our use */ 1866 /* get the pci devices we want to reserve for our use */
1842 mutex_lock(&i7core_edac_lock); 1867 mutex_lock(&i7core_edac_lock);
1843 1868
1844 rc = i7core_get_devices(pci_dev_descr_i7core, 1869 if (pdev->device == PCI_DEVICE_ID_INTEL_LYNNFIELD_NONCORE) {
1845 ARRAY_SIZE(pci_dev_descr_i7core)); 1870 printk(KERN_INFO "i7core_edac: detected a "
1871 "Lynnfield processor\n");
1872 rc = i7core_get_devices(pci_dev_descr_lynnfield,
1873 ARRAY_SIZE(pci_dev_descr_lynnfield));
1874 } else {
1875 printk(KERN_INFO "i7core_edac: detected a "
1876 "Nehalem/Nehalem-EP processor\n");
1877 rc = i7core_get_devices(pci_dev_descr_i7core,
1878 ARRAY_SIZE(pci_dev_descr_i7core));
1879 }
1880
1846 if (unlikely(rc < 0)) 1881 if (unlikely(rc < 0))
1847 goto fail0; 1882 goto fail0;
1848 1883