xref: /freebsd/sys/contrib/dev/broadcom/brcm80211/brcmfmac/acpi.c (revision b4c3e9b5b09c829b4135aff738bd2893ed052377)
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