aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPeter Feuerer <peter@piie.net>2009-12-21 19:20:06 -0500
committerLen Brown <len.brown@intel.com>2009-12-24 00:17:09 -0500
commitdcbfb8156a2149fd6358a377aa9400e28ef43800 (patch)
tree6ad406b1c74d29f838b655fbff71f4a2bcf3ade2
parent94219d798e65dff1dac5f8f36f03a9bdb3105f91 (diff)
drivers/platform/x86/acerhdf.c: check BIOS information whether it begins with string of table
BIOS information is now checked whether it begins with the strings stored in the BIOS table. Previous method did a strcmp, what lead to problems if BIOS information has appended whitespaces. Signed-off-by: Peter Feuerer <peter@piie.net> Cc: Borislav Petkov <petkovbb@gmail.com> Cc: Andreas Mohr <andi@lisas.de> Cc: Ingo Molnar <mingo@elte.hu> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: "H. Peter Anvin" <hpa@zytor.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Len Brown <len.brown@intel.com>
-rw-r--r--drivers/platform/x86/acerhdf.c46
1 files changed, 28 insertions, 18 deletions
diff --git a/drivers/platform/x86/acerhdf.c b/drivers/platform/x86/acerhdf.c
index a97fc4a7c60..7b2384d674d 100644
--- a/drivers/platform/x86/acerhdf.c
+++ b/drivers/platform/x86/acerhdf.c
@@ -52,7 +52,7 @@
52 */ 52 */
53#undef START_IN_KERNEL_MODE 53#undef START_IN_KERNEL_MODE
54 54
55#define DRV_VER "0.5.21" 55#define DRV_VER "0.5.22"
56 56
57/* 57/*
58 * According to the Atom N270 datasheet, 58 * According to the Atom N270 datasheet,
@@ -165,12 +165,9 @@ static const struct bios_settings_t bios_tbl[] = {
165 /* Gateway */ 165 /* Gateway */
166 {"Gateway", "AOA110", "v0.3103", 0x55, 0x58, {0x21, 0x21, 0x00} }, 166 {"Gateway", "AOA110", "v0.3103", 0x55, 0x58, {0x21, 0x21, 0x00} },
167 {"Gateway", "AOA150", "v0.3103", 0x55, 0x58, {0x20, 0x20, 0x00} }, 167 {"Gateway", "AOA150", "v0.3103", 0x55, 0x58, {0x20, 0x20, 0x00} },
168 {"Gateway ", "LT31 ", "v1.3103 ", 0x55, 0x58, 168 {"Gateway", "LT31", "v1.3103", 0x55, 0x58, {0x10, 0x0f, 0x00} },
169 {0x10, 0x0f, 0x00} }, 169 {"Gateway", "LT31", "v1.3201", 0x55, 0x58, {0x10, 0x0f, 0x00} },
170 {"Gateway ", "LT31 ", "v1.3201 ", 0x55, 0x58, 170 {"Gateway", "LT31", "v1.3302", 0x55, 0x58, {0x10, 0x0f, 0x00} },
171 {0x10, 0x0f, 0x00} },
172 {"Gateway ", "LT31 ", "v1.3302 ", 0x55, 0x58,
173 {0x10, 0x0f, 0x00} },
174 /* Packard Bell */ 171 /* Packard Bell */
175 {"Packard Bell", "DOA150", "v0.3104", 0x55, 0x58, {0x21, 0x21, 0x00} }, 172 {"Packard Bell", "DOA150", "v0.3104", 0x55, 0x58, {0x21, 0x21, 0x00} },
176 {"Packard Bell", "DOA150", "v0.3105", 0x55, 0x58, {0x20, 0x20, 0x00} }, 173 {"Packard Bell", "DOA150", "v0.3105", 0x55, 0x58, {0x20, 0x20, 0x00} },
@@ -495,13 +492,26 @@ static struct platform_driver acerhdf_driver = {
495 .remove = acerhdf_remove, 492 .remove = acerhdf_remove,
496}; 493};
497 494
495/* checks if str begins with start */
496static int str_starts_with(const char *str, const char *start)
497{
498 unsigned long str_len = 0, start_len = 0;
499
500 str_len = strlen(str);
501 start_len = strlen(start);
502
503 if (str_len >= start_len &&
504 !strncmp(str, start, start_len))
505 return 1;
506
507 return 0;
508}
498 509
499/* check hardware */ 510/* check hardware */
500static int acerhdf_check_hardware(void) 511static int acerhdf_check_hardware(void)
501{ 512{
502 char const *vendor, *version, *product; 513 char const *vendor, *version, *product;
503 int i; 514 const struct bios_settings_t *bt = NULL;
504 unsigned long prod_len = 0;
505 515
506 /* get BIOS data */ 516 /* get BIOS data */
507 vendor = dmi_get_system_info(DMI_SYS_VENDOR); 517 vendor = dmi_get_system_info(DMI_SYS_VENDOR);
@@ -523,20 +533,20 @@ static int acerhdf_check_hardware(void)
523 kernelmode = 0; 533 kernelmode = 0;
524 } 534 }
525 535
526 prod_len = strlen(product);
527
528 if (verbose) 536 if (verbose)
529 pr_info("BIOS info: %s %s, product: %s\n", 537 pr_info("BIOS info: %s %s, product: %s\n",
530 vendor, version, product); 538 vendor, version, product);
531 539
532 /* search BIOS version and vendor in BIOS settings table */ 540 /* search BIOS version and vendor in BIOS settings table */
533 for (i = 0; bios_tbl[i].version[0]; i++) { 541 for (bt = bios_tbl; bt->vendor[0]; bt++) {
534 if (strlen(bios_tbl[i].product) >= prod_len && 542 /*
535 !strncmp(bios_tbl[i].product, product, 543 * check if actual hardware BIOS vendor, product and version
536 strlen(bios_tbl[i].product)) && 544 * IDs start with the strings of BIOS table entry
537 !strcmp(bios_tbl[i].vendor, vendor) && 545 */
538 !strcmp(bios_tbl[i].version, version)) { 546 if (str_starts_with(vendor, bt->vendor) &&
539 bios_cfg = &bios_tbl[i]; 547 str_starts_with(product, bt->product) &&
548 str_starts_with(version, bt->version)) {
549 bios_cfg = bt;
540 break; 550 break;
541 } 551 }
542 } 552 }