aboutsummaryrefslogtreecommitdiffstats
path: root/arch/um/drivers/line.c
diff options
context:
space:
mode:
authorJeff Dike <jdike@addtoit.com>2006-01-06 03:18:54 -0500
committerLinus Torvalds <torvalds@g5.osdl.org>2006-01-06 11:33:46 -0500
commit418e55d49b0ec7d2e7a033f2dd083f5b2ab7d119 (patch)
treed1e598b98955774b270b0f3f8f4a4e63815ff97e /arch/um/drivers/line.c
parent9010772cdff36072dd509ec72c1a55fccde8e58e (diff)
[PATCH] uml: line_setup interface change
line_setup is changed to return the device which it set up, rather than just success or failure. This will be important in the line-config patch. Signed-off-by: Jeff Dike <jdike@addtoit.com> Cc: Paolo 'Blaisorblade' Giarrusso <blaisorblade@yahoo.it> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'arch/um/drivers/line.c')
-rw-r--r--arch/um/drivers/line.c12
1 files changed, 9 insertions, 3 deletions
diff --git a/arch/um/drivers/line.c b/arch/um/drivers/line.c
index 1c2cc5d48bbb..1352a212964a 100644
--- a/arch/um/drivers/line.c
+++ b/arch/um/drivers/line.c
@@ -555,12 +555,13 @@ int line_setup(struct line *lines, unsigned int num, char *init)
555 } 555 }
556 } 556 }
557 } 557 }
558 return 1; 558 return n == -1 ? num : n;
559} 559}
560 560
561int line_config(struct line *lines, unsigned int num, char *str) 561int line_config(struct line *lines, unsigned int num, char *str)
562{ 562{
563 char *new; 563 char *new;
564 int n;
564 565
565 if(*str == '='){ 566 if(*str == '='){
566 printk("line_config - can't configure all devices from " 567 printk("line_config - can't configure all devices from "
@@ -573,7 +574,8 @@ int line_config(struct line *lines, unsigned int num, char *str)
573 printk("line_config - kstrdup failed\n"); 574 printk("line_config - kstrdup failed\n");
574 return -ENOMEM; 575 return -ENOMEM;
575 } 576 }
576 return !line_setup(lines, num, new); 577 n = line_setup(lines, num, new);
578 return n < 0 ? n : 0;
577} 579}
578 580
579int line_get_config(char *name, struct line *lines, unsigned int num, char *str, 581int line_get_config(char *name, struct line *lines, unsigned int num, char *str,
@@ -624,10 +626,14 @@ int line_id(char **str, int *start_out, int *end_out)
624 626
625int line_remove(struct line *lines, unsigned int num, int n) 627int line_remove(struct line *lines, unsigned int num, int n)
626{ 628{
629 int err;
627 char config[sizeof("conxxxx=none\0")]; 630 char config[sizeof("conxxxx=none\0")];
628 631
629 sprintf(config, "%d=none", n); 632 sprintf(config, "%d=none", n);
630 return !line_setup(lines, num, config); 633 err = line_setup(lines, num, config);
634 if(err >= 0)
635 err = 0;
636 return err;
631} 637}
632 638
633struct tty_driver *line_register_devfs(struct lines *set, 639struct tty_driver *line_register_devfs(struct lines *set,