Commit 9cef779e authored by Jan Beulich's avatar Jan Beulich Committed by Linus Torvalds

[PATCH] RTC driver init adjustment

- conditionalizes procfs code upon CONFIG_PROC_FS (to reduce code size when
  that option is not enabled)

- make initialization no longer fail when the procfs entry can't be
  allocated (namely would initialization always have failed when
  CONFIG_PROC_FS was not set)

- move the formerly file-scope static variable rtc_int_handler_ptr into
  the only function using it, and makes it automatic.
Signed-off-by: default avatarJan Beulich <jbeulich@novell.com>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent f3e92d35
...@@ -113,7 +113,7 @@ static int rtc_has_irq = 1; ...@@ -113,7 +113,7 @@ static int rtc_has_irq = 1;
#define hpet_set_rtc_irq_bit(arg) 0 #define hpet_set_rtc_irq_bit(arg) 0
#define hpet_rtc_timer_init() do { } while (0) #define hpet_rtc_timer_init() do { } while (0)
#define hpet_rtc_dropped_irq() 0 #define hpet_rtc_dropped_irq() 0
static inline irqreturn_t hpet_rtc_interrupt(int irq, void *dev_id) {return 0;} static irqreturn_t hpet_rtc_interrupt(int irq, void *dev_id) {return 0;}
#else #else
extern irqreturn_t hpet_rtc_interrupt(int irq, void *dev_id); extern irqreturn_t hpet_rtc_interrupt(int irq, void *dev_id);
#endif #endif
...@@ -165,7 +165,9 @@ static void mask_rtc_irq_bit(unsigned char bit) ...@@ -165,7 +165,9 @@ static void mask_rtc_irq_bit(unsigned char bit)
} }
#endif #endif
#ifdef CONFIG_PROC_FS
static int rtc_proc_open(struct inode *inode, struct file *file); static int rtc_proc_open(struct inode *inode, struct file *file);
#endif
/* /*
* Bits in rtc_status. (6 bits of room for future expansion) * Bits in rtc_status. (6 bits of room for future expansion)
...@@ -906,6 +908,7 @@ static struct miscdevice rtc_dev = { ...@@ -906,6 +908,7 @@ static struct miscdevice rtc_dev = {
.fops = &rtc_fops, .fops = &rtc_fops,
}; };
#ifdef CONFIG_PROC_FS
static const struct file_operations rtc_proc_fops = { static const struct file_operations rtc_proc_fops = {
.owner = THIS_MODULE, .owner = THIS_MODULE,
.open = rtc_proc_open, .open = rtc_proc_open,
...@@ -913,14 +916,13 @@ static const struct file_operations rtc_proc_fops = { ...@@ -913,14 +916,13 @@ static const struct file_operations rtc_proc_fops = {
.llseek = seq_lseek, .llseek = seq_lseek,
.release = single_release, .release = single_release,
}; };
#if defined(RTC_IRQ) && !defined(__sparc__)
static irq_handler_t rtc_int_handler_ptr;
#endif #endif
static int __init rtc_init(void) static int __init rtc_init(void)
{ {
#ifdef CONFIG_PROC_FS
struct proc_dir_entry *ent; struct proc_dir_entry *ent;
#endif
#if defined(__alpha__) || defined(__mips__) #if defined(__alpha__) || defined(__mips__)
unsigned int year, ctrl; unsigned int year, ctrl;
char *guess = NULL; char *guess = NULL;
...@@ -932,9 +934,11 @@ static int __init rtc_init(void) ...@@ -932,9 +934,11 @@ static int __init rtc_init(void)
struct sparc_isa_bridge *isa_br; struct sparc_isa_bridge *isa_br;
struct sparc_isa_device *isa_dev; struct sparc_isa_device *isa_dev;
#endif #endif
#endif #else
#ifndef __sparc__
void *r; void *r;
#ifdef RTC_IRQ
irq_handler_t rtc_int_handler_ptr;
#endif
#endif #endif
#ifdef __sparc__ #ifdef __sparc__
...@@ -1024,17 +1028,13 @@ static int __init rtc_init(void) ...@@ -1024,17 +1028,13 @@ static int __init rtc_init(void)
return -ENODEV; return -ENODEV;
} }
#ifdef CONFIG_PROC_FS
ent = create_proc_entry("driver/rtc", 0, NULL); ent = create_proc_entry("driver/rtc", 0, NULL);
if (!ent) { if (ent)
#ifdef RTC_IRQ ent->proc_fops = &rtc_proc_fops;
free_irq(RTC_IRQ, NULL); else
rtc_has_irq = 0; printk(KERN_WARNING "rtc: Failed to register with procfs.\n");
#endif #endif
release_region(RTC_PORT(0), RTC_IO_EXTENT);
misc_deregister(&rtc_dev);
return -ENOMEM;
}
ent->proc_fops = &rtc_proc_fops;
#if defined(__alpha__) || defined(__mips__) #if defined(__alpha__) || defined(__mips__)
rtc_freq = HZ; rtc_freq = HZ;
...@@ -1167,6 +1167,7 @@ static void rtc_dropped_irq(unsigned long data) ...@@ -1167,6 +1167,7 @@ static void rtc_dropped_irq(unsigned long data)
} }
#endif #endif
#ifdef CONFIG_PROC_FS
/* /*
* Info exported via "/proc/driver/rtc". * Info exported via "/proc/driver/rtc".
*/ */
...@@ -1251,6 +1252,7 @@ static int rtc_proc_open(struct inode *inode, struct file *file) ...@@ -1251,6 +1252,7 @@ static int rtc_proc_open(struct inode *inode, struct file *file)
{ {
return single_open(file, rtc_proc_show, NULL); return single_open(file, rtc_proc_show, NULL);
} }
#endif
void rtc_get_rtc_time(struct rtc_time *rtc_tm) void rtc_get_rtc_time(struct rtc_time *rtc_tm)
{ {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment