diff options
Diffstat (limited to 'drivers/edac')
33 files changed, 120 insertions, 146 deletions
diff --git a/drivers/edac/Kconfig b/drivers/edac/Kconfig index 4c6c876d9dc3..66719925970f 100644 --- a/drivers/edac/Kconfig +++ b/drivers/edac/Kconfig | |||
@@ -4,6 +4,9 @@ | |||
4 | # Licensed and distributed under the GPL | 4 | # Licensed and distributed under the GPL |
5 | # | 5 | # |
6 | 6 | ||
7 | config EDAC_SUPPORT | ||
8 | bool | ||
9 | |||
7 | menuconfig EDAC | 10 | menuconfig EDAC |
8 | bool "EDAC (Error Detection And Correction) reporting" | 11 | bool "EDAC (Error Detection And Correction) reporting" |
9 | depends on HAS_IOMEM | 12 | depends on HAS_IOMEM |
@@ -27,13 +30,8 @@ menuconfig EDAC | |||
27 | There is also a mailing list for the EDAC project, which can | 30 | There is also a mailing list for the EDAC project, which can |
28 | be found via the sourceforge page. | 31 | be found via the sourceforge page. |
29 | 32 | ||
30 | config EDAC_SUPPORT | ||
31 | bool | ||
32 | |||
33 | if EDAC | 33 | if EDAC |
34 | 34 | ||
35 | comment "Reporting subsystems" | ||
36 | |||
37 | config EDAC_LEGACY_SYSFS | 35 | config EDAC_LEGACY_SYSFS |
38 | bool "EDAC legacy sysfs" | 36 | bool "EDAC legacy sysfs" |
39 | default y | 37 | default y |
diff --git a/drivers/edac/amd64_edac.c b/drivers/edac/amd64_edac.c index f74a684269ff..ad8bf2aa629d 100644 --- a/drivers/edac/amd64_edac.c +++ b/drivers/edac/amd64_edac.c | |||
@@ -2563,8 +2563,8 @@ err_ret: | |||
2563 | return ret; | 2563 | return ret; |
2564 | } | 2564 | } |
2565 | 2565 | ||
2566 | static int __devinit amd64_probe_one_instance(struct pci_dev *pdev, | 2566 | static int amd64_probe_one_instance(struct pci_dev *pdev, |
2567 | const struct pci_device_id *mc_type) | 2567 | const struct pci_device_id *mc_type) |
2568 | { | 2568 | { |
2569 | u8 nid = get_node_id(pdev); | 2569 | u8 nid = get_node_id(pdev); |
2570 | struct pci_dev *F3 = node_to_amd_nb(nid)->misc; | 2570 | struct pci_dev *F3 = node_to_amd_nb(nid)->misc; |
@@ -2612,7 +2612,7 @@ err_out: | |||
2612 | return ret; | 2612 | return ret; |
2613 | } | 2613 | } |
2614 | 2614 | ||
2615 | static void __devexit amd64_remove_one_instance(struct pci_dev *pdev) | 2615 | static void amd64_remove_one_instance(struct pci_dev *pdev) |
2616 | { | 2616 | { |
2617 | struct mem_ctl_info *mci; | 2617 | struct mem_ctl_info *mci; |
2618 | struct amd64_pvt *pvt; | 2618 | struct amd64_pvt *pvt; |
@@ -2686,7 +2686,7 @@ MODULE_DEVICE_TABLE(pci, amd64_pci_table); | |||
2686 | static struct pci_driver amd64_pci_driver = { | 2686 | static struct pci_driver amd64_pci_driver = { |
2687 | .name = EDAC_MOD_STR, | 2687 | .name = EDAC_MOD_STR, |
2688 | .probe = amd64_probe_one_instance, | 2688 | .probe = amd64_probe_one_instance, |
2689 | .remove = __devexit_p(amd64_remove_one_instance), | 2689 | .remove = amd64_remove_one_instance, |
2690 | .id_table = amd64_pci_table, | 2690 | .id_table = amd64_pci_table, |
2691 | }; | 2691 | }; |
2692 | 2692 | ||
diff --git a/drivers/edac/amd76x_edac.c b/drivers/edac/amd76x_edac.c index 29eeb68a200c..96e3ee3460a5 100644 --- a/drivers/edac/amd76x_edac.c +++ b/drivers/edac/amd76x_edac.c | |||
@@ -301,8 +301,8 @@ fail: | |||
301 | } | 301 | } |
302 | 302 | ||
303 | /* returns count (>= 0), or negative on error */ | 303 | /* returns count (>= 0), or negative on error */ |
304 | static int __devinit amd76x_init_one(struct pci_dev *pdev, | 304 | static int amd76x_init_one(struct pci_dev *pdev, |
305 | const struct pci_device_id *ent) | 305 | const struct pci_device_id *ent) |
306 | { | 306 | { |
307 | edac_dbg(0, "\n"); | 307 | edac_dbg(0, "\n"); |
308 | 308 | ||
@@ -318,7 +318,7 @@ static int __devinit amd76x_init_one(struct pci_dev *pdev, | |||
318 | * structure for the device then delete the mci and free the | 318 | * structure for the device then delete the mci and free the |
319 | * resources. | 319 | * resources. |
320 | */ | 320 | */ |
321 | static void __devexit amd76x_remove_one(struct pci_dev *pdev) | 321 | static void amd76x_remove_one(struct pci_dev *pdev) |
322 | { | 322 | { |
323 | struct mem_ctl_info *mci; | 323 | struct mem_ctl_info *mci; |
324 | 324 | ||
@@ -350,7 +350,7 @@ MODULE_DEVICE_TABLE(pci, amd76x_pci_tbl); | |||
350 | static struct pci_driver amd76x_driver = { | 350 | static struct pci_driver amd76x_driver = { |
351 | .name = EDAC_MOD_STR, | 351 | .name = EDAC_MOD_STR, |
352 | .probe = amd76x_init_one, | 352 | .probe = amd76x_init_one, |
353 | .remove = __devexit_p(amd76x_remove_one), | 353 | .remove = amd76x_remove_one, |
354 | .id_table = amd76x_pci_tbl, | 354 | .id_table = amd76x_pci_tbl, |
355 | }; | 355 | }; |
356 | 356 | ||
diff --git a/drivers/edac/cell_edac.c b/drivers/edac/cell_edac.c index a1bbd8edd257..c2eaf334b90b 100644 --- a/drivers/edac/cell_edac.c +++ b/drivers/edac/cell_edac.c | |||
@@ -124,7 +124,7 @@ static void cell_edac_check(struct mem_ctl_info *mci) | |||
124 | } | 124 | } |
125 | } | 125 | } |
126 | 126 | ||
127 | static void __devinit cell_edac_init_csrows(struct mem_ctl_info *mci) | 127 | static void cell_edac_init_csrows(struct mem_ctl_info *mci) |
128 | { | 128 | { |
129 | struct csrow_info *csrow = mci->csrows[0]; | 129 | struct csrow_info *csrow = mci->csrows[0]; |
130 | struct dimm_info *dimm; | 130 | struct dimm_info *dimm; |
@@ -164,7 +164,7 @@ static void __devinit cell_edac_init_csrows(struct mem_ctl_info *mci) | |||
164 | } | 164 | } |
165 | } | 165 | } |
166 | 166 | ||
167 | static int __devinit cell_edac_probe(struct platform_device *pdev) | 167 | static int cell_edac_probe(struct platform_device *pdev) |
168 | { | 168 | { |
169 | struct cbe_mic_tm_regs __iomem *regs; | 169 | struct cbe_mic_tm_regs __iomem *regs; |
170 | struct mem_ctl_info *mci; | 170 | struct mem_ctl_info *mci; |
@@ -233,7 +233,7 @@ static int __devinit cell_edac_probe(struct platform_device *pdev) | |||
233 | return 0; | 233 | return 0; |
234 | } | 234 | } |
235 | 235 | ||
236 | static int __devexit cell_edac_remove(struct platform_device *pdev) | 236 | static int cell_edac_remove(struct platform_device *pdev) |
237 | { | 237 | { |
238 | struct mem_ctl_info *mci = edac_mc_del_mc(&pdev->dev); | 238 | struct mem_ctl_info *mci = edac_mc_del_mc(&pdev->dev); |
239 | if (mci) | 239 | if (mci) |
@@ -247,7 +247,7 @@ static struct platform_driver cell_edac_driver = { | |||
247 | .owner = THIS_MODULE, | 247 | .owner = THIS_MODULE, |
248 | }, | 248 | }, |
249 | .probe = cell_edac_probe, | 249 | .probe = cell_edac_probe, |
250 | .remove = __devexit_p(cell_edac_remove), | 250 | .remove = cell_edac_remove, |
251 | }; | 251 | }; |
252 | 252 | ||
253 | static int __init cell_edac_init(void) | 253 | static int __init cell_edac_init(void) |
diff --git a/drivers/edac/cpc925_edac.c b/drivers/edac/cpc925_edac.c index c2ef13495873..7f3c57113ba1 100644 --- a/drivers/edac/cpc925_edac.c +++ b/drivers/edac/cpc925_edac.c | |||
@@ -932,7 +932,7 @@ static int cpc925_mc_get_channels(void __iomem *vbase) | |||
932 | return dual; | 932 | return dual; |
933 | } | 933 | } |
934 | 934 | ||
935 | static int __devinit cpc925_probe(struct platform_device *pdev) | 935 | static int cpc925_probe(struct platform_device *pdev) |
936 | { | 936 | { |
937 | static int edac_mc_idx; | 937 | static int edac_mc_idx; |
938 | struct mem_ctl_info *mci; | 938 | struct mem_ctl_info *mci; |
diff --git a/drivers/edac/e752x_edac.c b/drivers/edac/e752x_edac.c index a5ed6b795fd4..644fec54681f 100644 --- a/drivers/edac/e752x_edac.c +++ b/drivers/edac/e752x_edac.c | |||
@@ -1390,8 +1390,7 @@ fail: | |||
1390 | } | 1390 | } |
1391 | 1391 | ||
1392 | /* returns count (>= 0), or negative on error */ | 1392 | /* returns count (>= 0), or negative on error */ |
1393 | static int __devinit e752x_init_one(struct pci_dev *pdev, | 1393 | static int e752x_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) |
1394 | const struct pci_device_id *ent) | ||
1395 | { | 1394 | { |
1396 | edac_dbg(0, "\n"); | 1395 | edac_dbg(0, "\n"); |
1397 | 1396 | ||
@@ -1402,7 +1401,7 @@ static int __devinit e752x_init_one(struct pci_dev *pdev, | |||
1402 | return e752x_probe1(pdev, ent->driver_data); | 1401 | return e752x_probe1(pdev, ent->driver_data); |
1403 | } | 1402 | } |
1404 | 1403 | ||
1405 | static void __devexit e752x_remove_one(struct pci_dev *pdev) | 1404 | static void e752x_remove_one(struct pci_dev *pdev) |
1406 | { | 1405 | { |
1407 | struct mem_ctl_info *mci; | 1406 | struct mem_ctl_info *mci; |
1408 | struct e752x_pvt *pvt; | 1407 | struct e752x_pvt *pvt; |
@@ -1445,7 +1444,7 @@ MODULE_DEVICE_TABLE(pci, e752x_pci_tbl); | |||
1445 | static struct pci_driver e752x_driver = { | 1444 | static struct pci_driver e752x_driver = { |
1446 | .name = EDAC_MOD_STR, | 1445 | .name = EDAC_MOD_STR, |
1447 | .probe = e752x_init_one, | 1446 | .probe = e752x_init_one, |
1448 | .remove = __devexit_p(e752x_remove_one), | 1447 | .remove = e752x_remove_one, |
1449 | .id_table = e752x_pci_tbl, | 1448 | .id_table = e752x_pci_tbl, |
1450 | }; | 1449 | }; |
1451 | 1450 | ||
diff --git a/drivers/edac/e7xxx_edac.c b/drivers/edac/e7xxx_edac.c index 9ff57f361a43..1c4056a50383 100644 --- a/drivers/edac/e7xxx_edac.c +++ b/drivers/edac/e7xxx_edac.c | |||
@@ -528,8 +528,7 @@ fail0: | |||
528 | } | 528 | } |
529 | 529 | ||
530 | /* returns count (>= 0), or negative on error */ | 530 | /* returns count (>= 0), or negative on error */ |
531 | static int __devinit e7xxx_init_one(struct pci_dev *pdev, | 531 | static int e7xxx_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) |
532 | const struct pci_device_id *ent) | ||
533 | { | 532 | { |
534 | edac_dbg(0, "\n"); | 533 | edac_dbg(0, "\n"); |
535 | 534 | ||
@@ -538,7 +537,7 @@ static int __devinit e7xxx_init_one(struct pci_dev *pdev, | |||
538 | -EIO : e7xxx_probe1(pdev, ent->driver_data); | 537 | -EIO : e7xxx_probe1(pdev, ent->driver_data); |
539 | } | 538 | } |
540 | 539 | ||
541 | static void __devexit e7xxx_remove_one(struct pci_dev *pdev) | 540 | static void e7xxx_remove_one(struct pci_dev *pdev) |
542 | { | 541 | { |
543 | struct mem_ctl_info *mci; | 542 | struct mem_ctl_info *mci; |
544 | struct e7xxx_pvt *pvt; | 543 | struct e7xxx_pvt *pvt; |
@@ -579,7 +578,7 @@ MODULE_DEVICE_TABLE(pci, e7xxx_pci_tbl); | |||
579 | static struct pci_driver e7xxx_driver = { | 578 | static struct pci_driver e7xxx_driver = { |
580 | .name = EDAC_MOD_STR, | 579 | .name = EDAC_MOD_STR, |
581 | .probe = e7xxx_init_one, | 580 | .probe = e7xxx_init_one, |
582 | .remove = __devexit_p(e7xxx_remove_one), | 581 | .remove = e7xxx_remove_one, |
583 | .id_table = e7xxx_pci_tbl, | 582 | .id_table = e7xxx_pci_tbl, |
584 | }; | 583 | }; |
585 | 584 | ||
diff --git a/drivers/edac/edac_mc_sysfs.c b/drivers/edac/edac_mc_sysfs.c index de2df92f9c77..0ca1ca71157f 100644 --- a/drivers/edac/edac_mc_sysfs.c +++ b/drivers/edac/edac_mc_sysfs.c | |||
@@ -472,8 +472,7 @@ static void edac_delete_csrow_objects(struct mem_ctl_info *mci) | |||
472 | device_remove_file(&csrow->dev, | 472 | device_remove_file(&csrow->dev, |
473 | dynamic_csrow_ce_count_attr[chan]); | 473 | dynamic_csrow_ce_count_attr[chan]); |
474 | } | 474 | } |
475 | put_device(&mci->csrows[i]->dev); | 475 | device_unregister(&mci->csrows[i]->dev); |
476 | device_del(&mci->csrows[i]->dev); | ||
477 | } | 476 | } |
478 | } | 477 | } |
479 | #endif | 478 | #endif |
@@ -1055,11 +1054,9 @@ fail: | |||
1055 | struct dimm_info *dimm = mci->dimms[i]; | 1054 | struct dimm_info *dimm = mci->dimms[i]; |
1056 | if (dimm->nr_pages == 0) | 1055 | if (dimm->nr_pages == 0) |
1057 | continue; | 1056 | continue; |
1058 | put_device(&dimm->dev); | 1057 | device_unregister(&dimm->dev); |
1059 | device_del(&dimm->dev); | ||
1060 | } | 1058 | } |
1061 | put_device(&mci->dev); | 1059 | device_unregister(&mci->dev); |
1062 | device_del(&mci->dev); | ||
1063 | bus_unregister(&mci->bus); | 1060 | bus_unregister(&mci->bus); |
1064 | kfree(mci->bus.name); | 1061 | kfree(mci->bus.name); |
1065 | return err; | 1062 | return err; |
@@ -1086,16 +1083,14 @@ void edac_remove_sysfs_mci_device(struct mem_ctl_info *mci) | |||
1086 | if (dimm->nr_pages == 0) | 1083 | if (dimm->nr_pages == 0) |
1087 | continue; | 1084 | continue; |
1088 | edac_dbg(0, "removing device %s\n", dev_name(&dimm->dev)); | 1085 | edac_dbg(0, "removing device %s\n", dev_name(&dimm->dev)); |
1089 | put_device(&dimm->dev); | 1086 | device_unregister(&dimm->dev); |
1090 | device_del(&dimm->dev); | ||
1091 | } | 1087 | } |
1092 | } | 1088 | } |
1093 | 1089 | ||
1094 | void edac_unregister_sysfs(struct mem_ctl_info *mci) | 1090 | void edac_unregister_sysfs(struct mem_ctl_info *mci) |
1095 | { | 1091 | { |
1096 | edac_dbg(1, "Unregistering device %s\n", dev_name(&mci->dev)); | 1092 | edac_dbg(1, "Unregistering device %s\n", dev_name(&mci->dev)); |
1097 | put_device(&mci->dev); | 1093 | device_unregister(&mci->dev); |
1098 | device_del(&mci->dev); | ||
1099 | bus_unregister(&mci->bus); | 1094 | bus_unregister(&mci->bus); |
1100 | kfree(mci->bus.name); | 1095 | kfree(mci->bus.name); |
1101 | } | 1096 | } |
@@ -1159,8 +1154,6 @@ int __init edac_mc_sysfs_init(void) | |||
1159 | 1154 | ||
1160 | void __exit edac_mc_sysfs_exit(void) | 1155 | void __exit edac_mc_sysfs_exit(void) |
1161 | { | 1156 | { |
1162 | put_device(mci_pdev); | 1157 | device_unregister(mci_pdev); |
1163 | device_del(mci_pdev); | ||
1164 | edac_put_sysfs_subsys(); | 1158 | edac_put_sysfs_subsys(); |
1165 | kfree(mci_pdev); | ||
1166 | } | 1159 | } |
diff --git a/drivers/edac/highbank_l2_edac.c b/drivers/edac/highbank_l2_edac.c index e599b00c05a8..c2bd8c6a4349 100644 --- a/drivers/edac/highbank_l2_edac.c +++ b/drivers/edac/highbank_l2_edac.c | |||
@@ -50,7 +50,7 @@ static irqreturn_t highbank_l2_err_handler(int irq, void *dev_id) | |||
50 | return IRQ_HANDLED; | 50 | return IRQ_HANDLED; |
51 | } | 51 | } |
52 | 52 | ||
53 | static int __devinit highbank_l2_err_probe(struct platform_device *pdev) | 53 | static int highbank_l2_err_probe(struct platform_device *pdev) |
54 | { | 54 | { |
55 | struct edac_device_ctl_info *dci; | 55 | struct edac_device_ctl_info *dci; |
56 | struct hb_l2_drvdata *drvdata; | 56 | struct hb_l2_drvdata *drvdata; |
diff --git a/drivers/edac/highbank_mc_edac.c b/drivers/edac/highbank_mc_edac.c index 7ea4cc2e8bd2..4695dd2d71fd 100644 --- a/drivers/edac/highbank_mc_edac.c +++ b/drivers/edac/highbank_mc_edac.c | |||
@@ -119,7 +119,7 @@ static const struct file_operations highbank_mc_debug_inject_fops = { | |||
119 | .llseek = generic_file_llseek, | 119 | .llseek = generic_file_llseek, |
120 | }; | 120 | }; |
121 | 121 | ||
122 | static void __devinit highbank_mc_create_debugfs_nodes(struct mem_ctl_info *mci) | 122 | static void highbank_mc_create_debugfs_nodes(struct mem_ctl_info *mci) |
123 | { | 123 | { |
124 | if (mci->debugfs) | 124 | if (mci->debugfs) |
125 | debugfs_create_file("inject_ctrl", S_IWUSR, mci->debugfs, mci, | 125 | debugfs_create_file("inject_ctrl", S_IWUSR, mci->debugfs, mci, |
@@ -127,11 +127,11 @@ static void __devinit highbank_mc_create_debugfs_nodes(struct mem_ctl_info *mci) | |||
127 | ; | 127 | ; |
128 | } | 128 | } |
129 | #else | 129 | #else |
130 | static void __devinit highbank_mc_create_debugfs_nodes(struct mem_ctl_info *mci) | 130 | static void highbank_mc_create_debugfs_nodes(struct mem_ctl_info *mci) |
131 | {} | 131 | {} |
132 | #endif | 132 | #endif |
133 | 133 | ||
134 | static int __devinit highbank_mc_probe(struct platform_device *pdev) | 134 | static int highbank_mc_probe(struct platform_device *pdev) |
135 | { | 135 | { |
136 | struct edac_mc_layer layers[2]; | 136 | struct edac_mc_layer layers[2]; |
137 | struct mem_ctl_info *mci; | 137 | struct mem_ctl_info *mci; |
diff --git a/drivers/edac/i3000_edac.c b/drivers/edac/i3000_edac.c index d3d19cc4e9a1..694efcbf19c0 100644 --- a/drivers/edac/i3000_edac.c +++ b/drivers/edac/i3000_edac.c | |||
@@ -455,8 +455,7 @@ fail: | |||
455 | } | 455 | } |
456 | 456 | ||
457 | /* returns count (>= 0), or negative on error */ | 457 | /* returns count (>= 0), or negative on error */ |
458 | static int __devinit i3000_init_one(struct pci_dev *pdev, | 458 | static int i3000_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) |
459 | const struct pci_device_id *ent) | ||
460 | { | 459 | { |
461 | int rc; | 460 | int rc; |
462 | 461 | ||
@@ -472,7 +471,7 @@ static int __devinit i3000_init_one(struct pci_dev *pdev, | |||
472 | return rc; | 471 | return rc; |
473 | } | 472 | } |
474 | 473 | ||
475 | static void __devexit i3000_remove_one(struct pci_dev *pdev) | 474 | static void i3000_remove_one(struct pci_dev *pdev) |
476 | { | 475 | { |
477 | struct mem_ctl_info *mci; | 476 | struct mem_ctl_info *mci; |
478 | 477 | ||
@@ -502,7 +501,7 @@ MODULE_DEVICE_TABLE(pci, i3000_pci_tbl); | |||
502 | static struct pci_driver i3000_driver = { | 501 | static struct pci_driver i3000_driver = { |
503 | .name = EDAC_MOD_STR, | 502 | .name = EDAC_MOD_STR, |
504 | .probe = i3000_init_one, | 503 | .probe = i3000_init_one, |
505 | .remove = __devexit_p(i3000_remove_one), | 504 | .remove = i3000_remove_one, |
506 | .id_table = i3000_pci_tbl, | 505 | .id_table = i3000_pci_tbl, |
507 | }; | 506 | }; |
508 | 507 | ||
diff --git a/drivers/edac/i3200_edac.c b/drivers/edac/i3200_edac.c index b6653a6fc5d5..4e8337602e78 100644 --- a/drivers/edac/i3200_edac.c +++ b/drivers/edac/i3200_edac.c | |||
@@ -419,8 +419,7 @@ fail: | |||
419 | return rc; | 419 | return rc; |
420 | } | 420 | } |
421 | 421 | ||
422 | static int __devinit i3200_init_one(struct pci_dev *pdev, | 422 | static int i3200_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) |
423 | const struct pci_device_id *ent) | ||
424 | { | 423 | { |
425 | int rc; | 424 | int rc; |
426 | 425 | ||
@@ -436,7 +435,7 @@ static int __devinit i3200_init_one(struct pci_dev *pdev, | |||
436 | return rc; | 435 | return rc; |
437 | } | 436 | } |
438 | 437 | ||
439 | static void __devexit i3200_remove_one(struct pci_dev *pdev) | 438 | static void i3200_remove_one(struct pci_dev *pdev) |
440 | { | 439 | { |
441 | struct mem_ctl_info *mci; | 440 | struct mem_ctl_info *mci; |
442 | struct i3200_priv *priv; | 441 | struct i3200_priv *priv; |
@@ -467,7 +466,7 @@ MODULE_DEVICE_TABLE(pci, i3200_pci_tbl); | |||
467 | static struct pci_driver i3200_driver = { | 466 | static struct pci_driver i3200_driver = { |
468 | .name = EDAC_MOD_STR, | 467 | .name = EDAC_MOD_STR, |
469 | .probe = i3200_init_one, | 468 | .probe = i3200_init_one, |
470 | .remove = __devexit_p(i3200_remove_one), | 469 | .remove = i3200_remove_one, |
471 | .id_table = i3200_pci_tbl, | 470 | .id_table = i3200_pci_tbl, |
472 | }; | 471 | }; |
473 | 472 | ||
diff --git a/drivers/edac/i5000_edac.c b/drivers/edac/i5000_edac.c index 6a49dd00b81b..63b2194e8c20 100644 --- a/drivers/edac/i5000_edac.c +++ b/drivers/edac/i5000_edac.c | |||
@@ -1489,8 +1489,7 @@ fail0: | |||
1489 | * negative on error | 1489 | * negative on error |
1490 | * count (>= 0) | 1490 | * count (>= 0) |
1491 | */ | 1491 | */ |
1492 | static int __devinit i5000_init_one(struct pci_dev *pdev, | 1492 | static int i5000_init_one(struct pci_dev *pdev, const struct pci_device_id *id) |
1493 | const struct pci_device_id *id) | ||
1494 | { | 1493 | { |
1495 | int rc; | 1494 | int rc; |
1496 | 1495 | ||
@@ -1509,7 +1508,7 @@ static int __devinit i5000_init_one(struct pci_dev *pdev, | |||
1509 | * i5000_remove_one destructor for one instance of device | 1508 | * i5000_remove_one destructor for one instance of device |
1510 | * | 1509 | * |
1511 | */ | 1510 | */ |
1512 | static void __devexit i5000_remove_one(struct pci_dev *pdev) | 1511 | static void i5000_remove_one(struct pci_dev *pdev) |
1513 | { | 1512 | { |
1514 | struct mem_ctl_info *mci; | 1513 | struct mem_ctl_info *mci; |
1515 | 1514 | ||
@@ -1547,7 +1546,7 @@ MODULE_DEVICE_TABLE(pci, i5000_pci_tbl); | |||
1547 | static struct pci_driver i5000_driver = { | 1546 | static struct pci_driver i5000_driver = { |
1548 | .name = KBUILD_BASENAME, | 1547 | .name = KBUILD_BASENAME, |
1549 | .probe = i5000_init_one, | 1548 | .probe = i5000_init_one, |
1550 | .remove = __devexit_p(i5000_remove_one), | 1549 | .remove = i5000_remove_one, |
1551 | .id_table = i5000_pci_tbl, | 1550 | .id_table = i5000_pci_tbl, |
1552 | }; | 1551 | }; |
1553 | 1552 | ||
diff --git a/drivers/edac/i5100_edac.c b/drivers/edac/i5100_edac.c index c4b5e5f868e8..d6955b2cc99f 100644 --- a/drivers/edac/i5100_edac.c +++ b/drivers/edac/i5100_edac.c | |||
@@ -638,8 +638,7 @@ static struct pci_dev *pci_get_device_func(unsigned vendor, | |||
638 | return ret; | 638 | return ret; |
639 | } | 639 | } |
640 | 640 | ||
641 | static unsigned long __devinit i5100_npages(struct mem_ctl_info *mci, | 641 | static unsigned long i5100_npages(struct mem_ctl_info *mci, int csrow) |
642 | int csrow) | ||
643 | { | 642 | { |
644 | struct i5100_priv *priv = mci->pvt_info; | 643 | struct i5100_priv *priv = mci->pvt_info; |
645 | const unsigned chan_rank = i5100_csrow_to_rank(mci, csrow); | 644 | const unsigned chan_rank = i5100_csrow_to_rank(mci, csrow); |
@@ -660,7 +659,7 @@ static unsigned long __devinit i5100_npages(struct mem_ctl_info *mci, | |||
660 | ((unsigned long long) (1ULL << addr_lines) / PAGE_SIZE); | 659 | ((unsigned long long) (1ULL << addr_lines) / PAGE_SIZE); |
661 | } | 660 | } |
662 | 661 | ||
663 | static void __devinit i5100_init_mtr(struct mem_ctl_info *mci) | 662 | static void i5100_init_mtr(struct mem_ctl_info *mci) |
664 | { | 663 | { |
665 | struct i5100_priv *priv = mci->pvt_info; | 664 | struct i5100_priv *priv = mci->pvt_info; |
666 | struct pci_dev *mms[2] = { priv->ch0mm, priv->ch1mm }; | 665 | struct pci_dev *mms[2] = { priv->ch0mm, priv->ch1mm }; |
@@ -732,7 +731,7 @@ static int i5100_read_spd_byte(const struct mem_ctl_info *mci, | |||
732 | * o not the only way to may chip selects to dimm slots | 731 | * o not the only way to may chip selects to dimm slots |
733 | * o investigate if there is some way to obtain this map from the bios | 732 | * o investigate if there is some way to obtain this map from the bios |
734 | */ | 733 | */ |
735 | static void __devinit i5100_init_dimm_csmap(struct mem_ctl_info *mci) | 734 | static void i5100_init_dimm_csmap(struct mem_ctl_info *mci) |
736 | { | 735 | { |
737 | struct i5100_priv *priv = mci->pvt_info; | 736 | struct i5100_priv *priv = mci->pvt_info; |
738 | int i; | 737 | int i; |
@@ -762,8 +761,8 @@ static void __devinit i5100_init_dimm_csmap(struct mem_ctl_info *mci) | |||
762 | } | 761 | } |
763 | } | 762 | } |
764 | 763 | ||
765 | static void __devinit i5100_init_dimm_layout(struct pci_dev *pdev, | 764 | static void i5100_init_dimm_layout(struct pci_dev *pdev, |
766 | struct mem_ctl_info *mci) | 765 | struct mem_ctl_info *mci) |
767 | { | 766 | { |
768 | struct i5100_priv *priv = mci->pvt_info; | 767 | struct i5100_priv *priv = mci->pvt_info; |
769 | int i; | 768 | int i; |
@@ -784,8 +783,8 @@ static void __devinit i5100_init_dimm_layout(struct pci_dev *pdev, | |||
784 | i5100_init_dimm_csmap(mci); | 783 | i5100_init_dimm_csmap(mci); |
785 | } | 784 | } |
786 | 785 | ||
787 | static void __devinit i5100_init_interleaving(struct pci_dev *pdev, | 786 | static void i5100_init_interleaving(struct pci_dev *pdev, |
788 | struct mem_ctl_info *mci) | 787 | struct mem_ctl_info *mci) |
789 | { | 788 | { |
790 | u16 w; | 789 | u16 w; |
791 | u32 dw; | 790 | u32 dw; |
@@ -830,7 +829,7 @@ static void __devinit i5100_init_interleaving(struct pci_dev *pdev, | |||
830 | i5100_init_mtr(mci); | 829 | i5100_init_mtr(mci); |
831 | } | 830 | } |
832 | 831 | ||
833 | static void __devinit i5100_init_csrows(struct mem_ctl_info *mci) | 832 | static void i5100_init_csrows(struct mem_ctl_info *mci) |
834 | { | 833 | { |
835 | int i; | 834 | int i; |
836 | struct i5100_priv *priv = mci->pvt_info; | 835 | struct i5100_priv *priv = mci->pvt_info; |
@@ -864,8 +863,7 @@ static void __devinit i5100_init_csrows(struct mem_ctl_info *mci) | |||
864 | } | 863 | } |
865 | } | 864 | } |
866 | 865 | ||
867 | static int __devinit i5100_init_one(struct pci_dev *pdev, | 866 | static int i5100_init_one(struct pci_dev *pdev, const struct pci_device_id *id) |
868 | const struct pci_device_id *id) | ||
869 | { | 867 | { |
870 | int rc; | 868 | int rc; |
871 | struct mem_ctl_info *mci; | 869 | struct mem_ctl_info *mci; |
@@ -1020,7 +1018,7 @@ bail: | |||
1020 | return ret; | 1018 | return ret; |
1021 | } | 1019 | } |
1022 | 1020 | ||
1023 | static void __devexit i5100_remove_one(struct pci_dev *pdev) | 1021 | static void i5100_remove_one(struct pci_dev *pdev) |
1024 | { | 1022 | { |
1025 | struct mem_ctl_info *mci; | 1023 | struct mem_ctl_info *mci; |
1026 | struct i5100_priv *priv; | 1024 | struct i5100_priv *priv; |
@@ -1054,7 +1052,7 @@ MODULE_DEVICE_TABLE(pci, i5100_pci_tbl); | |||
1054 | static struct pci_driver i5100_driver = { | 1052 | static struct pci_driver i5100_driver = { |
1055 | .name = KBUILD_BASENAME, | 1053 | .name = KBUILD_BASENAME, |
1056 | .probe = i5100_init_one, | 1054 | .probe = i5100_init_one, |
1057 | .remove = __devexit_p(i5100_remove_one), | 1055 | .remove = i5100_remove_one, |
1058 | .id_table = i5100_pci_tbl, | 1056 | .id_table = i5100_pci_tbl, |
1059 | }; | 1057 | }; |
1060 | 1058 | ||
diff --git a/drivers/edac/i5400_edac.c b/drivers/edac/i5400_edac.c index 277246998b80..0a05bbceb08f 100644 --- a/drivers/edac/i5400_edac.c +++ b/drivers/edac/i5400_edac.c | |||
@@ -1373,8 +1373,7 @@ fail0: | |||
1373 | * negative on error | 1373 | * negative on error |
1374 | * count (>= 0) | 1374 | * count (>= 0) |
1375 | */ | 1375 | */ |
1376 | static int __devinit i5400_init_one(struct pci_dev *pdev, | 1376 | static int i5400_init_one(struct pci_dev *pdev, const struct pci_device_id *id) |
1377 | const struct pci_device_id *id) | ||
1378 | { | 1377 | { |
1379 | int rc; | 1378 | int rc; |
1380 | 1379 | ||
@@ -1393,7 +1392,7 @@ static int __devinit i5400_init_one(struct pci_dev *pdev, | |||
1393 | * i5400_remove_one destructor for one instance of device | 1392 | * i5400_remove_one destructor for one instance of device |
1394 | * | 1393 | * |
1395 | */ | 1394 | */ |
1396 | static void __devexit i5400_remove_one(struct pci_dev *pdev) | 1395 | static void i5400_remove_one(struct pci_dev *pdev) |
1397 | { | 1396 | { |
1398 | struct mem_ctl_info *mci; | 1397 | struct mem_ctl_info *mci; |
1399 | 1398 | ||
@@ -1431,7 +1430,7 @@ MODULE_DEVICE_TABLE(pci, i5400_pci_tbl); | |||
1431 | static struct pci_driver i5400_driver = { | 1430 | static struct pci_driver i5400_driver = { |
1432 | .name = "i5400_edac", | 1431 | .name = "i5400_edac", |
1433 | .probe = i5400_init_one, | 1432 | .probe = i5400_init_one, |
1434 | .remove = __devexit_p(i5400_remove_one), | 1433 | .remove = i5400_remove_one, |
1435 | .id_table = i5400_pci_tbl, | 1434 | .id_table = i5400_pci_tbl, |
1436 | }; | 1435 | }; |
1437 | 1436 | ||
diff --git a/drivers/edac/i7300_edac.c b/drivers/edac/i7300_edac.c index 9d669cd43618..087c27bc5d42 100644 --- a/drivers/edac/i7300_edac.c +++ b/drivers/edac/i7300_edac.c | |||
@@ -923,7 +923,7 @@ static void i7300_put_devices(struct mem_ctl_info *mci) | |||
923 | * Device 21 function 0: PCI_DEVICE_ID_INTEL_I7300_MCH_FB0 | 923 | * Device 21 function 0: PCI_DEVICE_ID_INTEL_I7300_MCH_FB0 |
924 | * Device 22 function 0: PCI_DEVICE_ID_INTEL_I7300_MCH_FB1 | 924 | * Device 22 function 0: PCI_DEVICE_ID_INTEL_I7300_MCH_FB1 |
925 | */ | 925 | */ |
926 | static int __devinit i7300_get_devices(struct mem_ctl_info *mci) | 926 | static int i7300_get_devices(struct mem_ctl_info *mci) |
927 | { | 927 | { |
928 | struct i7300_pvt *pvt; | 928 | struct i7300_pvt *pvt; |
929 | struct pci_dev *pdev; | 929 | struct pci_dev *pdev; |
@@ -1008,8 +1008,7 @@ error: | |||
1008 | * @pdev: struct pci_dev pointer | 1008 | * @pdev: struct pci_dev pointer |
1009 | * @id: struct pci_device_id pointer - currently unused | 1009 | * @id: struct pci_device_id pointer - currently unused |
1010 | */ | 1010 | */ |
1011 | static int __devinit i7300_init_one(struct pci_dev *pdev, | 1011 | static int i7300_init_one(struct pci_dev *pdev, const struct pci_device_id *id) |
1012 | const struct pci_device_id *id) | ||
1013 | { | 1012 | { |
1014 | struct mem_ctl_info *mci; | 1013 | struct mem_ctl_info *mci; |
1015 | struct edac_mc_layer layers[3]; | 1014 | struct edac_mc_layer layers[3]; |
@@ -1122,7 +1121,7 @@ fail0: | |||
1122 | * i7300_remove_one() - Remove the driver | 1121 | * i7300_remove_one() - Remove the driver |
1123 | * @pdev: struct pci_dev pointer | 1122 | * @pdev: struct pci_dev pointer |
1124 | */ | 1123 | */ |
1125 | static void __devexit i7300_remove_one(struct pci_dev *pdev) | 1124 | static void i7300_remove_one(struct pci_dev *pdev) |
1126 | { | 1125 | { |
1127 | struct mem_ctl_info *mci; | 1126 | struct mem_ctl_info *mci; |
1128 | char *tmp; | 1127 | char *tmp; |
@@ -1163,7 +1162,7 @@ MODULE_DEVICE_TABLE(pci, i7300_pci_tbl); | |||
1163 | static struct pci_driver i7300_driver = { | 1162 | static struct pci_driver i7300_driver = { |
1164 | .name = "i7300_edac", | 1163 | .name = "i7300_edac", |
1165 | .probe = i7300_init_one, | 1164 | .probe = i7300_init_one, |
1166 | .remove = __devexit_p(i7300_remove_one), | 1165 | .remove = i7300_remove_one, |
1167 | .id_table = i7300_pci_tbl, | 1166 | .id_table = i7300_pci_tbl, |
1168 | }; | 1167 | }; |
1169 | 1168 | ||
diff --git a/drivers/edac/i7core_edac.c b/drivers/edac/i7core_edac.c index 10c8c00d6469..e213d030b0dd 100644 --- a/drivers/edac/i7core_edac.c +++ b/drivers/edac/i7core_edac.c | |||
@@ -2305,8 +2305,7 @@ fail0: | |||
2305 | * < 0 for error code | 2305 | * < 0 for error code |
2306 | */ | 2306 | */ |
2307 | 2307 | ||
2308 | static int __devinit i7core_probe(struct pci_dev *pdev, | 2308 | static int i7core_probe(struct pci_dev *pdev, const struct pci_device_id *id) |
2309 | const struct pci_device_id *id) | ||
2310 | { | 2309 | { |
2311 | int rc, count = 0; | 2310 | int rc, count = 0; |
2312 | struct i7core_dev *i7core_dev; | 2311 | struct i7core_dev *i7core_dev; |
@@ -2368,7 +2367,7 @@ fail0: | |||
2368 | * i7core_remove destructor for one instance of device | 2367 | * i7core_remove destructor for one instance of device |
2369 | * | 2368 | * |
2370 | */ | 2369 | */ |
2371 | static void __devexit i7core_remove(struct pci_dev *pdev) | 2370 | static void i7core_remove(struct pci_dev *pdev) |
2372 | { | 2371 | { |
2373 | struct i7core_dev *i7core_dev; | 2372 | struct i7core_dev *i7core_dev; |
2374 | 2373 | ||
@@ -2409,7 +2408,7 @@ MODULE_DEVICE_TABLE(pci, i7core_pci_tbl); | |||
2409 | static struct pci_driver i7core_driver = { | 2408 | static struct pci_driver i7core_driver = { |
2410 | .name = "i7core_edac", | 2409 | .name = "i7core_edac", |
2411 | .probe = i7core_probe, | 2410 | .probe = i7core_probe, |
2412 | .remove = __devexit_p(i7core_remove), | 2411 | .remove = i7core_remove, |
2413 | .id_table = i7core_pci_tbl, | 2412 | .id_table = i7core_pci_tbl, |
2414 | }; | 2413 | }; |
2415 | 2414 | ||
diff --git a/drivers/edac/i82443bxgx_edac.c b/drivers/edac/i82443bxgx_edac.c index 90f303db5d1d..57fdb77903ba 100644 --- a/drivers/edac/i82443bxgx_edac.c +++ b/drivers/edac/i82443bxgx_edac.c | |||
@@ -353,8 +353,8 @@ fail: | |||
353 | EXPORT_SYMBOL_GPL(i82443bxgx_edacmc_probe1); | 353 | EXPORT_SYMBOL_GPL(i82443bxgx_edacmc_probe1); |
354 | 354 | ||
355 | /* returns count (>= 0), or negative on error */ | 355 | /* returns count (>= 0), or negative on error */ |
356 | static int __devinit i82443bxgx_edacmc_init_one(struct pci_dev *pdev, | 356 | static int i82443bxgx_edacmc_init_one(struct pci_dev *pdev, |
357 | const struct pci_device_id *ent) | 357 | const struct pci_device_id *ent) |
358 | { | 358 | { |
359 | int rc; | 359 | int rc; |
360 | 360 | ||
@@ -369,7 +369,7 @@ static int __devinit i82443bxgx_edacmc_init_one(struct pci_dev *pdev, | |||
369 | return rc; | 369 | return rc; |
370 | } | 370 | } |
371 | 371 | ||
372 | static void __devexit i82443bxgx_edacmc_remove_one(struct pci_dev *pdev) | 372 | static void i82443bxgx_edacmc_remove_one(struct pci_dev *pdev) |
373 | { | 373 | { |
374 | struct mem_ctl_info *mci; | 374 | struct mem_ctl_info *mci; |
375 | 375 | ||
@@ -399,7 +399,7 @@ MODULE_DEVICE_TABLE(pci, i82443bxgx_pci_tbl); | |||
399 | static struct pci_driver i82443bxgx_edacmc_driver = { | 399 | static struct pci_driver i82443bxgx_edacmc_driver = { |
400 | .name = EDAC_MOD_STR, | 400 | .name = EDAC_MOD_STR, |
401 | .probe = i82443bxgx_edacmc_init_one, | 401 | .probe = i82443bxgx_edacmc_init_one, |
402 | .remove = __devexit_p(i82443bxgx_edacmc_remove_one), | 402 | .remove = i82443bxgx_edacmc_remove_one, |
403 | .id_table = i82443bxgx_pci_tbl, | 403 | .id_table = i82443bxgx_pci_tbl, |
404 | }; | 404 | }; |
405 | 405 | ||
diff --git a/drivers/edac/i82860_edac.c b/drivers/edac/i82860_edac.c index 1faa74971513..3e3e431c8301 100644 --- a/drivers/edac/i82860_edac.c +++ b/drivers/edac/i82860_edac.c | |||
@@ -254,8 +254,8 @@ fail: | |||
254 | } | 254 | } |
255 | 255 | ||
256 | /* returns count (>= 0), or negative on error */ | 256 | /* returns count (>= 0), or negative on error */ |
257 | static int __devinit i82860_init_one(struct pci_dev *pdev, | 257 | static int i82860_init_one(struct pci_dev *pdev, |
258 | const struct pci_device_id *ent) | 258 | const struct pci_device_id *ent) |
259 | { | 259 | { |
260 | int rc; | 260 | int rc; |
261 | 261 | ||
@@ -273,7 +273,7 @@ static int __devinit i82860_init_one(struct pci_dev *pdev, | |||
273 | return rc; | 273 | return rc; |
274 | } | 274 | } |
275 | 275 | ||
276 | static void __devexit i82860_remove_one(struct pci_dev *pdev) | 276 | static void i82860_remove_one(struct pci_dev *pdev) |
277 | { | 277 | { |
278 | struct mem_ctl_info *mci; | 278 | struct mem_ctl_info *mci; |
279 | 279 | ||
@@ -302,7 +302,7 @@ MODULE_DEVICE_TABLE(pci, i82860_pci_tbl); | |||
302 | static struct pci_driver i82860_driver = { | 302 | static struct pci_driver i82860_driver = { |
303 | .name = EDAC_MOD_STR, | 303 | .name = EDAC_MOD_STR, |
304 | .probe = i82860_init_one, | 304 | .probe = i82860_init_one, |
305 | .remove = __devexit_p(i82860_remove_one), | 305 | .remove = i82860_remove_one, |
306 | .id_table = i82860_pci_tbl, | 306 | .id_table = i82860_pci_tbl, |
307 | }; | 307 | }; |
308 | 308 | ||
diff --git a/drivers/edac/i82875p_edac.c b/drivers/edac/i82875p_edac.c index 3e416b1a6b53..2f8535fc451e 100644 --- a/drivers/edac/i82875p_edac.c +++ b/drivers/edac/i82875p_edac.c | |||
@@ -479,8 +479,8 @@ fail0: | |||
479 | } | 479 | } |
480 | 480 | ||
481 | /* returns count (>= 0), or negative on error */ | 481 | /* returns count (>= 0), or negative on error */ |
482 | static int __devinit i82875p_init_one(struct pci_dev *pdev, | 482 | static int i82875p_init_one(struct pci_dev *pdev, |
483 | const struct pci_device_id *ent) | 483 | const struct pci_device_id *ent) |
484 | { | 484 | { |
485 | int rc; | 485 | int rc; |
486 | 486 | ||
@@ -498,7 +498,7 @@ static int __devinit i82875p_init_one(struct pci_dev *pdev, | |||
498 | return rc; | 498 | return rc; |
499 | } | 499 | } |
500 | 500 | ||
501 | static void __devexit i82875p_remove_one(struct pci_dev *pdev) | 501 | static void i82875p_remove_one(struct pci_dev *pdev) |
502 | { | 502 | { |
503 | struct mem_ctl_info *mci; | 503 | struct mem_ctl_info *mci; |
504 | struct i82875p_pvt *pvt = NULL; | 504 | struct i82875p_pvt *pvt = NULL; |
@@ -541,7 +541,7 @@ MODULE_DEVICE_TABLE(pci, i82875p_pci_tbl); | |||
541 | static struct pci_driver i82875p_driver = { | 541 | static struct pci_driver i82875p_driver = { |
542 | .name = EDAC_MOD_STR, | 542 | .name = EDAC_MOD_STR, |
543 | .probe = i82875p_init_one, | 543 | .probe = i82875p_init_one, |
544 | .remove = __devexit_p(i82875p_remove_one), | 544 | .remove = i82875p_remove_one, |
545 | .id_table = i82875p_pci_tbl, | 545 | .id_table = i82875p_pci_tbl, |
546 | }; | 546 | }; |
547 | 547 | ||
diff --git a/drivers/edac/i82975x_edac.c b/drivers/edac/i82975x_edac.c index a98020409fa9..0c8d4b0eaa32 100644 --- a/drivers/edac/i82975x_edac.c +++ b/drivers/edac/i82975x_edac.c | |||
@@ -592,8 +592,8 @@ fail0: | |||
592 | } | 592 | } |
593 | 593 | ||
594 | /* returns count (>= 0), or negative on error */ | 594 | /* returns count (>= 0), or negative on error */ |
595 | static int __devinit i82975x_init_one(struct pci_dev *pdev, | 595 | static int i82975x_init_one(struct pci_dev *pdev, |
596 | const struct pci_device_id *ent) | 596 | const struct pci_device_id *ent) |
597 | { | 597 | { |
598 | int rc; | 598 | int rc; |
599 | 599 | ||
@@ -610,7 +610,7 @@ static int __devinit i82975x_init_one(struct pci_dev *pdev, | |||
610 | return rc; | 610 | return rc; |
611 | } | 611 | } |
612 | 612 | ||
613 | static void __devexit i82975x_remove_one(struct pci_dev *pdev) | 613 | static void i82975x_remove_one(struct pci_dev *pdev) |
614 | { | 614 | { |
615 | struct mem_ctl_info *mci; | 615 | struct mem_ctl_info *mci; |
616 | struct i82975x_pvt *pvt; | 616 | struct i82975x_pvt *pvt; |
@@ -643,7 +643,7 @@ MODULE_DEVICE_TABLE(pci, i82975x_pci_tbl); | |||
643 | static struct pci_driver i82975x_driver = { | 643 | static struct pci_driver i82975x_driver = { |
644 | .name = EDAC_MOD_STR, | 644 | .name = EDAC_MOD_STR, |
645 | .probe = i82975x_init_one, | 645 | .probe = i82975x_init_one, |
646 | .remove = __devexit_p(i82975x_remove_one), | 646 | .remove = i82975x_remove_one, |
647 | .id_table = i82975x_pci_tbl, | 647 | .id_table = i82975x_pci_tbl, |
648 | }; | 648 | }; |
649 | 649 | ||
diff --git a/drivers/edac/mpc85xx_edac.c b/drivers/edac/mpc85xx_edac.c index 4fe66fa183ec..42a840d530a5 100644 --- a/drivers/edac/mpc85xx_edac.c +++ b/drivers/edac/mpc85xx_edac.c | |||
@@ -212,7 +212,7 @@ static irqreturn_t mpc85xx_pci_isr(int irq, void *dev_id) | |||
212 | return IRQ_HANDLED; | 212 | return IRQ_HANDLED; |
213 | } | 213 | } |
214 | 214 | ||
215 | int __devinit mpc85xx_pci_err_probe(struct platform_device *op) | 215 | int mpc85xx_pci_err_probe(struct platform_device *op) |
216 | { | 216 | { |
217 | struct edac_pci_ctl_info *pci; | 217 | struct edac_pci_ctl_info *pci; |
218 | struct mpc85xx_pci_pdata *pdata; | 218 | struct mpc85xx_pci_pdata *pdata; |
@@ -504,7 +504,7 @@ static irqreturn_t mpc85xx_l2_isr(int irq, void *dev_id) | |||
504 | return IRQ_HANDLED; | 504 | return IRQ_HANDLED; |
505 | } | 505 | } |
506 | 506 | ||
507 | static int __devinit mpc85xx_l2_err_probe(struct platform_device *op) | 507 | static int mpc85xx_l2_err_probe(struct platform_device *op) |
508 | { | 508 | { |
509 | struct edac_device_ctl_info *edac_dev; | 509 | struct edac_device_ctl_info *edac_dev; |
510 | struct mpc85xx_l2_pdata *pdata; | 510 | struct mpc85xx_l2_pdata *pdata; |
@@ -885,7 +885,7 @@ static irqreturn_t mpc85xx_mc_isr(int irq, void *dev_id) | |||
885 | return IRQ_HANDLED; | 885 | return IRQ_HANDLED; |
886 | } | 886 | } |
887 | 887 | ||
888 | static void __devinit mpc85xx_init_csrows(struct mem_ctl_info *mci) | 888 | static void mpc85xx_init_csrows(struct mem_ctl_info *mci) |
889 | { | 889 | { |
890 | struct mpc85xx_mc_pdata *pdata = mci->pvt_info; | 890 | struct mpc85xx_mc_pdata *pdata = mci->pvt_info; |
891 | struct csrow_info *csrow; | 891 | struct csrow_info *csrow; |
@@ -964,7 +964,7 @@ static void __devinit mpc85xx_init_csrows(struct mem_ctl_info *mci) | |||
964 | } | 964 | } |
965 | } | 965 | } |
966 | 966 | ||
967 | static int __devinit mpc85xx_mc_err_probe(struct platform_device *op) | 967 | static int mpc85xx_mc_err_probe(struct platform_device *op) |
968 | { | 968 | { |
969 | struct mem_ctl_info *mci; | 969 | struct mem_ctl_info *mci; |
970 | struct edac_mc_layer layers[2]; | 970 | struct edac_mc_layer layers[2]; |
diff --git a/drivers/edac/mv64x60_edac.c b/drivers/edac/mv64x60_edac.c index 2b315c2edc3c..542fad70e360 100644 --- a/drivers/edac/mv64x60_edac.c +++ b/drivers/edac/mv64x60_edac.c | |||
@@ -100,7 +100,7 @@ static int __init mv64x60_pci_fixup(struct platform_device *pdev) | |||
100 | return 0; | 100 | return 0; |
101 | } | 101 | } |
102 | 102 | ||
103 | static int __devinit mv64x60_pci_err_probe(struct platform_device *pdev) | 103 | static int mv64x60_pci_err_probe(struct platform_device *pdev) |
104 | { | 104 | { |
105 | struct edac_pci_ctl_info *pci; | 105 | struct edac_pci_ctl_info *pci; |
106 | struct mv64x60_pci_pdata *pdata; | 106 | struct mv64x60_pci_pdata *pdata; |
@@ -221,7 +221,7 @@ static int mv64x60_pci_err_remove(struct platform_device *pdev) | |||
221 | 221 | ||
222 | static struct platform_driver mv64x60_pci_err_driver = { | 222 | static struct platform_driver mv64x60_pci_err_driver = { |
223 | .probe = mv64x60_pci_err_probe, | 223 | .probe = mv64x60_pci_err_probe, |
224 | .remove = __devexit_p(mv64x60_pci_err_remove), | 224 | .remove = mv64x60_pci_err_remove, |
225 | .driver = { | 225 | .driver = { |
226 | .name = "mv64x60_pci_err", | 226 | .name = "mv64x60_pci_err", |
227 | } | 227 | } |
@@ -271,7 +271,7 @@ static irqreturn_t mv64x60_sram_isr(int irq, void *dev_id) | |||
271 | return IRQ_HANDLED; | 271 | return IRQ_HANDLED; |
272 | } | 272 | } |
273 | 273 | ||
274 | static int __devinit mv64x60_sram_err_probe(struct platform_device *pdev) | 274 | static int mv64x60_sram_err_probe(struct platform_device *pdev) |
275 | { | 275 | { |
276 | struct edac_device_ctl_info *edac_dev; | 276 | struct edac_device_ctl_info *edac_dev; |
277 | struct mv64x60_sram_pdata *pdata; | 277 | struct mv64x60_sram_pdata *pdata; |
@@ -439,7 +439,7 @@ static irqreturn_t mv64x60_cpu_isr(int irq, void *dev_id) | |||
439 | return IRQ_HANDLED; | 439 | return IRQ_HANDLED; |
440 | } | 440 | } |
441 | 441 | ||
442 | static int __devinit mv64x60_cpu_err_probe(struct platform_device *pdev) | 442 | static int mv64x60_cpu_err_probe(struct platform_device *pdev) |
443 | { | 443 | { |
444 | struct edac_device_ctl_info *edac_dev; | 444 | struct edac_device_ctl_info *edac_dev; |
445 | struct resource *r; | 445 | struct resource *r; |
@@ -697,7 +697,7 @@ static void mv64x60_init_csrows(struct mem_ctl_info *mci, | |||
697 | dimm->edac_mode = EDAC_SECDED; | 697 | dimm->edac_mode = EDAC_SECDED; |
698 | } | 698 | } |
699 | 699 | ||
700 | static int __devinit mv64x60_mc_err_probe(struct platform_device *pdev) | 700 | static int mv64x60_mc_err_probe(struct platform_device *pdev) |
701 | { | 701 | { |
702 | struct mem_ctl_info *mci; | 702 | struct mem_ctl_info *mci; |
703 | struct edac_mc_layer layers[2]; | 703 | struct edac_mc_layer layers[2]; |
diff --git a/drivers/edac/octeon_edac-l2c.c b/drivers/edac/octeon_edac-l2c.c index 40fde6a51ed6..7e98084d3645 100644 --- a/drivers/edac/octeon_edac-l2c.c +++ b/drivers/edac/octeon_edac-l2c.c | |||
@@ -131,7 +131,7 @@ static void octeon_l2c_poll_oct2(struct edac_device_ctl_info *l2c) | |||
131 | _octeon_l2c_poll_oct2(l2c, i); | 131 | _octeon_l2c_poll_oct2(l2c, i); |
132 | } | 132 | } |
133 | 133 | ||
134 | static int __devinit octeon_l2c_probe(struct platform_device *pdev) | 134 | static int octeon_l2c_probe(struct platform_device *pdev) |
135 | { | 135 | { |
136 | struct edac_device_ctl_info *l2c; | 136 | struct edac_device_ctl_info *l2c; |
137 | 137 | ||
diff --git a/drivers/edac/octeon_edac-lmc.c b/drivers/edac/octeon_edac-lmc.c index 33bca766e37d..93412d6b3af1 100644 --- a/drivers/edac/octeon_edac-lmc.c +++ b/drivers/edac/octeon_edac-lmc.c | |||
@@ -86,7 +86,7 @@ static void octeon_lmc_edac_poll_o2(struct mem_ctl_info *mci) | |||
86 | cvmx_write_csr(CVMX_LMCX_INT(mci->mc_idx), int_reg.u64); | 86 | cvmx_write_csr(CVMX_LMCX_INT(mci->mc_idx), int_reg.u64); |
87 | } | 87 | } |
88 | 88 | ||
89 | static int __devinit octeon_lmc_edac_probe(struct platform_device *pdev) | 89 | static int octeon_lmc_edac_probe(struct platform_device *pdev) |
90 | { | 90 | { |
91 | struct mem_ctl_info *mci; | 91 | struct mem_ctl_info *mci; |
92 | struct edac_mc_layer layers[1]; | 92 | struct edac_mc_layer layers[1]; |
diff --git a/drivers/edac/octeon_edac-pc.c b/drivers/edac/octeon_edac-pc.c index 14a5e57f2b32..0f83c33a7d1f 100644 --- a/drivers/edac/octeon_edac-pc.c +++ b/drivers/edac/octeon_edac-pc.c | |||
@@ -82,7 +82,7 @@ static int co_cache_error_event(struct notifier_block *this, | |||
82 | return NOTIFY_STOP; | 82 | return NOTIFY_STOP; |
83 | } | 83 | } |
84 | 84 | ||
85 | static int __devinit co_cache_error_probe(struct platform_device *pdev) | 85 | static int co_cache_error_probe(struct platform_device *pdev) |
86 | { | 86 | { |
87 | struct co_cache_error *p = devm_kzalloc(&pdev->dev, sizeof(*p), | 87 | struct co_cache_error *p = devm_kzalloc(&pdev->dev, sizeof(*p), |
88 | GFP_KERNEL); | 88 | GFP_KERNEL); |
diff --git a/drivers/edac/octeon_edac-pci.c b/drivers/edac/octeon_edac-pci.c index 758c1ef5fc9e..9ca73cec74e7 100644 --- a/drivers/edac/octeon_edac-pci.c +++ b/drivers/edac/octeon_edac-pci.c | |||
@@ -58,7 +58,7 @@ static void octeon_pci_poll(struct edac_pci_ctl_info *pci) | |||
58 | } | 58 | } |
59 | } | 59 | } |
60 | 60 | ||
61 | static int __devinit octeon_pci_probe(struct platform_device *pdev) | 61 | static int octeon_pci_probe(struct platform_device *pdev) |
62 | { | 62 | { |
63 | struct edac_pci_ctl_info *pci; | 63 | struct edac_pci_ctl_info *pci; |
64 | int res = 0; | 64 | int res = 0; |
diff --git a/drivers/edac/pasemi_edac.c b/drivers/edac/pasemi_edac.c index 2d35b78ada3c..9c971b575530 100644 --- a/drivers/edac/pasemi_edac.c +++ b/drivers/edac/pasemi_edac.c | |||
@@ -188,8 +188,8 @@ static int pasemi_edac_init_csrows(struct mem_ctl_info *mci, | |||
188 | return 0; | 188 | return 0; |
189 | } | 189 | } |
190 | 190 | ||
191 | static int __devinit pasemi_edac_probe(struct pci_dev *pdev, | 191 | static int pasemi_edac_probe(struct pci_dev *pdev, |
192 | const struct pci_device_id *ent) | 192 | const struct pci_device_id *ent) |
193 | { | 193 | { |
194 | struct mem_ctl_info *mci = NULL; | 194 | struct mem_ctl_info *mci = NULL; |
195 | struct edac_mc_layer layers[2]; | 195 | struct edac_mc_layer layers[2]; |
@@ -266,7 +266,7 @@ fail: | |||
266 | return -ENODEV; | 266 | return -ENODEV; |
267 | } | 267 | } |
268 | 268 | ||
269 | static void __devexit pasemi_edac_remove(struct pci_dev *pdev) | 269 | static void pasemi_edac_remove(struct pci_dev *pdev) |
270 | { | 270 | { |
271 | struct mem_ctl_info *mci = edac_mc_del_mc(&pdev->dev); | 271 | struct mem_ctl_info *mci = edac_mc_del_mc(&pdev->dev); |
272 | 272 | ||
@@ -287,7 +287,7 @@ MODULE_DEVICE_TABLE(pci, pasemi_edac_pci_tbl); | |||
287 | static struct pci_driver pasemi_edac_driver = { | 287 | static struct pci_driver pasemi_edac_driver = { |
288 | .name = MODULE_NAME, | 288 | .name = MODULE_NAME, |
289 | .probe = pasemi_edac_probe, | 289 | .probe = pasemi_edac_probe, |
290 | .remove = __devexit_p(pasemi_edac_remove), | 290 | .remove = pasemi_edac_remove, |
291 | .id_table = pasemi_edac_pci_tbl, | 291 | .id_table = pasemi_edac_pci_tbl, |
292 | }; | 292 | }; |
293 | 293 | ||
diff --git a/drivers/edac/ppc4xx_edac.c b/drivers/edac/ppc4xx_edac.c index bf0957635991..ef6b7e08f485 100644 --- a/drivers/edac/ppc4xx_edac.c +++ b/drivers/edac/ppc4xx_edac.c | |||
@@ -838,8 +838,7 @@ ppc4xx_edac_isr(int irq, void *dev_id) | |||
838 | * | 838 | * |
839 | * Returns a device type width enumeration. | 839 | * Returns a device type width enumeration. |
840 | */ | 840 | */ |
841 | static enum dev_type __devinit | 841 | static enum dev_type ppc4xx_edac_get_dtype(u32 mcopt1) |
842 | ppc4xx_edac_get_dtype(u32 mcopt1) | ||
843 | { | 842 | { |
844 | switch (mcopt1 & SDRAM_MCOPT1_WDTH_MASK) { | 843 | switch (mcopt1 & SDRAM_MCOPT1_WDTH_MASK) { |
845 | case SDRAM_MCOPT1_WDTH_16: | 844 | case SDRAM_MCOPT1_WDTH_16: |
@@ -862,8 +861,7 @@ ppc4xx_edac_get_dtype(u32 mcopt1) | |||
862 | * | 861 | * |
863 | * Returns a memory type enumeration. | 862 | * Returns a memory type enumeration. |
864 | */ | 863 | */ |
865 | static enum mem_type __devinit | 864 | static enum mem_type ppc4xx_edac_get_mtype(u32 mcopt1) |
866 | ppc4xx_edac_get_mtype(u32 mcopt1) | ||
867 | { | 865 | { |
868 | bool rden = ((mcopt1 & SDRAM_MCOPT1_RDEN_MASK) == SDRAM_MCOPT1_RDEN); | 866 | bool rden = ((mcopt1 & SDRAM_MCOPT1_RDEN_MASK) == SDRAM_MCOPT1_RDEN); |
869 | 867 | ||
@@ -893,8 +891,7 @@ ppc4xx_edac_get_mtype(u32 mcopt1) | |||
893 | * Returns 0 if OK; otherwise, -EINVAL if the memory bank size | 891 | * Returns 0 if OK; otherwise, -EINVAL if the memory bank size |
894 | * configuration cannot be determined. | 892 | * configuration cannot be determined. |
895 | */ | 893 | */ |
896 | static int __devinit | 894 | static int ppc4xx_edac_init_csrows(struct mem_ctl_info *mci, u32 mcopt1) |
897 | ppc4xx_edac_init_csrows(struct mem_ctl_info *mci, u32 mcopt1) | ||
898 | { | 895 | { |
899 | const struct ppc4xx_edac_pdata *pdata = mci->pvt_info; | 896 | const struct ppc4xx_edac_pdata *pdata = mci->pvt_info; |
900 | int status = 0; | 897 | int status = 0; |
@@ -1011,11 +1008,9 @@ ppc4xx_edac_init_csrows(struct mem_ctl_info *mci, u32 mcopt1) | |||
1011 | * | 1008 | * |
1012 | * Returns 0 if OK; otherwise, < 0 on error. | 1009 | * Returns 0 if OK; otherwise, < 0 on error. |
1013 | */ | 1010 | */ |
1014 | static int __devinit | 1011 | static int ppc4xx_edac_mc_init(struct mem_ctl_info *mci, |
1015 | ppc4xx_edac_mc_init(struct mem_ctl_info *mci, | 1012 | struct platform_device *op, |
1016 | struct platform_device *op, | 1013 | const dcr_host_t *dcr_host, u32 mcopt1) |
1017 | const dcr_host_t *dcr_host, | ||
1018 | u32 mcopt1) | ||
1019 | { | 1014 | { |
1020 | int status = 0; | 1015 | int status = 0; |
1021 | const u32 memcheck = (mcopt1 & SDRAM_MCOPT1_MCHK_MASK); | 1016 | const u32 memcheck = (mcopt1 & SDRAM_MCOPT1_MCHK_MASK); |
@@ -1105,8 +1100,8 @@ ppc4xx_edac_mc_init(struct mem_ctl_info *mci, | |||
1105 | * Returns 0 if OK; otherwise, -ENODEV if the interrupts could not be | 1100 | * Returns 0 if OK; otherwise, -ENODEV if the interrupts could not be |
1106 | * mapped and assigned. | 1101 | * mapped and assigned. |
1107 | */ | 1102 | */ |
1108 | static int __devinit | 1103 | static int ppc4xx_edac_register_irq(struct platform_device *op, |
1109 | ppc4xx_edac_register_irq(struct platform_device *op, struct mem_ctl_info *mci) | 1104 | struct mem_ctl_info *mci) |
1110 | { | 1105 | { |
1111 | int status = 0; | 1106 | int status = 0; |
1112 | int ded_irq, sec_irq; | 1107 | int ded_irq, sec_irq; |
@@ -1183,8 +1178,8 @@ ppc4xx_edac_register_irq(struct platform_device *op, struct mem_ctl_info *mci) | |||
1183 | * Returns 0 if the DCRs were successfully mapped; otherwise, < 0 on | 1178 | * Returns 0 if the DCRs were successfully mapped; otherwise, < 0 on |
1184 | * error. | 1179 | * error. |
1185 | */ | 1180 | */ |
1186 | static int __devinit | 1181 | static int ppc4xx_edac_map_dcrs(const struct device_node *np, |
1187 | ppc4xx_edac_map_dcrs(const struct device_node *np, dcr_host_t *dcr_host) | 1182 | dcr_host_t *dcr_host) |
1188 | { | 1183 | { |
1189 | unsigned int dcr_base, dcr_len; | 1184 | unsigned int dcr_base, dcr_len; |
1190 | 1185 | ||
@@ -1232,7 +1227,7 @@ ppc4xx_edac_map_dcrs(const struct device_node *np, dcr_host_t *dcr_host) | |||
1232 | * Returns 0 if the controller instance was successfully bound to the | 1227 | * Returns 0 if the controller instance was successfully bound to the |
1233 | * driver; otherwise, < 0 on error. | 1228 | * driver; otherwise, < 0 on error. |
1234 | */ | 1229 | */ |
1235 | static int __devinit ppc4xx_edac_probe(struct platform_device *op) | 1230 | static int ppc4xx_edac_probe(struct platform_device *op) |
1236 | { | 1231 | { |
1237 | int status = 0; | 1232 | int status = 0; |
1238 | u32 mcopt1, memcheck; | 1233 | u32 mcopt1, memcheck; |
diff --git a/drivers/edac/r82600_edac.c b/drivers/edac/r82600_edac.c index f854debd5533..2fd6a5490905 100644 --- a/drivers/edac/r82600_edac.c +++ b/drivers/edac/r82600_edac.c | |||
@@ -359,8 +359,8 @@ fail: | |||
359 | } | 359 | } |
360 | 360 | ||
361 | /* returns count (>= 0), or negative on error */ | 361 | /* returns count (>= 0), or negative on error */ |
362 | static int __devinit r82600_init_one(struct pci_dev *pdev, | 362 | static int r82600_init_one(struct pci_dev *pdev, |
363 | const struct pci_device_id *ent) | 363 | const struct pci_device_id *ent) |
364 | { | 364 | { |
365 | edac_dbg(0, "\n"); | 365 | edac_dbg(0, "\n"); |
366 | 366 | ||
@@ -368,7 +368,7 @@ static int __devinit r82600_init_one(struct pci_dev *pdev, | |||
368 | return r82600_probe1(pdev, ent->driver_data); | 368 | return r82600_probe1(pdev, ent->driver_data); |
369 | } | 369 | } |
370 | 370 | ||
371 | static void __devexit r82600_remove_one(struct pci_dev *pdev) | 371 | static void r82600_remove_one(struct pci_dev *pdev) |
372 | { | 372 | { |
373 | struct mem_ctl_info *mci; | 373 | struct mem_ctl_info *mci; |
374 | 374 | ||
@@ -397,7 +397,7 @@ MODULE_DEVICE_TABLE(pci, r82600_pci_tbl); | |||
397 | static struct pci_driver r82600_driver = { | 397 | static struct pci_driver r82600_driver = { |
398 | .name = EDAC_MOD_STR, | 398 | .name = EDAC_MOD_STR, |
399 | .probe = r82600_init_one, | 399 | .probe = r82600_init_one, |
400 | .remove = __devexit_p(r82600_remove_one), | 400 | .remove = r82600_remove_one, |
401 | .id_table = r82600_pci_tbl, | 401 | .id_table = r82600_pci_tbl, |
402 | }; | 402 | }; |
403 | 403 | ||
diff --git a/drivers/edac/sb_edac.c b/drivers/edac/sb_edac.c index 5715b7c2c517..da7e2986e3d5 100644 --- a/drivers/edac/sb_edac.c +++ b/drivers/edac/sb_edac.c | |||
@@ -1692,8 +1692,7 @@ fail0: | |||
1692 | * < 0 for error code | 1692 | * < 0 for error code |
1693 | */ | 1693 | */ |
1694 | 1694 | ||
1695 | static int __devinit sbridge_probe(struct pci_dev *pdev, | 1695 | static int sbridge_probe(struct pci_dev *pdev, const struct pci_device_id *id) |
1696 | const struct pci_device_id *id) | ||
1697 | { | 1696 | { |
1698 | int rc; | 1697 | int rc; |
1699 | u8 mc, num_mc = 0; | 1698 | u8 mc, num_mc = 0; |
@@ -1744,7 +1743,7 @@ fail0: | |||
1744 | * sbridge_remove destructor for one instance of device | 1743 | * sbridge_remove destructor for one instance of device |
1745 | * | 1744 | * |
1746 | */ | 1745 | */ |
1747 | static void __devexit sbridge_remove(struct pci_dev *pdev) | 1746 | static void sbridge_remove(struct pci_dev *pdev) |
1748 | { | 1747 | { |
1749 | struct sbridge_dev *sbridge_dev; | 1748 | struct sbridge_dev *sbridge_dev; |
1750 | 1749 | ||
@@ -1785,7 +1784,7 @@ MODULE_DEVICE_TABLE(pci, sbridge_pci_tbl); | |||
1785 | static struct pci_driver sbridge_driver = { | 1784 | static struct pci_driver sbridge_driver = { |
1786 | .name = "sbridge_edac", | 1785 | .name = "sbridge_edac", |
1787 | .probe = sbridge_probe, | 1786 | .probe = sbridge_probe, |
1788 | .remove = __devexit_p(sbridge_remove), | 1787 | .remove = sbridge_remove, |
1789 | .id_table = sbridge_pci_tbl, | 1788 | .id_table = sbridge_pci_tbl, |
1790 | }; | 1789 | }; |
1791 | 1790 | ||
diff --git a/drivers/edac/tile_edac.c b/drivers/edac/tile_edac.c index 1e904b7b79a0..a0820536b7d9 100644 --- a/drivers/edac/tile_edac.c +++ b/drivers/edac/tile_edac.c | |||
@@ -82,7 +82,7 @@ static void tile_edac_check(struct mem_ctl_info *mci) | |||
82 | * Initialize the 'csrows' table within the mci control structure with the | 82 | * Initialize the 'csrows' table within the mci control structure with the |
83 | * addressing of memory. | 83 | * addressing of memory. |
84 | */ | 84 | */ |
85 | static int __devinit tile_edac_init_csrows(struct mem_ctl_info *mci) | 85 | static int tile_edac_init_csrows(struct mem_ctl_info *mci) |
86 | { | 86 | { |
87 | struct csrow_info *csrow = mci->csrows[0]; | 87 | struct csrow_info *csrow = mci->csrows[0]; |
88 | struct tile_edac_priv *priv = mci->pvt_info; | 88 | struct tile_edac_priv *priv = mci->pvt_info; |
@@ -120,7 +120,7 @@ static int __devinit tile_edac_init_csrows(struct mem_ctl_info *mci) | |||
120 | return 0; | 120 | return 0; |
121 | } | 121 | } |
122 | 122 | ||
123 | static int __devinit tile_edac_mc_probe(struct platform_device *pdev) | 123 | static int tile_edac_mc_probe(struct platform_device *pdev) |
124 | { | 124 | { |
125 | char hv_file[32]; | 125 | char hv_file[32]; |
126 | int hv_devhdl; | 126 | int hv_devhdl; |
@@ -186,7 +186,7 @@ static int __devinit tile_edac_mc_probe(struct platform_device *pdev) | |||
186 | return 0; | 186 | return 0; |
187 | } | 187 | } |
188 | 188 | ||
189 | static int __devexit tile_edac_mc_remove(struct platform_device *pdev) | 189 | static int tile_edac_mc_remove(struct platform_device *pdev) |
190 | { | 190 | { |
191 | struct mem_ctl_info *mci = platform_get_drvdata(pdev); | 191 | struct mem_ctl_info *mci = platform_get_drvdata(pdev); |
192 | 192 | ||
@@ -202,7 +202,7 @@ static struct platform_driver tile_edac_mc_driver = { | |||
202 | .owner = THIS_MODULE, | 202 | .owner = THIS_MODULE, |
203 | }, | 203 | }, |
204 | .probe = tile_edac_mc_probe, | 204 | .probe = tile_edac_mc_probe, |
205 | .remove = __devexit_p(tile_edac_mc_remove), | 205 | .remove = tile_edac_mc_remove, |
206 | }; | 206 | }; |
207 | 207 | ||
208 | /* | 208 | /* |
diff --git a/drivers/edac/x38_edac.c b/drivers/edac/x38_edac.c index 08a992693e62..c9db24d95caa 100644 --- a/drivers/edac/x38_edac.c +++ b/drivers/edac/x38_edac.c | |||
@@ -418,8 +418,7 @@ fail: | |||
418 | return rc; | 418 | return rc; |
419 | } | 419 | } |
420 | 420 | ||
421 | static int __devinit x38_init_one(struct pci_dev *pdev, | 421 | static int x38_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) |
422 | const struct pci_device_id *ent) | ||
423 | { | 422 | { |
424 | int rc; | 423 | int rc; |
425 | 424 | ||
@@ -435,7 +434,7 @@ static int __devinit x38_init_one(struct pci_dev *pdev, | |||
435 | return rc; | 434 | return rc; |
436 | } | 435 | } |
437 | 436 | ||
438 | static void __devexit x38_remove_one(struct pci_dev *pdev) | 437 | static void x38_remove_one(struct pci_dev *pdev) |
439 | { | 438 | { |
440 | struct mem_ctl_info *mci; | 439 | struct mem_ctl_info *mci; |
441 | 440 | ||
@@ -464,7 +463,7 @@ MODULE_DEVICE_TABLE(pci, x38_pci_tbl); | |||
464 | static struct pci_driver x38_driver = { | 463 | static struct pci_driver x38_driver = { |
465 | .name = EDAC_MOD_STR, | 464 | .name = EDAC_MOD_STR, |
466 | .probe = x38_init_one, | 465 | .probe = x38_init_one, |
467 | .remove = __devexit_p(x38_remove_one), | 466 | .remove = x38_remove_one, |
468 | .id_table = x38_pci_tbl, | 467 | .id_table = x38_pci_tbl, |
469 | }; | 468 | }; |
470 | 469 | ||