提交 87b8e0c8 编写于 作者: M Mariusz Gorski 提交者: Greg Kroah-Hartman

staging: panel: Make two more module params read-only

Make keypad_type and lcd_type module params read-only.
This step also starts making it more clear what is
the precedence of device params coming from different
sources (device profile, runtime module param values etc).
Signed-off-by: NMariusz Gorski <marius.gorski@gmail.com>
Acked-by: NWilly Tarreau <w@1wt.eu>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 a8b2580b
...@@ -227,6 +227,9 @@ static struct { ...@@ -227,6 +227,9 @@ static struct {
bool enabled; bool enabled;
} lcd; } lcd;
/* Needed only for init */
static int selected_lcd_type = NOT_SET;
/* contains the LCD config state */ /* contains the LCD config state */
static unsigned long int lcd_flags; static unsigned long int lcd_flags;
/* contains the LCD X offset */ /* contains the LCD X offset */
...@@ -1415,7 +1418,7 @@ static void panel_lcd_print(const char *s) ...@@ -1415,7 +1418,7 @@ static void panel_lcd_print(const char *s)
/* initialize the LCD driver */ /* initialize the LCD driver */
static void lcd_init(void) static void lcd_init(void)
{ {
switch (lcd_type) { switch (selected_lcd_type) {
case LCD_TYPE_OLD: case LCD_TYPE_OLD:
/* parallel mode, 8 bits */ /* parallel mode, 8 bits */
if (lcd_proto == NOT_SET) if (lcd_proto == NOT_SET)
...@@ -2233,28 +2236,21 @@ static struct parport_driver panel_driver = { ...@@ -2233,28 +2236,21 @@ static struct parport_driver panel_driver = {
/* init function */ /* init function */
static int __init panel_init_module(void) static int __init panel_init_module(void)
{ {
/* for backwards compatibility */ int selected_keypad_type = NOT_SET;
if (keypad_type == NOT_SET)
keypad_type = keypad_enabled;
if (lcd_type == NOT_SET)
lcd_type = lcd_enabled;
/* take care of an eventual profile */ /* take care of an eventual profile */
switch (profile) { switch (profile) {
case PANEL_PROFILE_CUSTOM: case PANEL_PROFILE_CUSTOM:
/* custom profile */ /* custom profile */
if (keypad_type == NOT_SET) selected_keypad_type = DEFAULT_KEYPAD_TYPE;
keypad_type = DEFAULT_KEYPAD_TYPE; selected_lcd_type = DEFAULT_LCD_TYPE;
if (lcd_type == NOT_SET)
lcd_type = DEFAULT_LCD_TYPE;
break; break;
case PANEL_PROFILE_OLD: case PANEL_PROFILE_OLD:
/* 8 bits, 2*16, old keypad */ /* 8 bits, 2*16, old keypad */
if (keypad_type == NOT_SET) selected_keypad_type = KEYPAD_TYPE_OLD;
keypad_type = KEYPAD_TYPE_OLD; selected_lcd_type = LCD_TYPE_OLD;
if (lcd_type == NOT_SET)
lcd_type = LCD_TYPE_OLD; /* TODO: This two are a little hacky, sort it out later */
if (lcd_width == NOT_SET) if (lcd_width == NOT_SET)
lcd_width = 16; lcd_width = 16;
if (lcd_hwidth == NOT_SET) if (lcd_hwidth == NOT_SET)
...@@ -2262,38 +2258,45 @@ static int __init panel_init_module(void) ...@@ -2262,38 +2258,45 @@ static int __init panel_init_module(void)
break; break;
case PANEL_PROFILE_NEW: case PANEL_PROFILE_NEW:
/* serial, 2*16, new keypad */ /* serial, 2*16, new keypad */
if (keypad_type == NOT_SET) selected_keypad_type = KEYPAD_TYPE_NEW;
keypad_type = KEYPAD_TYPE_NEW; selected_lcd_type = LCD_TYPE_KS0074;
if (lcd_type == NOT_SET)
lcd_type = LCD_TYPE_KS0074;
break; break;
case PANEL_PROFILE_HANTRONIX: case PANEL_PROFILE_HANTRONIX:
/* 8 bits, 2*16 hantronix-like, no keypad */ /* 8 bits, 2*16 hantronix-like, no keypad */
if (keypad_type == NOT_SET) selected_keypad_type = KEYPAD_TYPE_NONE;
keypad_type = KEYPAD_TYPE_NONE; selected_lcd_type = LCD_TYPE_HANTRONIX;
if (lcd_type == NOT_SET)
lcd_type = LCD_TYPE_HANTRONIX;
break; break;
case PANEL_PROFILE_NEXCOM: case PANEL_PROFILE_NEXCOM:
/* generic 8 bits, 2*16, nexcom keypad, eg. Nexcom. */ /* generic 8 bits, 2*16, nexcom keypad, eg. Nexcom. */
if (keypad_type == NOT_SET) selected_keypad_type = KEYPAD_TYPE_NEXCOM;
keypad_type = KEYPAD_TYPE_NEXCOM; selected_lcd_type = LCD_TYPE_NEXCOM;
if (lcd_type == NOT_SET)
lcd_type = LCD_TYPE_NEXCOM;
break; break;
case PANEL_PROFILE_LARGE: case PANEL_PROFILE_LARGE:
/* 8 bits, 2*40, old keypad */ /* 8 bits, 2*40, old keypad */
if (keypad_type == NOT_SET) selected_keypad_type = KEYPAD_TYPE_OLD;
keypad_type = KEYPAD_TYPE_OLD; selected_lcd_type = LCD_TYPE_OLD;
if (lcd_type == NOT_SET)
lcd_type = LCD_TYPE_OLD;
break; break;
} }
lcd.enabled = (lcd_type > 0); /*
keypad.enabled = (keypad_type > 0); * Overwrite selection with module param values (both keypad and lcd),
* where the deprecated params have lower prio.
*/
if (keypad_enabled > -1)
selected_keypad_type = keypad_enabled;
if (keypad_type > -1)
selected_keypad_type = keypad_type;
keypad.enabled = (selected_keypad_type > 0);
if (lcd_enabled > -1)
selected_lcd_type = lcd_enabled;
if (lcd_type > -1)
selected_lcd_type = lcd_type;
lcd.enabled = (selected_lcd_type > 0);
switch (keypad_type) { switch (selected_keypad_type) {
case KEYPAD_TYPE_OLD: case KEYPAD_TYPE_OLD:
keypad_profile = old_keypad_profile; keypad_profile = old_keypad_profile;
break; break;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册