aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/char
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/char')
-rw-r--r--drivers/char/genrtc.c48
1 files changed, 23 insertions, 25 deletions
diff --git a/drivers/char/genrtc.c b/drivers/char/genrtc.c
index 21cb980f1157..bc9b84d56ee4 100644
--- a/drivers/char/genrtc.c
+++ b/drivers/char/genrtc.c
@@ -52,6 +52,7 @@
52#include <linux/init.h> 52#include <linux/init.h>
53#include <linux/poll.h> 53#include <linux/poll.h>
54#include <linux/proc_fs.h> 54#include <linux/proc_fs.h>
55#include <linux/seq_file.h>
55#include <linux/mutex.h> 56#include <linux/mutex.h>
56#include <linux/workqueue.h> 57#include <linux/workqueue.h>
57 58
@@ -386,18 +387,15 @@ static int gen_rtc_release(struct inode *inode, struct file *file)
386 * Info exported via "/proc/driver/rtc". 387 * Info exported via "/proc/driver/rtc".
387 */ 388 */
388 389
389static int gen_rtc_proc_output(char *buf) 390static int gen_rtc_proc_show(struct seq_file *m, void *v)
390{ 391{
391 char *p;
392 struct rtc_time tm; 392 struct rtc_time tm;
393 unsigned int flags; 393 unsigned int flags;
394 struct rtc_pll_info pll; 394 struct rtc_pll_info pll;
395 395
396 p = buf;
397
398 flags = get_rtc_time(&tm); 396 flags = get_rtc_time(&tm);
399 397
400 p += sprintf(p, 398 seq_printf(m,
401 "rtc_time\t: %02d:%02d:%02d\n" 399 "rtc_time\t: %02d:%02d:%02d\n"
402 "rtc_date\t: %04d-%02d-%02d\n" 400 "rtc_date\t: %04d-%02d-%02d\n"
403 "rtc_epoch\t: %04u\n", 401 "rtc_epoch\t: %04u\n",
@@ -406,23 +404,23 @@ static int gen_rtc_proc_output(char *buf)
406 404
407 tm.tm_hour = tm.tm_min = tm.tm_sec = 0; 405 tm.tm_hour = tm.tm_min = tm.tm_sec = 0;
408 406
409 p += sprintf(p, "alarm\t\t: "); 407 seq_puts(m, "alarm\t\t: ");
410 if (tm.tm_hour <= 24) 408 if (tm.tm_hour <= 24)
411 p += sprintf(p, "%02d:", tm.tm_hour); 409 seq_printf(m, "%02d:", tm.tm_hour);
412 else 410 else
413 p += sprintf(p, "**:"); 411 seq_puts(m, "**:");
414 412
415 if (tm.tm_min <= 59) 413 if (tm.tm_min <= 59)
416 p += sprintf(p, "%02d:", tm.tm_min); 414 seq_printf(m, "%02d:", tm.tm_min);
417 else 415 else
418 p += sprintf(p, "**:"); 416 seq_puts(m, "**:");
419 417
420 if (tm.tm_sec <= 59) 418 if (tm.tm_sec <= 59)
421 p += sprintf(p, "%02d\n", tm.tm_sec); 419 seq_printf(m, "%02d\n", tm.tm_sec);
422 else 420 else
423 p += sprintf(p, "**\n"); 421 seq_puts(m, "**\n");
424 422
425 p += sprintf(p, 423 seq_printf(m,
426 "DST_enable\t: %s\n" 424 "DST_enable\t: %s\n"
427 "BCD\t\t: %s\n" 425 "BCD\t\t: %s\n"
428 "24hr\t\t: %s\n" 426 "24hr\t\t: %s\n"
@@ -442,7 +440,7 @@ static int gen_rtc_proc_output(char *buf)
442 0L /* freq */, 440 0L /* freq */,
443 (flags & RTC_BATT_BAD) ? "bad" : "okay"); 441 (flags & RTC_BATT_BAD) ? "bad" : "okay");
444 if (!get_rtc_pll(&pll)) 442 if (!get_rtc_pll(&pll))
445 p += sprintf(p, 443 seq_printf(m,
446 "PLL adjustment\t: %d\n" 444 "PLL adjustment\t: %d\n"
447 "PLL max +ve adjustment\t: %d\n" 445 "PLL max +ve adjustment\t: %d\n"
448 "PLL max -ve adjustment\t: %d\n" 446 "PLL max -ve adjustment\t: %d\n"
@@ -455,26 +453,26 @@ static int gen_rtc_proc_output(char *buf)
455 pll.pll_posmult, 453 pll.pll_posmult,
456 pll.pll_negmult, 454 pll.pll_negmult,
457 pll.pll_clock); 455 pll.pll_clock);
458 return p - buf; 456 return 0;
459} 457}
460 458
461static int gen_rtc_read_proc(char *page, char **start, off_t off, 459static int gen_rtc_proc_open(struct inode *inode, struct file *file)
462 int count, int *eof, void *data)
463{ 460{
464 int len = gen_rtc_proc_output (page); 461 return single_open(file, gen_rtc_proc_show, NULL);
465 if (len <= off+count) *eof = 1;
466 *start = page + off;
467 len -= off;
468 if (len>count) len = count;
469 if (len<0) len = 0;
470 return len;
471} 462}
472 463
464static const struct file_operations gen_rtc_proc_fops = {
465 .open = gen_rtc_proc_open,
466 .read = seq_read,
467 .llseek = seq_lseek,
468 .release = seq_release,
469};
470
473static int __init gen_rtc_proc_init(void) 471static int __init gen_rtc_proc_init(void)
474{ 472{
475 struct proc_dir_entry *r; 473 struct proc_dir_entry *r;
476 474
477 r = create_proc_read_entry("driver/rtc", 0, NULL, gen_rtc_read_proc, NULL); 475 r = proc_create("driver/rtc", 0, NULL, &gen_rtc_proc_fops);
478 if (!r) 476 if (!r)
479 return -ENOMEM; 477 return -ENOMEM;
480 return 0; 478 return 0;