diff options
author | Andrew Morton <akpm@osdl.org> | 2006-03-26 04:37:31 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-03-26 11:56:57 -0500 |
commit | 222b9f933a76b127a073f45278d2b0199587e8ce (patch) | |
tree | f8bc703ebd08a961c95183aad52bc349b3a787d5 /drivers/char | |
parent | 3e88c17d404c5787afd5bd1763380317f5ccbf84 (diff) |
[PATCH] tlclk: fix handling of device major
tlclk calls register_chrdev() and permits register_chrdev() to allocate the
major, but it promptly forgets what that major was. So if there's no hardware
present you still get "telco_clock" appearing in /proc/devices and, I assume,
an oops reading /proc/devices if tlclk was a module.
Fix.
Mark, I'd suggest that that we not call register_chrdev() until _after_ we've
established that the hardware is present.
Cc: Mark Gross <mgross@linux.intel.com>
Cc: <stable@kernel.org>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'drivers/char')
-rw-r--r-- | drivers/char/tlclk.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/drivers/char/tlclk.c b/drivers/char/tlclk.c index 4c272189cd42..2546637a55c0 100644 --- a/drivers/char/tlclk.c +++ b/drivers/char/tlclk.c | |||
@@ -767,6 +767,7 @@ static int __init tlclk_init(void) | |||
767 | printk(KERN_ERR "tlclk: can't get major %d.\n", tlclk_major); | 767 | printk(KERN_ERR "tlclk: can't get major %d.\n", tlclk_major); |
768 | return ret; | 768 | return ret; |
769 | } | 769 | } |
770 | tlclk_major = ret; | ||
770 | alarm_events = kzalloc( sizeof(struct tlclk_alarms), GFP_KERNEL); | 771 | alarm_events = kzalloc( sizeof(struct tlclk_alarms), GFP_KERNEL); |
771 | if (!alarm_events) | 772 | if (!alarm_events) |
772 | goto out1; | 773 | goto out1; |