Commit 37f60dd0 authored by Samuel Thibault's avatar Samuel Thibault Committed by Greg Kroah-Hartman

braille-console: Fix value returned by _braille_console_setup


[ Upstream commit 2ed2b862 ]

commit bbeddf52 ("printk: move braille console support into
separate braille.[ch] files") introduced _braille_console_setup()
to outline the braille initialization code.  There was however some
confusion over the value it was supposed to return. commit 2cfe6c4a
("printk: Fix return of braille_register_console()") tried to fix it
but failed to.

This fixes and documents the returned value according to the use
in printk.c: non-zero return means a parsing error, and thus this
console configuration should be ignored.
Signed-off-by: default avatarSamuel Thibault <samuel.thibault@ens-lyon.org>
Cc: Aleksey Makarov <aleksey.makarov@linaro.org>
Cc: Joe Perches <joe@perches.com>
Cc: Ming Lei <ming.lei@canonical.com>
Cc: Steven Rostedt <rostedt@goodmis.org>
Acked-by: default avatarPetr Mladek <pmladek@suse.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarSasha Levin <alexander.levin@microsoft.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent e4d8f491
...@@ -2,12 +2,13 @@ ...@@ -2,12 +2,13 @@
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/console.h> #include <linux/console.h>
#include <linux/errno.h>
#include <linux/string.h> #include <linux/string.h>
#include "console_cmdline.h" #include "console_cmdline.h"
#include "braille.h" #include "braille.h"
char *_braille_console_setup(char **str, char **brl_options) int _braille_console_setup(char **str, char **brl_options)
{ {
if (!strncmp(*str, "brl,", 4)) { if (!strncmp(*str, "brl,", 4)) {
*brl_options = ""; *brl_options = "";
...@@ -15,14 +16,14 @@ char *_braille_console_setup(char **str, char **brl_options) ...@@ -15,14 +16,14 @@ char *_braille_console_setup(char **str, char **brl_options)
} else if (!strncmp(*str, "brl=", 4)) { } else if (!strncmp(*str, "brl=", 4)) {
*brl_options = *str + 4; *brl_options = *str + 4;
*str = strchr(*brl_options, ','); *str = strchr(*brl_options, ',');
if (!*str) if (!*str) {
pr_err("need port name after brl=\n"); pr_err("need port name after brl=\n");
else return -EINVAL;
*((*str)++) = 0; }
} else *((*str)++) = 0;
return NULL; }
return *str; return 0;
} }
int int
......
...@@ -9,7 +9,14 @@ braille_set_options(struct console_cmdline *c, char *brl_options) ...@@ -9,7 +9,14 @@ braille_set_options(struct console_cmdline *c, char *brl_options)
c->brl_options = brl_options; c->brl_options = brl_options;
} }
char * /*
* Setup console according to braille options.
* Return -EINVAL on syntax error, 0 on success (or no braille option was
* actually given).
* Modifies str to point to the serial options
* Sets brl_options to the parsed braille options.
*/
int
_braille_console_setup(char **str, char **brl_options); _braille_console_setup(char **str, char **brl_options);
int int
...@@ -25,10 +32,10 @@ braille_set_options(struct console_cmdline *c, char *brl_options) ...@@ -25,10 +32,10 @@ braille_set_options(struct console_cmdline *c, char *brl_options)
{ {
} }
static inline char * static inline int
_braille_console_setup(char **str, char **brl_options) _braille_console_setup(char **str, char **brl_options)
{ {
return NULL; return 0;
} }
static inline int static inline int
......
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