2013-08-01 04:53:45 +08:00
|
|
|
#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
|
|
|
|
|
|
|
|
#include <linux/kernel.h>
|
|
|
|
#include <linux/console.h>
|
2017-03-27 04:47:36 +08:00
|
|
|
#include <linux/errno.h>
|
2013-08-01 04:53:45 +08:00
|
|
|
#include <linux/string.h>
|
|
|
|
|
|
|
|
#include "console_cmdline.h"
|
|
|
|
#include "braille.h"
|
|
|
|
|
2017-03-27 04:47:36 +08:00
|
|
|
int _braille_console_setup(char **str, char **brl_options)
|
2013-08-01 04:53:45 +08:00
|
|
|
{
|
printk: fix parsing of "brl=" option
Commit bbeddf52adc1 ("printk: move braille console support into separate
braille.[ch] files") moved the parsing of braille-related options into
_braille_console_setup(), changing the type of variable str from char*
to char**. In this commit, memcmp(str, "brl,", 4) was correctly updated
to memcmp(*str, "brl,", 4) but not memcmp(str, "brl=", 4).
Update the code to make "brl=" option work again and replace memcmp()
with strncmp() to make the compiler able to detect such an issue.
Fixes: bbeddf52adc1 ("printk: move braille console support into separate braille.[ch] files")
Link: http://lkml.kernel.org/r/20160823165700.28952-1-nicolas.iooss_linux@m4x.org
Signed-off-by: Nicolas Iooss <nicolas.iooss_linux@m4x.org>
Cc: Joe Perches <joe@perches.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2016-08-26 06:17:00 +08:00
|
|
|
if (!strncmp(*str, "brl,", 4)) {
|
2013-08-01 04:53:45 +08:00
|
|
|
*brl_options = "";
|
|
|
|
*str += 4;
|
printk: fix parsing of "brl=" option
Commit bbeddf52adc1 ("printk: move braille console support into separate
braille.[ch] files") moved the parsing of braille-related options into
_braille_console_setup(), changing the type of variable str from char*
to char**. In this commit, memcmp(str, "brl,", 4) was correctly updated
to memcmp(*str, "brl,", 4) but not memcmp(str, "brl=", 4).
Update the code to make "brl=" option work again and replace memcmp()
with strncmp() to make the compiler able to detect such an issue.
Fixes: bbeddf52adc1 ("printk: move braille console support into separate braille.[ch] files")
Link: http://lkml.kernel.org/r/20160823165700.28952-1-nicolas.iooss_linux@m4x.org
Signed-off-by: Nicolas Iooss <nicolas.iooss_linux@m4x.org>
Cc: Joe Perches <joe@perches.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2016-08-26 06:17:00 +08:00
|
|
|
} else if (!strncmp(*str, "brl=", 4)) {
|
2013-08-01 04:53:45 +08:00
|
|
|
*brl_options = *str + 4;
|
|
|
|
*str = strchr(*brl_options, ',');
|
2017-03-27 04:47:36 +08:00
|
|
|
if (!*str) {
|
2013-08-01 04:53:45 +08:00
|
|
|
pr_err("need port name after brl=\n");
|
2017-03-27 04:47:36 +08:00
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
*((*str)++) = 0;
|
|
|
|
}
|
2013-08-01 04:53:45 +08:00
|
|
|
|
2017-03-27 04:47:36 +08:00
|
|
|
return 0;
|
2013-08-01 04:53:45 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
_braille_register_console(struct console *console, struct console_cmdline *c)
|
|
|
|
{
|
|
|
|
int rtn = 0;
|
|
|
|
|
|
|
|
if (c->brl_options) {
|
|
|
|
console->flags |= CON_BRL;
|
|
|
|
rtn = braille_register_console(console, c->index, c->options,
|
|
|
|
c->brl_options);
|
|
|
|
}
|
|
|
|
|
|
|
|
return rtn;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
_braille_unregister_console(struct console *console)
|
|
|
|
{
|
|
|
|
if (console->flags & CON_BRL)
|
|
|
|
return braille_unregister_console(console);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|