mb/google/volteer/var/copano: Add fw_config probe for ALC5682-VD & VS
ALC5682-VD/ALC5682I-VS load different kernel driver by different _HID name. Update hid name depending on the AUDIO_CODEC_SOURCE field of fw_config. Define FW_CONFIG bits 41 - 43 (SSFC bits 9 - 11) for codec selection. ALC5682-VD: _HID = "10EC5682" ALC5682I-VS: _HID = "RTL5682" BUG=b:218245715 BRANCH=volteer TEST=ALC5682-VD/ALC5682I-VS audio codec can work Signed-off-by: Frank Chu <frank_chu@pegatron.corp-partner.google.com> Change-Id: I081dcf5451c82c03592f954ee25267b31ad81753 Reviewed-on: https://review.coreboot.org/c/coreboot/+/61674 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Tim Wawrzynczak <twawrzynczak@chromium.org>
This commit is contained in:
parent
7516766abc
commit
6e122455bd
|
@ -5,3 +5,5 @@ romstage-y += memory.c
|
||||||
bootblock-y += gpio.c
|
bootblock-y += gpio.c
|
||||||
|
|
||||||
ramstage-y += gpio.c
|
ramstage-y += gpio.c
|
||||||
|
|
||||||
|
ramstage-y += variant.c
|
||||||
|
|
|
@ -1,3 +1,10 @@
|
||||||
|
fw_config
|
||||||
|
field AUDIO_CODEC_SOURCE 41 43
|
||||||
|
option AUDIO_CODEC_UNPROVISIONED 0
|
||||||
|
option AUDIO_CODEC_ALC5682 1
|
||||||
|
option AUDIO_CODEC_ALC5682I_VS 2
|
||||||
|
end
|
||||||
|
end
|
||||||
chip soc/intel/tigerlake
|
chip soc/intel/tigerlake
|
||||||
# BitMask where bits [3:0] are Controller 0 Channel [3:0] and
|
# BitMask where bits [3:0] are Controller 0 Channel [3:0] and
|
||||||
# bits [7:4] are Controller 1 Channel [3:0].
|
# bits [7:4] are Controller 1 Channel [3:0].
|
||||||
|
@ -117,7 +124,7 @@ chip soc/intel/tigerlake
|
||||||
|
|
||||||
device ref i2c0 on
|
device ref i2c0 on
|
||||||
chip drivers/i2c/generic
|
chip drivers/i2c/generic
|
||||||
register "hid" = ""10EC5682""
|
# register "hid" is set in variant.c because of FW_CONFIG
|
||||||
register "name" = ""RT58""
|
register "name" = ""RT58""
|
||||||
register "desc" = ""Headset Codec""
|
register "desc" = ""Headset Codec""
|
||||||
register "irq_gpio" = "ACPI_GPIO_IRQ_EDGE_BOTH(GPP_R5)"
|
register "irq_gpio" = "ACPI_GPIO_IRQ_EDGE_BOTH(GPP_R5)"
|
||||||
|
@ -126,8 +133,7 @@ chip soc/intel/tigerlake
|
||||||
register "property_list[0].type" = "ACPI_DP_TYPE_INTEGER"
|
register "property_list[0].type" = "ACPI_DP_TYPE_INTEGER"
|
||||||
register "property_list[0].name" = ""realtek,jd-src""
|
register "property_list[0].name" = ""realtek,jd-src""
|
||||||
register "property_list[0].integer" = "1"
|
register "property_list[0].integer" = "1"
|
||||||
device i2c 1a on
|
device i2c 1a alias audio_codec on end
|
||||||
end
|
|
||||||
end
|
end
|
||||||
chip drivers/i2c/max98373
|
chip drivers/i2c/max98373
|
||||||
register "vmon_slot_no" = "0"
|
register "vmon_slot_no" = "0"
|
||||||
|
|
|
@ -0,0 +1,22 @@
|
||||||
|
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
||||||
|
|
||||||
|
#include <baseboard/variants.h>
|
||||||
|
#include <fw_config.h>
|
||||||
|
#include <drivers/i2c/hid/chip.h>
|
||||||
|
#include <device/device.h>
|
||||||
|
|
||||||
|
static void audio_codec_update(void)
|
||||||
|
{
|
||||||
|
struct device *codec = DEV_PTR(audio_codec);
|
||||||
|
struct drivers_i2c_generic_config *config;
|
||||||
|
|
||||||
|
config = codec->chip_info;
|
||||||
|
if (fw_config_probe(FW_CONFIG(AUDIO_CODEC_SOURCE, AUDIO_CODEC_ALC5682)))
|
||||||
|
config->hid = "10EC5682";
|
||||||
|
else
|
||||||
|
config->hid = "RTL5682";
|
||||||
|
}
|
||||||
|
void variant_devtree_update(void)
|
||||||
|
{
|
||||||
|
audio_codec_update();
|
||||||
|
}
|
Loading…
Reference in New Issue