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