18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: ISC 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * Copyright 2018 Hans de Goede <hdegoede@redhat.com> 48c2ecf20Sopenharmony_ci */ 58c2ecf20Sopenharmony_ci 68c2ecf20Sopenharmony_ci#include <linux/dmi.h> 78c2ecf20Sopenharmony_ci#include <linux/mod_devicetable.h> 88c2ecf20Sopenharmony_ci#include "core.h" 98c2ecf20Sopenharmony_ci#include "common.h" 108c2ecf20Sopenharmony_ci#include "brcm_hw_ids.h" 118c2ecf20Sopenharmony_ci 128c2ecf20Sopenharmony_ci/* The DMI data never changes so we can use a static buf for this */ 138c2ecf20Sopenharmony_cistatic char dmi_board_type[128]; 148c2ecf20Sopenharmony_ci 158c2ecf20Sopenharmony_cistruct brcmf_dmi_data { 168c2ecf20Sopenharmony_ci u32 chip; 178c2ecf20Sopenharmony_ci u32 chiprev; 188c2ecf20Sopenharmony_ci const char *board_type; 198c2ecf20Sopenharmony_ci}; 208c2ecf20Sopenharmony_ci 218c2ecf20Sopenharmony_ci/* NOTE: Please keep all entries sorted alphabetically */ 228c2ecf20Sopenharmony_ci 238c2ecf20Sopenharmony_cistatic const struct brcmf_dmi_data acepc_t8_data = { 248c2ecf20Sopenharmony_ci BRCM_CC_4345_CHIP_ID, 6, "acepc-t8" 258c2ecf20Sopenharmony_ci}; 268c2ecf20Sopenharmony_ci 278c2ecf20Sopenharmony_cistatic const struct brcmf_dmi_data gpd_win_pocket_data = { 288c2ecf20Sopenharmony_ci BRCM_CC_4356_CHIP_ID, 2, "gpd-win-pocket" 298c2ecf20Sopenharmony_ci}; 308c2ecf20Sopenharmony_ci 318c2ecf20Sopenharmony_cistatic const struct brcmf_dmi_data jumper_ezpad_mini3_data = { 328c2ecf20Sopenharmony_ci BRCM_CC_43430_CHIP_ID, 0, "jumper-ezpad-mini3" 338c2ecf20Sopenharmony_ci}; 348c2ecf20Sopenharmony_ci 358c2ecf20Sopenharmony_cistatic const struct brcmf_dmi_data meegopad_t08_data = { 368c2ecf20Sopenharmony_ci BRCM_CC_43340_CHIP_ID, 2, "meegopad-t08" 378c2ecf20Sopenharmony_ci}; 388c2ecf20Sopenharmony_ci 398c2ecf20Sopenharmony_cistatic const struct brcmf_dmi_data pov_tab_p1006w_data = { 408c2ecf20Sopenharmony_ci BRCM_CC_43340_CHIP_ID, 2, "pov-tab-p1006w-data" 418c2ecf20Sopenharmony_ci}; 428c2ecf20Sopenharmony_ci 438c2ecf20Sopenharmony_cistatic const struct brcmf_dmi_data predia_basic_data = { 448c2ecf20Sopenharmony_ci BRCM_CC_43341_CHIP_ID, 2, "predia-basic" 458c2ecf20Sopenharmony_ci}; 468c2ecf20Sopenharmony_ci 478c2ecf20Sopenharmony_ci/* Note the Voyo winpad A15 tablet uses the same Ampak AP6330 module, with the 488c2ecf20Sopenharmony_ci * exact same nvram file as the Prowise-PT301 tablet. Since the nvram for the 498c2ecf20Sopenharmony_ci * Prowise-PT301 is already in linux-firmware we just point to that here. 508c2ecf20Sopenharmony_ci */ 518c2ecf20Sopenharmony_cistatic const struct brcmf_dmi_data voyo_winpad_a15_data = { 528c2ecf20Sopenharmony_ci BRCM_CC_4330_CHIP_ID, 4, "Prowise-PT301" 538c2ecf20Sopenharmony_ci}; 548c2ecf20Sopenharmony_ci 558c2ecf20Sopenharmony_cistatic const struct dmi_system_id dmi_platform_data[] = { 568c2ecf20Sopenharmony_ci { 578c2ecf20Sopenharmony_ci /* ACEPC T8 Cherry Trail Z8350 mini PC */ 588c2ecf20Sopenharmony_ci .matches = { 598c2ecf20Sopenharmony_ci DMI_EXACT_MATCH(DMI_BOARD_VENDOR, "To be filled by O.E.M."), 608c2ecf20Sopenharmony_ci DMI_EXACT_MATCH(DMI_BOARD_NAME, "Cherry Trail CR"), 618c2ecf20Sopenharmony_ci DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "T8"), 628c2ecf20Sopenharmony_ci /* also match on somewhat unique bios-version */ 638c2ecf20Sopenharmony_ci DMI_EXACT_MATCH(DMI_BIOS_VERSION, "1.000"), 648c2ecf20Sopenharmony_ci }, 658c2ecf20Sopenharmony_ci .driver_data = (void *)&acepc_t8_data, 668c2ecf20Sopenharmony_ci }, 678c2ecf20Sopenharmony_ci { 688c2ecf20Sopenharmony_ci /* ACEPC T11 Cherry Trail Z8350 mini PC, same wifi as the T8 */ 698c2ecf20Sopenharmony_ci .matches = { 708c2ecf20Sopenharmony_ci DMI_EXACT_MATCH(DMI_BOARD_VENDOR, "To be filled by O.E.M."), 718c2ecf20Sopenharmony_ci DMI_EXACT_MATCH(DMI_BOARD_NAME, "Cherry Trail CR"), 728c2ecf20Sopenharmony_ci DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "T11"), 738c2ecf20Sopenharmony_ci /* also match on somewhat unique bios-version */ 748c2ecf20Sopenharmony_ci DMI_EXACT_MATCH(DMI_BIOS_VERSION, "1.000"), 758c2ecf20Sopenharmony_ci }, 768c2ecf20Sopenharmony_ci .driver_data = (void *)&acepc_t8_data, 778c2ecf20Sopenharmony_ci }, 788c2ecf20Sopenharmony_ci { 798c2ecf20Sopenharmony_ci /* Cyberbook T116 rugged tablet */ 808c2ecf20Sopenharmony_ci .matches = { 818c2ecf20Sopenharmony_ci DMI_EXACT_MATCH(DMI_BOARD_VENDOR, "Default string"), 828c2ecf20Sopenharmony_ci DMI_EXACT_MATCH(DMI_BOARD_NAME, "Cherry Trail CR"), 838c2ecf20Sopenharmony_ci DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "20170531"), 848c2ecf20Sopenharmony_ci }, 858c2ecf20Sopenharmony_ci /* The factory image nvram file is identical to the ACEPC T8 one */ 868c2ecf20Sopenharmony_ci .driver_data = (void *)&acepc_t8_data, 878c2ecf20Sopenharmony_ci }, 888c2ecf20Sopenharmony_ci { 898c2ecf20Sopenharmony_ci /* Match for the GPDwin which unfortunately uses somewhat 908c2ecf20Sopenharmony_ci * generic dmi strings, which is why we test for 4 strings. 918c2ecf20Sopenharmony_ci * Comparing against 23 other byt/cht boards, board_vendor 928c2ecf20Sopenharmony_ci * and board_name are unique to the GPDwin, where as only one 938c2ecf20Sopenharmony_ci * other board has the same board_serial and 3 others have 948c2ecf20Sopenharmony_ci * the same default product_name. Also the GPDwin is the 958c2ecf20Sopenharmony_ci * only device to have both board_ and product_name not set. 968c2ecf20Sopenharmony_ci */ 978c2ecf20Sopenharmony_ci .matches = { 988c2ecf20Sopenharmony_ci DMI_MATCH(DMI_BOARD_VENDOR, "AMI Corporation"), 998c2ecf20Sopenharmony_ci DMI_MATCH(DMI_BOARD_NAME, "Default string"), 1008c2ecf20Sopenharmony_ci DMI_MATCH(DMI_BOARD_SERIAL, "Default string"), 1018c2ecf20Sopenharmony_ci DMI_MATCH(DMI_PRODUCT_NAME, "Default string"), 1028c2ecf20Sopenharmony_ci }, 1038c2ecf20Sopenharmony_ci .driver_data = (void *)&gpd_win_pocket_data, 1048c2ecf20Sopenharmony_ci }, 1058c2ecf20Sopenharmony_ci { 1068c2ecf20Sopenharmony_ci /* Jumper EZpad mini3 */ 1078c2ecf20Sopenharmony_ci .matches = { 1088c2ecf20Sopenharmony_ci DMI_MATCH(DMI_SYS_VENDOR, "Insyde"), 1098c2ecf20Sopenharmony_ci DMI_MATCH(DMI_PRODUCT_NAME, "CherryTrail"), 1108c2ecf20Sopenharmony_ci /* jumperx.T87.KFBNEEA02 with the version-nr dropped */ 1118c2ecf20Sopenharmony_ci DMI_MATCH(DMI_BIOS_VERSION, "jumperx.T87.KFBNEEA"), 1128c2ecf20Sopenharmony_ci }, 1138c2ecf20Sopenharmony_ci .driver_data = (void *)&jumper_ezpad_mini3_data, 1148c2ecf20Sopenharmony_ci }, 1158c2ecf20Sopenharmony_ci { 1168c2ecf20Sopenharmony_ci /* Meegopad T08 */ 1178c2ecf20Sopenharmony_ci .matches = { 1188c2ecf20Sopenharmony_ci DMI_MATCH(DMI_SYS_VENDOR, "Default string"), 1198c2ecf20Sopenharmony_ci DMI_MATCH(DMI_PRODUCT_NAME, "Default string"), 1208c2ecf20Sopenharmony_ci DMI_MATCH(DMI_BOARD_NAME, "T3 MRD"), 1218c2ecf20Sopenharmony_ci DMI_MATCH(DMI_BOARD_VERSION, "V1.1"), 1228c2ecf20Sopenharmony_ci }, 1238c2ecf20Sopenharmony_ci .driver_data = (void *)&meegopad_t08_data, 1248c2ecf20Sopenharmony_ci }, 1258c2ecf20Sopenharmony_ci { 1268c2ecf20Sopenharmony_ci /* Point of View TAB-P1006W-232 */ 1278c2ecf20Sopenharmony_ci .matches = { 1288c2ecf20Sopenharmony_ci DMI_EXACT_MATCH(DMI_SYS_VENDOR, "Insyde"), 1298c2ecf20Sopenharmony_ci DMI_EXACT_MATCH(DMI_PRODUCT_NAME, "BayTrail"), 1308c2ecf20Sopenharmony_ci /* Note 105b is Foxcon's USB/PCI vendor id */ 1318c2ecf20Sopenharmony_ci DMI_EXACT_MATCH(DMI_BOARD_VENDOR, "105B"), 1328c2ecf20Sopenharmony_ci DMI_EXACT_MATCH(DMI_BOARD_NAME, "0E57"), 1338c2ecf20Sopenharmony_ci }, 1348c2ecf20Sopenharmony_ci .driver_data = (void *)&pov_tab_p1006w_data, 1358c2ecf20Sopenharmony_ci }, 1368c2ecf20Sopenharmony_ci { 1378c2ecf20Sopenharmony_ci /* Predia Basic tablet (+ with keyboard dock) */ 1388c2ecf20Sopenharmony_ci .matches = { 1398c2ecf20Sopenharmony_ci DMI_MATCH(DMI_SYS_VENDOR, "Insyde"), 1408c2ecf20Sopenharmony_ci DMI_MATCH(DMI_PRODUCT_NAME, "CherryTrail"), 1418c2ecf20Sopenharmony_ci /* Mx.WT107.KUBNGEA02 with the version-nr dropped */ 1428c2ecf20Sopenharmony_ci DMI_MATCH(DMI_BIOS_VERSION, "Mx.WT107.KUBNGEA"), 1438c2ecf20Sopenharmony_ci }, 1448c2ecf20Sopenharmony_ci .driver_data = (void *)&predia_basic_data, 1458c2ecf20Sopenharmony_ci }, 1468c2ecf20Sopenharmony_ci { 1478c2ecf20Sopenharmony_ci /* Voyo winpad A15 tablet */ 1488c2ecf20Sopenharmony_ci .matches = { 1498c2ecf20Sopenharmony_ci DMI_MATCH(DMI_BOARD_VENDOR, "AMI Corporation"), 1508c2ecf20Sopenharmony_ci DMI_MATCH(DMI_BOARD_NAME, "Aptio CRB"), 1518c2ecf20Sopenharmony_ci /* Above strings are too generic, also match on BIOS date */ 1528c2ecf20Sopenharmony_ci DMI_MATCH(DMI_BIOS_DATE, "11/20/2014"), 1538c2ecf20Sopenharmony_ci }, 1548c2ecf20Sopenharmony_ci .driver_data = (void *)&voyo_winpad_a15_data, 1558c2ecf20Sopenharmony_ci }, 1568c2ecf20Sopenharmony_ci {} 1578c2ecf20Sopenharmony_ci}; 1588c2ecf20Sopenharmony_ci 1598c2ecf20Sopenharmony_civoid brcmf_dmi_probe(struct brcmf_mp_device *settings, u32 chip, u32 chiprev) 1608c2ecf20Sopenharmony_ci{ 1618c2ecf20Sopenharmony_ci const struct dmi_system_id *match; 1628c2ecf20Sopenharmony_ci const struct brcmf_dmi_data *data; 1638c2ecf20Sopenharmony_ci const char *sys_vendor; 1648c2ecf20Sopenharmony_ci const char *product_name; 1658c2ecf20Sopenharmony_ci 1668c2ecf20Sopenharmony_ci /* Some models have DMI strings which are too generic, e.g. 1678c2ecf20Sopenharmony_ci * "Default string", we use a quirk table for these. 1688c2ecf20Sopenharmony_ci */ 1698c2ecf20Sopenharmony_ci for (match = dmi_first_match(dmi_platform_data); 1708c2ecf20Sopenharmony_ci match; 1718c2ecf20Sopenharmony_ci match = dmi_first_match(match + 1)) { 1728c2ecf20Sopenharmony_ci data = match->driver_data; 1738c2ecf20Sopenharmony_ci 1748c2ecf20Sopenharmony_ci if (data->chip == chip && data->chiprev == chiprev) { 1758c2ecf20Sopenharmony_ci settings->board_type = data->board_type; 1768c2ecf20Sopenharmony_ci return; 1778c2ecf20Sopenharmony_ci } 1788c2ecf20Sopenharmony_ci } 1798c2ecf20Sopenharmony_ci 1808c2ecf20Sopenharmony_ci /* Not found in the quirk-table, use sys_vendor-product_name */ 1818c2ecf20Sopenharmony_ci sys_vendor = dmi_get_system_info(DMI_SYS_VENDOR); 1828c2ecf20Sopenharmony_ci product_name = dmi_get_system_info(DMI_PRODUCT_NAME); 1838c2ecf20Sopenharmony_ci if (sys_vendor && product_name) { 1848c2ecf20Sopenharmony_ci snprintf(dmi_board_type, sizeof(dmi_board_type), "%s-%s", 1858c2ecf20Sopenharmony_ci sys_vendor, product_name); 1868c2ecf20Sopenharmony_ci settings->board_type = dmi_board_type; 1878c2ecf20Sopenharmony_ci } 1888c2ecf20Sopenharmony_ci} 189