Bug#1019148: pulseaudio: Chromebook delbin-xhvi: not detecting earphone/headset, no mic input, no headphone output

Hans-Christoph Steiner hans at eds.org
Sun Sep 4 17:43:31 BST 2022


Package: pulseaudio
Version: 15.0+dfsg1-4+b1
Severity: important

Dear Maintainer,

I installed bullseye on a Asus Chromebook Flip C536E (delbin-xhvi),
then upgraded it to Debian/testing to get more things working.  Almost
everything is working well in bookworm, there are just some audio
issues.  Sound output via the speakers works well, as does volume
control.  What does not work is:

* No sound output to headphones or headsets
* No mic input at all, both on the device mic and headset mics.
* No detection when plugging in headphones or a headset (no GNOME
   prompt).  The sound keeps playing out of the speakers.

This is a TigerLake Chromebook, so it should be maintained in upstream
Linux and ALSA, and source repos are available.  I tried the
experimental 5.19 kernel, but that didn't change anything.  This
computer seems closely related to the 'delbin' model, though not
exactly the same: Asus Chromebook Flip CX5 (delbin) vs. Asus
Chromebook Flip C536E (delbin-xhvi).  Both are "volteer" boards.

There are a whole range of "delbin" laptops that are well speced and
good candidates for solid Debian machines.

-- Package-specific info:
File '/etc/default/pulseaudio' does not exist


-- System Information:
Debian Release: bookworm/sid
   APT prefers testing
   APT policy: (500, 'testing')
Architecture: amd64 (x86_64)

Kernel: Linux 5.18.0-4-amd64 (SMP w/4 CPU threads; PREEMPT)
Locale: LANG=en_US.UTF-8, LC_CTYPE=en_US.UTF-8 (charmap=UTF-8), LANGUAGE not set
Shell: /bin/sh linked to /usr/bin/dash
Init: systemd (via /run/systemd/system)
LSM: AppArmor: enabled

Versions of packages pulseaudio depends on:
ii  adduser                         3.128
ii  init-system-helpers             1.64
ii  libasound2                      1.2.7.2-1
ii  libasound2-plugins              1.2.7.1-1
ii  libc6                           2.34-4
ii  libcap2                         1:2.44-1
ii  libdbus-1-3                     1.14.0-2
ii  libfftw3-single3                3.3.8-2
ii  libgcc-s1                       12.2.0-1
ii  libglib2.0-0                    2.72.3-1+b1
ii  libgstreamer-plugins-base1.0-0  1.20.3-2
ii  libgstreamer1.0-0               1.20.3-1
ii  libice6                         2:1.0.10-1
ii  libltdl7                        2.4.7-4
ii  liborc-0.4-0                    1:0.4.32-2
ii  libpulse0                       15.0+dfsg1-4+b1
ii  libsm6                          2:1.2.3-1
ii  libsndfile1                     1.0.31-2
ii  libsoxr0                        0.1.3-4
ii  libspeexdsp1                    1.2.0-1
ii  libstdc++6                      12.2.0-1
ii  libsystemd0                     251.3-1
ii  libtdb1                         1.4.6-3
ii  libudev1                        251.3-1
ii  libwebrtc-audio-processing1     0.3-1+b1
ii  libx11-6                        2:1.8.1-2
ii  libx11-xcb1                     2:1.8.1-2
ii  libxcb1                         1.15-1
ii  libxtst6                        2:1.2.3-1.1
ii  lsb-base                        11.2
ii  pulseaudio-utils                15.0+dfsg1-4+b1

Versions of packages pulseaudio recommends:
ii  dbus-user-session        1.14.0-2
ii  libpam-systemd [logind]  251.3-1
ii  rtkit                    0.13-4

Versions of packages pulseaudio suggests:
pn  paprefs      <none>
pn  pavucontrol  <none>
pn  pavumeter    <none>
ii  udev         251.3-1

Additional packages that might be relevant:
ii  alsa-topology-conf   	    1.2.5.1-2
ii  alsa-ucm-conf        	    1.2.7.2-1
ii  alsa-utils           	    1.2.7-1
ii  firmware-amd-graphics  	    20210818-1
ii  firmware-intel-sound   	    20210818-1
ii  firmware-iwlwifi       	    20210818-1
ii  firmware-linux-free    	    20200122-1
ii  firmware-misc-nonfree  	    20210818-1
ii  firmware-sof-signed    	    2.1.1-1
-- no debconf information

