From 27b7e82d3c68ed8d8fae9faeb047b72e0d53eb1c Mon Sep 17 00:00:00 2001 From: kettenis Date: Tue, 26 Dec 2023 09:25:15 +0000 Subject: [PATCH] Apple machines with multiple speakers typically have the shutdown pin of the digital amplifier codecs wired up to a single GPIO. This is apparently problematic for Linux and Asahi Linux changed their device trees to use a regulator instead to such that reference counting makes sure that shutdown isn't asserted until all codecs are ready for it. Follow suit, even though our regulator code doesn't do the proper reference counting yet. ok patrick@ --- sys/dev/fdt/sncodec.c | 7 +++++-- sys/dev/fdt/tascodec.c | 5 ++++- 2 files changed, 9 insertions(+), 3 deletions(-) diff --git a/sys/dev/fdt/sncodec.c b/sys/dev/fdt/sncodec.c index adbd2a88fe0..7f7efe09ff9 100644 --- a/sys/dev/fdt/sncodec.c +++ b/sys/dev/fdt/sncodec.c @@ -1,4 +1,4 @@ -/* $OpenBSD: sncodec.c,v 1.3 2023/07/09 12:32:22 kettenis Exp $ */ +/* $OpenBSD: sncodec.c,v 1.4 2023/12/26 09:25:15 kettenis Exp $ */ /* * Copyright (c) 2023 Mark Kettenis * @@ -26,6 +26,7 @@ #include #include #include +#include #include #include @@ -136,6 +137,8 @@ sncodec_attach(struct device *parent, struct device *self, void *aux) printf("\n"); + regulator_enable(OF_getpropint(node, "SDZ-supply", 0)); + sdz_gpiolen = OF_getproplen(node, "shutdown-gpios"); if (sdz_gpiolen > 0) { sdz_gpio = malloc(sdz_gpiolen, M_TEMP, M_WAITOK); @@ -146,7 +149,7 @@ sncodec_attach(struct device *parent, struct device *self, void *aux) free(sdz_gpio, M_TEMP, sdz_gpiolen); delay(1000); } - + /* Set volume to a reasonable level. */ sc->sc_dvc = DVC_LVL_30DB; sc->sc_mute = MODE_CTRL_MODE_ACTIVE; diff --git a/sys/dev/fdt/tascodec.c b/sys/dev/fdt/tascodec.c index 1c63afd3990..9769aa10693 100644 --- a/sys/dev/fdt/tascodec.c +++ b/sys/dev/fdt/tascodec.c @@ -1,4 +1,4 @@ -/* $OpenBSD: tascodec.c,v 1.7 2023/07/15 13:35:17 kettenis Exp $ */ +/* $OpenBSD: tascodec.c,v 1.8 2023/12/26 09:25:15 kettenis Exp $ */ /* * Copyright (c) 2022 Mark Kettenis * @@ -26,6 +26,7 @@ #include #include #include +#include #include #include @@ -127,6 +128,8 @@ tascodec_attach(struct device *parent, struct device *self, void *aux) printf("\n"); + regulator_enable(OF_getpropint(node, "SDZ-supply", 0)); + sdz_gpiolen = OF_getproplen(node, "shutdown-gpios"); if (sdz_gpiolen > 0) { sdz_gpio = malloc(sdz_gpiolen, M_TEMP, M_WAITOK); -- 2.20.1