Do lcd autodetection for all models - not just the ones we have DMI matches for. Also, if we're running on an unknown model, inform the user that generic keycodes (PROG_1 up to PROG_4) will be used as opposed to specific codes like KEY_HELP. Signed-off-by: Alan Jenkins <alan-jenkins@xxxxxxxxxxxxxx> Signed-off-by: Jonathan Woithe <jwoithe@xxxxxxxxxx> --- a/drivers/platform/x86/fujitsu-laptop.c 2017-01-30 22:41:22.976106164 +1030 +++ b/drivers/platform/x86/fujitsu-laptop.c 2017-01-30 22:41:04.736105860 +1030 @@ -161,6 +161,7 @@ struct acpi_device *dev; struct input_dev *input; char phys[32]; + const char *dmi_ident; struct platform_device *pf_device; struct kfifo fifo; spinlock_t fifo_lock; @@ -615,23 +616,9 @@ } }; -static void __init dmi_check_cb_common(const struct dmi_system_id *id) -{ - pr_info("Identified laptop model '%s'\n", id->ident); - if (use_alt_lcd_levels == -1) { - if (acpi_has_method(NULL, - "\\_SB.PCI0.LPCB.FJEX.SBL2")) - use_alt_lcd_levels = 1; - else - use_alt_lcd_levels = 0; - vdbg_printk(FUJLAPTOP_DBG_TRACE, "auto-detected usealt as " - "%i\n", use_alt_lcd_levels); - } -} - static int __init dmi_check_cb_s6410(const struct dmi_system_id *id) { - dmi_check_cb_common(id); + fujitsu_laptop->dmi_ident = id->ident; fujitsu_laptop->keycode1 = KEY_SCREENLOCK; /* "Lock" */ fujitsu_laptop->keycode2 = KEY_HELP; /* "Mobility Center" */ return 1; @@ -639,7 +626,7 @@ static int __init dmi_check_cb_s6420(const struct dmi_system_id *id) { - dmi_check_cb_common(id); + fujitsu_laptop->dmi_ident = id->ident; fujitsu_laptop->keycode1 = KEY_SCREENLOCK; /* "Lock" */ fujitsu_laptop->keycode2 = KEY_HELP; /* "Mobility Center" */ return 1; @@ -647,7 +634,7 @@ static int __init dmi_check_cb_p8010(const struct dmi_system_id *id) { - dmi_check_cb_common(id); + fujitsu_laptop->dmi_ident = id->ident; fujitsu_laptop->keycode1 = KEY_HELP; /* "Support" */ fujitsu_laptop->keycode3 = KEY_SWITCHVIDEOMODE; /* "Presentation" */ fujitsu_laptop->keycode4 = KEY_WWW; /* "Internet" */ @@ -683,8 +670,8 @@ static int acpi_fujitsu_bl_add(struct acpi_device *device) { - int result = 0; int state = 0; + int result = 0; struct input_dev *input; int error; @@ -742,6 +729,16 @@ pr_err("_INI Method failed\n"); } + if (use_alt_lcd_levels == -1) { + if (acpi_has_method(NULL, + "\\_SB.PCI0.LPCB.FJEX.SBL2")) + use_alt_lcd_levels = 1; + else + use_alt_lcd_levels = 0; + vdbg_printk(FUJLAPTOP_DBG_TRACE, "auto-detected usealt as " + "%i\n", use_alt_lcd_levels); + } + /* do config (detect defaults) */ use_alt_lcd_levels = use_alt_lcd_levels == 1 ? 1 : 0; disable_brightness_adjust = disable_brightness_adjust == 1 ? 1 : 0; @@ -877,11 +874,18 @@ sprintf(acpi_device_class(device), "%s", ACPI_FUJITSU_CLASS); device->driver_data = fujitsu_laptop; - fujitsu_laptop->keycode1 = KEY_PROG1; - fujitsu_laptop->keycode2 = KEY_PROG2; - fujitsu_laptop->keycode3 = KEY_PROG3; - fujitsu_laptop->keycode4 = KEY_PROG4; - dmi_check_system(fujitsu_laptop_dmi_table); + if (dmi_check_system(fujitsu_laptop_dmi_table)) { + pr_info("Identified laptop model '%s'\n", + fujitsu_laptop->dmi_ident); + } else { + pr_info("fujitsu-laptop: Unknown laptop model" + " - using generic keycodes.\n"); + fujitsu_laptop->keycode1 = KEY1_CODE; + fujitsu_laptop->keycode2 = KEY2_CODE; + fujitsu_laptop->keycode3 = KEY3_CODE; + fujitsu_laptop->keycode4 = KEY4_CODE; + fujitsu_laptop->keycode5 = KEY5_CODE; + } /* kfifo */ spin_lock_init(&fujitsu_laptop->fifo_lock);