$ pactl list short sinks
0	alsa_output.pci-0000_00_1f.3-platform-tgl_mx98373_rt5682.stereo-fallback 
module-alsa-card.c	s16le 2ch 48000Hz	SUSPENDED
$ pactl list short sources
0 
alsa_output.pci-0000_00_1f.3-platform-tgl_mx98373_rt5682.stereo-fallback.monitor	module-alsa-card.c 
s16le 2ch 48000Hz	SUSPENDED
1	alsa_input.pci-0000_00_1f.3-platform-tgl_mx98373_rt5682.stereo-fallback 
module-alsa-card.c	s16le 2ch 48000Hz	SUSPENDED

# aplay -L
null
     Discard all samples (playback) or generate zero samples (capture)
lavrate
     Rate Converter Plugin Using Libav/FFmpeg Library
samplerate
     Rate Converter Plugin Using Samplerate Library
speexrate
     Rate Converter Plugin Using Speex Resampler
jack
     JACK Audio Connection Kit
oss
     Open Sound System
pulse
     PulseAudio Sound Server
speex
     Plugin using Speex DSP (resample, agc, denoise, echo, dereverb)
upmix
     Plugin for channel upmix (4,6,8)
vdownmix
     Plugin for channel downmix (stereo) with a simple spacialization
hw:CARD=sofrt5682,DEV=0
     sof-rt5682,
     Direct hardware device without any conversions
hw:CARD=sofrt5682,DEV=1
     sof-rt5682,
     Direct hardware device without any conversions
hw:CARD=sofrt5682,DEV=2
     sof-rt5682,
     Direct hardware device without any conversions
hw:CARD=sofrt5682,DEV=3
     sof-rt5682,
     Direct hardware device without any conversions
hw:CARD=sofrt5682,DEV=4
     sof-rt5682,
     Direct hardware device without any conversions
hw:CARD=sofrt5682,DEV=5
     sof-rt5682,
     Direct hardware device without any conversions
plughw:CARD=sofrt5682,DEV=0
     sof-rt5682,
     Hardware device with all software conversions
plughw:CARD=sofrt5682,DEV=1
     sof-rt5682,
     Hardware device with all software conversions
plughw:CARD=sofrt5682,DEV=2
     sof-rt5682,
     Hardware device with all software conversions
plughw:CARD=sofrt5682,DEV=3
     sof-rt5682,
     Hardware device with all software conversions
plughw:CARD=sofrt5682,DEV=4
     sof-rt5682,
     Hardware device with all software conversions
plughw:CARD=sofrt5682,DEV=5
     sof-rt5682,
     Hardware device with all software conversions
default:CARD=sofrt5682
     sof-rt5682,
     Default Audio Device
sysdefault:CARD=sofrt5682
     sof-rt5682,
     Default Audio Device
dmix:CARD=sofrt5682,DEV=0
     sof-rt5682,
     Direct sample mixing device
dmix:CARD=sofrt5682,DEV=1
     sof-rt5682,
     Direct sample mixing device
dmix:CARD=sofrt5682,DEV=2
     sof-rt5682,
     Direct sample mixing device
dmix:CARD=sofrt5682,DEV=3
     sof-rt5682,
     Direct sample mixing device
dmix:CARD=sofrt5682,DEV=4
     sof-rt5682,
     Direct sample mixing device
dmix:CARD=sofrt5682,DEV=5
     sof-rt5682,
     Direct sample mixing device
usbstream:CARD=sofrt5682
     sof-rt5682
     USB Stream Output



# cat /proc/asound/cards
  0 [sofrt5682      ]: sof-rt5682 - sof-rt5682
                       Google-Delbin-rev3
# aplay --list-devices
**** List of PLAYBACK Hardware Devices ****
card 0: sofrt5682 [sof-rt5682], device 0: smart373-spk (*) []
   Subdevices: 0/1
   Subdevice #0: subdevice #0
card 0: sofrt5682 [sof-rt5682], device 1: Headset (*) []
   Subdevices: 1/1
   Subdevice #0: subdevice #0
card 0: sofrt5682 [sof-rt5682], device 2: HDMI1 (*) []
   Subdevices: 1/1
   Subdevice #0: subdevice #0
card 0: sofrt5682 [sof-rt5682], device 3: HDMI2 (*) []
   Subdevices: 1/1
   Subdevice #0: subdevice #0
card 0: sofrt5682 [sof-rt5682], device 4: HDMI3 (*) []
   Subdevices: 1/1
   Subdevice #0: subdevice #0
