1*b4c3e9b5SBjoern A. Zeeb // SPDX-License-Identifier: ISC
2*b4c3e9b5SBjoern A. Zeeb /*
3*b4c3e9b5SBjoern A. Zeeb * Copyright The Asahi Linux Contributors
4*b4c3e9b5SBjoern A. Zeeb */
5*b4c3e9b5SBjoern A. Zeeb
6*b4c3e9b5SBjoern A. Zeeb #include <linux/acpi.h>
7*b4c3e9b5SBjoern A. Zeeb #include "debug.h"
8*b4c3e9b5SBjoern A. Zeeb #include "core.h"
9*b4c3e9b5SBjoern A. Zeeb #include "common.h"
10*b4c3e9b5SBjoern A. Zeeb
brcmf_acpi_probe(struct device * dev,enum brcmf_bus_type bus_type,struct brcmf_mp_device * settings)11*b4c3e9b5SBjoern A. Zeeb void brcmf_acpi_probe(struct device *dev, enum brcmf_bus_type bus_type,
12*b4c3e9b5SBjoern A. Zeeb struct brcmf_mp_device *settings)
13*b4c3e9b5SBjoern A. Zeeb {
14*b4c3e9b5SBjoern A. Zeeb acpi_status status;
15*b4c3e9b5SBjoern A. Zeeb const union acpi_object *o;
16*b4c3e9b5SBjoern A. Zeeb struct acpi_buffer buf = {ACPI_ALLOCATE_BUFFER, NULL};
17*b4c3e9b5SBjoern A. Zeeb struct acpi_device *adev = ACPI_COMPANION(dev);
18*b4c3e9b5SBjoern A. Zeeb
19*b4c3e9b5SBjoern A. Zeeb if (!adev)
20*b4c3e9b5SBjoern A. Zeeb return;
21*b4c3e9b5SBjoern A. Zeeb
22*b4c3e9b5SBjoern A. Zeeb if (!ACPI_FAILURE(acpi_dev_get_property(adev, "module-instance",
23*b4c3e9b5SBjoern A. Zeeb ACPI_TYPE_STRING, &o))) {
24*b4c3e9b5SBjoern A. Zeeb brcmf_dbg(INFO, "ACPI module-instance=%s\n", o->string.pointer);
25*b4c3e9b5SBjoern A. Zeeb settings->board_type = devm_kasprintf(dev, GFP_KERNEL,
26*b4c3e9b5SBjoern A. Zeeb "apple,%s",
27*b4c3e9b5SBjoern A. Zeeb o->string.pointer);
28*b4c3e9b5SBjoern A. Zeeb } else {
29*b4c3e9b5SBjoern A. Zeeb brcmf_dbg(INFO, "No ACPI module-instance\n");
30*b4c3e9b5SBjoern A. Zeeb return;
31*b4c3e9b5SBjoern A. Zeeb }
32*b4c3e9b5SBjoern A. Zeeb
33*b4c3e9b5SBjoern A. Zeeb status = acpi_evaluate_object(adev->handle, "RWCV", NULL, &buf);
34*b4c3e9b5SBjoern A. Zeeb o = buf.pointer;
35*b4c3e9b5SBjoern A. Zeeb if (!ACPI_FAILURE(status) && o && o->type == ACPI_TYPE_BUFFER &&
36*b4c3e9b5SBjoern A. Zeeb o->buffer.length >= 2) {
37*b4c3e9b5SBjoern A. Zeeb char *antenna_sku = devm_kzalloc(dev, 3, GFP_KERNEL);
38*b4c3e9b5SBjoern A. Zeeb
39*b4c3e9b5SBjoern A. Zeeb if (antenna_sku) {
40*b4c3e9b5SBjoern A. Zeeb memcpy(antenna_sku, o->buffer.pointer, 2);
41*b4c3e9b5SBjoern A. Zeeb brcmf_dbg(INFO, "ACPI RWCV data=%*phN antenna-sku=%s\n",
42*b4c3e9b5SBjoern A. Zeeb (int)o->buffer.length, o->buffer.pointer,
43*b4c3e9b5SBjoern A. Zeeb antenna_sku);
44*b4c3e9b5SBjoern A. Zeeb settings->antenna_sku = antenna_sku;
45*b4c3e9b5SBjoern A. Zeeb }
46*b4c3e9b5SBjoern A. Zeeb
47*b4c3e9b5SBjoern A. Zeeb kfree(buf.pointer);
48*b4c3e9b5SBjoern A. Zeeb } else {
49*b4c3e9b5SBjoern A. Zeeb brcmf_dbg(INFO, "No ACPI antenna-sku\n");
50*b4c3e9b5SBjoern A. Zeeb }
51*b4c3e9b5SBjoern A. Zeeb }
52