diff options
author | Paul Gortmaker <paul.gortmaker@windriver.com> | 2016-04-22 14:07:04 -0400 |
---|---|---|
committer | Rich Felker <dalias@libc.org> | 2016-07-30 23:33:32 -0400 |
commit | e75438e2a2374771e8b116e5244eb837309ed4d9 (patch) | |
tree | 003dd8850d47bc558509ed739b02c692d59f7e31 | |
parent | f368d475871e8aafdfcffc858aad9647ced82fa2 (diff) |
sh: make heartbeat driver explicitly non-modular
The Kconfig for this driver is currently:
config HEARTBEAT
bool "Heartbeat LED"
....meaning that it currently is not being built as a module by anyone.
Lets remove the modular code that is essentially orphaned, so that
when reading the driver there is no doubt it is builtin-only.
Since module_init translates to device_initcall in the non-modular
case, the init ordering remains unchanged with this commit.
We explicitly disallow a driver unbind, since that doesn't have a
sensible use case anyway, and it allows us to drop the ".remove"
code for non-modular drivers.
We also delete the MODULE_LICENSE tag etc. since all that information
is already contained at the top of the file in the comments.
Cc: Yoshinori Sato <ysato@users.sourceforge.jp>
Cc: Rich Felker <dalias@libc.org>
Cc: linux-sh@vger.kernel.org
Signed-off-by: Paul Gortmaker <paul.gortmaker@windriver.com>
Signed-off-by: Rich Felker <dalias@libc.org>
-rw-r--r-- | arch/sh/drivers/heartbeat.c | 32 |
1 files changed, 3 insertions, 29 deletions
diff --git a/arch/sh/drivers/heartbeat.c b/arch/sh/drivers/heartbeat.c index 7efc9c354fc7..49bace446a1a 100644 --- a/arch/sh/drivers/heartbeat.c +++ b/arch/sh/drivers/heartbeat.c | |||
@@ -19,7 +19,6 @@ | |||
19 | * for more details. | 19 | * for more details. |
20 | */ | 20 | */ |
21 | #include <linux/init.h> | 21 | #include <linux/init.h> |
22 | #include <linux/module.h> | ||
23 | #include <linux/platform_device.h> | 22 | #include <linux/platform_device.h> |
24 | #include <linux/sched.h> | 23 | #include <linux/sched.h> |
25 | #include <linux/timer.h> | 24 | #include <linux/timer.h> |
@@ -139,26 +138,11 @@ static int heartbeat_drv_probe(struct platform_device *pdev) | |||
139 | return mod_timer(&hd->timer, jiffies + 1); | 138 | return mod_timer(&hd->timer, jiffies + 1); |
140 | } | 139 | } |
141 | 140 | ||
142 | static int heartbeat_drv_remove(struct platform_device *pdev) | ||
143 | { | ||
144 | struct heartbeat_data *hd = platform_get_drvdata(pdev); | ||
145 | |||
146 | del_timer_sync(&hd->timer); | ||
147 | iounmap(hd->base); | ||
148 | |||
149 | platform_set_drvdata(pdev, NULL); | ||
150 | |||
151 | if (!pdev->dev.platform_data) | ||
152 | kfree(hd); | ||
153 | |||
154 | return 0; | ||
155 | } | ||
156 | |||
157 | static struct platform_driver heartbeat_driver = { | 141 | static struct platform_driver heartbeat_driver = { |
158 | .probe = heartbeat_drv_probe, | 142 | .probe = heartbeat_drv_probe, |
159 | .remove = heartbeat_drv_remove, | ||
160 | .driver = { | 143 | .driver = { |
161 | .name = DRV_NAME, | 144 | .name = DRV_NAME, |
145 | .suppress_bind_attrs = true, | ||
162 | }, | 146 | }, |
163 | }; | 147 | }; |
164 | 148 | ||
@@ -167,14 +151,4 @@ static int __init heartbeat_init(void) | |||
167 | printk(KERN_NOTICE DRV_NAME ": version %s loaded\n", DRV_VERSION); | 151 | printk(KERN_NOTICE DRV_NAME ": version %s loaded\n", DRV_VERSION); |
168 | return platform_driver_register(&heartbeat_driver); | 152 | return platform_driver_register(&heartbeat_driver); |
169 | } | 153 | } |
170 | 154 | device_initcall(heartbeat_init); | |
171 | static void __exit heartbeat_exit(void) | ||
172 | { | ||
173 | platform_driver_unregister(&heartbeat_driver); | ||
174 | } | ||
175 | module_init(heartbeat_init); | ||
176 | module_exit(heartbeat_exit); | ||
177 | |||
178 | MODULE_VERSION(DRV_VERSION); | ||
179 | MODULE_AUTHOR("Paul Mundt"); | ||
180 | MODULE_LICENSE("GPL v2"); | ||