card 0: sofrt5682 [sof-rt5682], device 5: HDMI4 (*) []
   Subdevices: 1/1
   Subdevice #0: subdevice #0
# lspci -v | grep -i audio
00:1f.3 Multimedia audio controller: Intel Corporation Tiger Lake-LP Smart Sound 
Technology Audio Controller (rev 20)
	DeviceName: Multimedia audio controller
	Subsystem: Intel Corporation Tiger Lake-LP Smart Sound Technology Audio Controller
	Kernel driver in use: sof-audio-pci-intel-tgl


# dmesg |grep -i -e snd -e sound -e audio -e sof
[    0.113916] ACPI: Added _OSI(Linux-Lenovo-NV-HDMI-Audio)
[    0.254968] PCI-DMA: Using software bounce buffering for IO (SWIOTLB)
[    0.254968] software IO TLB: mapped [mem 
0x0000000071a58000-0x0000000075a58000] (64MB)
[    8.693706] snd_hda_intel 0000:00:1f.3: DSP detected with PCI 
class/subclass/prog-if info 0x040100
[    8.832664] sof-audio-pci-intel-tgl 0000:00:1f.3: DSP detected with PCI 
class/subclass/prog-if info 0x040100
[    8.832908] sof-audio-pci-intel-tgl 0000:00:1f.3: DSP detected with PCI 
class/subclass/prog-if 0x040100
[    8.833019] sof-audio-pci-intel-tgl 0000:00:1f.3: bound 0000:00:02.0 (ops 
i915_audio_component_bind_ops [i915])
[    8.842553] sof-audio-pci-intel-tgl 0000:00:1f.3: use msi interrupt mode
[    8.860916] sof-audio-pci-intel-tgl 0000:00:1f.3: NHLT table not found
[    8.860922] sof-audio-pci-intel-tgl 0000:00:1f.3: NHLT table not found
[    8.860924] sof-audio-pci-intel-tgl 0000:00:1f.3: hda codecs found, mask 4
[    8.867374] sof-audio-pci-intel-tgl 0000:00:1f.3: firmware: direct-loading 
firmware intel/sof/community/sof-tgl.ri
[    8.867384] sof-audio-pci-intel-tgl 0000:00:1f.3: Firmware info: version 
2:1:1-3964a
[    8.867386] sof-audio-pci-intel-tgl 0000:00:1f.3: Firmware: ABI 3:21:0 Kernel 
ABI 3:19:1
[    8.867387] sof-audio-pci-intel-tgl 0000:00:1f.3: warn: FW ABI is more recent 
than kernel
[    8.867392] sof-audio-pci-intel-tgl 0000:00:1f.3: unknown sof_ext_man header 
type 3 size 0x30
[    8.976531] sof-audio-pci-intel-tgl 0000:00:1f.3: Firmware info: version 
2:1:1-3964a
[    8.976534] sof-audio-pci-intel-tgl 0000:00:1f.3: Firmware: ABI 3:21:0 Kernel 
ABI 3:19:1
[    8.976535] sof-audio-pci-intel-tgl 0000:00:1f.3: warn: FW ABI is more recent 
than kernel
[    9.032758] sof-audio-pci-intel-tgl 0000:00:1f.3: firmware: direct-loading 
firmware intel/sof-tplg/sof-tgl-max98373-rt5682.tplg
[    9.032771] sof-audio-pci-intel-tgl 0000:00:1f.3: Topology: ABI 3:21:0 Kernel 
ABI 3:19:1
[    9.032773] sof-audio-pci-intel-tgl 0000:00:1f.3: warn: topology ABI is more 
recent than kernel
[    9.033047] sof_rt5682 tgl_mx98373_rt5682: ASoC: Parent card not yet 
available, widget card binding deferred
[    9.107183] snd_hda_codec_hdmi ehdaudio0D2: ASoC: sink widget AIF1TX overwritten
[    9.107196] snd_hda_codec_hdmi ehdaudio0D2: ASoC: source widget AIF1RX 
overwritten
[    9.180391] input: sof-rt5682 Headset Jack as 
/devices/pci0000:00/0000:00:1f.3/tgl_mx98373_rt5682/sound/card0/input19
[    9.180480] input: sof-rt5682 HDMI/DP,pcm=2 as 
/devices/pci0000:00/0000:00:1f.3/tgl_mx98373_rt5682/sound/card0/input20
[    9.180585] input: sof-rt5682 HDMI/DP,pcm=3 as 
/devices/pci0000:00/0000:00:1f.3/tgl_mx98373_rt5682/sound/card0/input21
[    9.181121] input: sof-rt5682 HDMI/DP,pcm=4 as 
/devices/pci0000:00/0000:00:1f.3/tgl_mx98373_rt5682/sound/card0/input22
[    9.181206] input: sof-rt5682 HDMI/DP,pcm=5 as 
/devices/pci0000:00/0000:00:1f.3/tgl_mx98373_rt5682/sound/card0/input23
[ 6266.529378] (NULL device *): firmware: direct-loading firmware 
intel/sof-tplg/sof-tgl-max98373-rt5682.tplg
-------------- next part --------------
# This file is part of PulseAudio.
#
# PulseAudio is free software; you can redistribute it and/or modify
# it under the terms of the GNU Lesser General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# PulseAudio is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with PulseAudio; if not, see <http://www.gnu.org/licenses/>.

## Configuration file for PulseAudio clients. See pulse-client.conf(5) for
## more information. Default values are commented out.  Use either ; or # for
## commenting.

; default-sink =
; default-source =
; default-server =
; default-dbus-server =

; autospawn = yes
; daemon-binary = /usr/bin/pulseaudio
; extra-arguments = --log-target=syslog

; cookie-file =

; enable-shm = yes
; shm-size-bytes = 0 # setting this 0 will use the system-default, usually 64 MiB

; auto-connect-localhost = no
; auto-connect-display = no
-------------- next part --------------
# This file is part of PulseAudio.
#
# PulseAudio is free software; you can redistribute it and/or modify
# it under the terms of the GNU Lesser General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# PulseAudio is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with PulseAudio; if not, see <http://www.gnu.org/licenses/>.

## Configuration file for the PulseAudio daemon. See pulse-daemon.conf(5) for
## more information. Default values are commented out.  Use either ; or # for
## commenting.

; daemonize = no
; fail = yes
; allow-module-loading = yes
; allow-exit = yes
; use-pid-file = yes
; system-instance = no
; local-server-type = user
; enable-shm = yes
; enable-memfd = yes
; shm-size-bytes = 0 # setting this 0 will use the system-default, usually 64 MiB
; lock-memory = no
; cpu-limit = no

; high-priority = yes
; nice-level = -11

; realtime-scheduling = yes
; realtime-priority = 5

; exit-idle-time = 20
; scache-idle-time = 20

; dl-search-path = (depends on architecture)

; load-default-script-file = yes
; default-script-file = /etc/pulse/default.pa

; log-target = auto
; log-level = notice
; log-meta = no
; log-time = no
; log-backtrace = 0

; resample-method = speex-float-1
; avoid-resampling = false
; enable-remixing = yes
; remixing-use-all-sink-channels = yes
; remixing-produce-lfe = no
; remixing-consume-lfe = no
; lfe-crossover-freq = 0

; flat-volumes = no

; rescue-streams = yes

; rlimit-fsize = -1
; rlimit-data = -1
; rlimit-stack = -1
; rlimit-core = -1
; rlimit-as = -1
; rlimit-rss = -1
; rlimit-nproc = -1
; rlimit-nofile = 256
; rlimit-memlock = -1
; rlimit-locks = -1
; rlimit-sigpending = -1
; rlimit-msgqueue = -1
; rlimit-nice = 31
; rlimit-rtprio = 9
; rlimit-rttime = 200000

; default-sample-format = s16le
; default-sample-rate = 44100
; alternate-sample-rate = 48000
; default-sample-channels = 2
; default-channel-map = front-left,front-right

; default-fragments = 4
; default-fragment-size-msec = 25

; enable-deferred-volume = yes
; deferred-volume-safety-margin-usec = 8000
; deferred-volume-extra-delay-usec = 0
-------------- next part --------------
#!/usr/bin/pulseaudio -nF
#
# This file is part of PulseAudio.
#
# PulseAudio is free software; you can redistribute it and/or modify it
# under the terms of the GNU Lesser General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# PulseAudio is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with PulseAudio; if not, see <http://www.gnu.org/licenses/>.

# This startup script is used only if PulseAudio is started per-user
# (i.e. not in system mode)

.fail

### Automatically restore the volume of streams and devices
load-module module-device-restore
load-module module-stream-restore
load-module module-card-restore

### Automatically augment property information from .desktop files
### stored in /usr/share/application
load-module module-augment-properties

### Should be after module-*-restore but before module-*-detect
load-module module-switch-on-port-available

### Load audio drivers statically
### (it's probably better to not load these drivers manually, but instead
### use module-udev-detect -- see below -- for doing this automatically)
#load-module module-alsa-sink
#load-module module-alsa-source device=hw:1,0
#load-module module-oss device="/dev/dsp" sink_name=output source_name=input
#load-module module-oss-mmap device="/dev/dsp" sink_name=output source_name=input
#load-module module-null-sink
#load-module module-pipe-sink

### Automatically load driver modules depending on the hardware available
.ifexists module-udev-detect.so
load-module module-udev-detect
.else
### Use the static hardware detection module (for systems that lack udev support)
load-module module-detect
.endif

### Automatically connect sink and source if JACK server is present
.ifexists module-jackdbus-detect.so
.nofail
load-module module-jackdbus-detect channels=2
.fail
.endif

### Automatically load driver modules for Bluetooth hardware
.ifexists module-bluetooth-policy.so
load-module module-bluetooth-policy
.endif

.ifexists module-bluetooth-discover.so
load-module module-bluetooth-discover
.endif

### Load several protocols
.ifexists module-esound-protocol-unix.so
load-module module-esound-protocol-unix
.endif
load-module module-native-protocol-unix

### Network access (may be configured with paprefs, so leave this commented
### here if you plan to use paprefs)
#load-module module-esound-protocol-tcp
#load-module module-native-protocol-tcp
#load-module module-zeroconf-publish

### Load the RTP receiver module (also configured via paprefs, see above)
#load-module module-rtp-recv

### Load the RTP sender module (also configured via paprefs, see above)
#load-module module-null-sink sink_name=rtp format=s16be channels=2 rate=44100 sink_properties="device.description='RTP Multicast Sink'"
#load-module module-rtp-send source=rtp.monitor

### Load additional modules from GSettings. This can be configured with the paprefs tool.
### Please keep in mind that the modules configured by paprefs might conflict with manually
### loaded modules.
.ifexists module-gsettings.so
.nofail
load-module module-gsettings
.fail
.endif


### Automatically restore the default sink/source when changed by the user
### during runtime
### NOTE: This should be loaded as early as possible so that subsequent modules
### that look up the default sink/source get the right value
load-module module-default-device-restore

### Make sure we always have a sink around, even if it is a null sink.
load-module module-always-sink

### Honour intended role device property
load-module module-intended-roles

### Automatically suspend sinks/sources that become idle for too long
load-module module-suspend-on-idle

### If autoexit on idle is enabled we want to make sure we only quit
### when no local session needs us anymore.
.ifexists module-console-kit.so
load-module module-console-kit
.endif
.ifexists module-systemd-login.so
load-module module-systemd-login
.endif

### Enable positioned event sounds
load-module module-position-event-sounds

### Cork music/video streams when a phone stream is active
load-module module-role-cork

### Modules to allow autoloading of filters (such as echo cancellation)
### on demand. module-filter-heuristics tries to determine what filters
### make sense, and module-filter-apply does the heavy-lifting of
### loading modules and rerouting streams.
load-module module-filter-heuristics
load-module module-filter-apply

### Make some devices default
#set-default-sink output
#set-default-source input
-------------- next part --------------
#!/usr/bin/pulseaudio -nF
#
# This file is part of PulseAudio.
#
# PulseAudio is free software; you can redistribute it and/or modify it
# under the terms of the GNU Lesser General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# PulseAudio is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with PulseAudio; if not, see <http://www.gnu.org/licenses/>.

# This startup script is used only if PulseAudio is started in system
# mode.

### Automatically restore the volume of streams and devices
load-module module-device-restore
load-module module-stream-restore
load-module module-card-restore

### Automatically load driver modules depending on the hardware available
.ifexists module-udev-detect.so
load-module module-udev-detect
.else
### Use the static hardware detection module (for systems that lack udev/hal support)
load-module module-detect
.endif

### Load several protocols
.ifexists module-esound-protocol-unix.so
load-module module-esound-protocol-unix
.endif
load-module module-native-protocol-unix

### Automatically restore the default sink/source when changed by the user
### during runtime
### NOTE: This should be loaded as early as possible so that subsequent modules
### that look up the default sink/source get the right value
load-module module-default-device-restore

### Make sure we always have a sink around, even if it is a null sink.
load-module module-always-sink

### Automatically suspend sinks/sources that become idle for too long
load-module module-suspend-on-idle

### Enable positioned event sounds
load-module module-position-event-sounds


More information about the pkg-pulseaudio-devel mailing list