WelcomeWelcome | FAQFAQ | DownloadsDownloads | WikiWiki

Author Topic: [Solved] how to detect audio playback using only alsa, without pulseaudio  (Read 11343 times)

Offline GNUser

  • Wiki Author
  • Hero Member
  • *****
  • Posts: 1533
With pulseaudio, I can use this trick to figure out if my machine is producing sound:
Code: [Select]
$ grep RUNNING /proc/asound/card*/pcm*/sub*/status
For example, with pulseaudio, I get this when a video or sound file is playing in mpv:
Code: [Select]
$ grep RUNNING /proc/asound/card*/pcm*/sub*/status
/proc/asound/card0/pcm0p/sub0/status:state: RUNNING
$

If I pause the playback in mpv, I get this (as expected):
Code: [Select]
$ grep RUNNING /proc/asound/card*/pcm*/sub*/status
$

The trick doesn't work if I ditch pulseaudio and use apulse instead: Whether mpv is playing or paused, I get this same output:
Code: [Select]
$ grep RUNNING /proc/asound/card*/pcm*/sub*/status
/proc/asound/card0/pcm0p/sub0/status:state: RUNNING
$

So with apulse, if an mpv window exists, card0's state is "RUNNING" even if playback is paused.

So my question is this: Is there a different way to detect whether the soundcard is producing sound, a way that would give me the right answer even in the setting of apulse + paused mpv?
« Last Edit: April 02, 2021, 04:06:03 PM by Rich »

Offline GNUser

  • Wiki Author
  • Hero Member
  • *****
  • Posts: 1533
how to detect audio playback using only alsa, without pulseaudio
« Reply #1 on: March 31, 2021, 03:39:25 PM »
I found this alternative:
Code: [Select]
$ fuser /dev/snd/timerThe command is supposed to succeed only if sound is playing but, unfortunately, it also succeeds when mpv is paused.

I have a hard time believing that there's no reliable/low-level way to determine whether sound card is producing sound.

P.S. I don't like the title of my thread. A better title would be "how to detect audio playback using only alsa, without pulseaudio".
« Last Edit: March 31, 2021, 04:49:33 PM by Rich »

Offline Rich

  • Administrator
  • Hero Member
  • *****
  • Posts: 11719
Re: how to detect audio playback using only alsa, without pulseaudio
« Reply #2 on: March 31, 2021, 04:51:45 PM »
Hi GNUser
... A better title would be "how to detect audio playback using only alsa, without pulseaudio".
Done. :)

Offline curaga

  • Administrator
  • Hero Member
  • *****
  • Posts: 11053
Re: how to detect audio playback using only alsa, without pulseaudio
« Reply #3 on: April 01, 2021, 02:17:39 AM »
If your card offers loopback (reading its output as an input), you could write a program to read a few samples, and if their volume is under a threshold, presume silence? Just an idea, otherwise you should ask on the alsa ML.
The only barriers that can stop you are the ones you create yourself.

Offline GNUser

  • Wiki Author
  • Hero Member
  • *****
  • Posts: 1533
Re: how to detect audio playback using only alsa, without pulseaudio
« Reply #4 on: April 01, 2021, 09:19:34 AM »
Rich,
Thanks for changing the thread title :)

curaga,
It seems the strategy would be to configure my machine to output audio simultaneously to both ALSA loopback and normal sound device (speakers/audio jack), then write a script that every few seconds records an audio sample from loopback and tests if the sample volume is below a certain low threshold. If so, presume silence.

The ALSA solution seems more complex than dealing with pulseaudio's shenanigans. Since my ultimate goal is to keep things as simple as possible, in this case it seems that loading pulseaudio is the way to go.

Offline jazzbiker

  • Hero Member
  • *****
  • Posts: 934
Re: how to detect audio playback using only alsa, without pulseaudio
« Reply #5 on: April 01, 2021, 01:57:55 PM »
Hi, GNUser!

In my system /proc/asound/card0/pcm0p/sub0/status file shows the status of playback.

Offline GNUser

  • Wiki Author
  • Hero Member
  • *****
  • Posts: 1533
Re: how to detect audio playback using only alsa, without pulseaudio
« Reply #6 on: April 01, 2021, 02:03:19 PM »
Just a quick follow-up about the observations in the initial post in this thread: ALSA was innocent. MPV is the culprit.

I recompiled mpv using the "--disable-pulse" flag. Then I rebooted my TCL box, making sure to load neither pulseaudio nor apulse. Only alsa was loaded.

I then did some tests using Brave (a web browser which, similar to chromium, does not use pulseaudio) and my recompiled mpv:

Results with Brave
When playing audio in the browser, "cat /proc/asound/card*/pcm*/sub*/status" shows "state: RUNNING". If I pause the audio in the browser, after about 5-10 seconds Brave releases the audio card because "cat /proc/asound/card*/pcm*/sub*/status" just shows "closed".

Results with MPV
When playing audio file in my recompiled mpv, "cat /proc/asound/card*/pcm*/sub*/status" shows "state: RUNNING". If I pause the audio, no matter how long I wait "cat /proc/asound/card*/pcm*/sub*/status" continues to show "state: RUNNING". So it seems that unless pulseaudio is being used, mpv does not know how to release the sound card when playback is paused.

    [EDIT]: Changed  --without-pulse  to  --disable-pulse.  Rich
« Last Edit: April 02, 2021, 12:02:59 AM by Rich »

Offline jazzbiker

  • Hero Member
  • *****
  • Posts: 934
Re: how to detect audio playback using only alsa, without pulseaudio
« Reply #7 on: April 01, 2021, 02:06:40 PM »
But there are numbers too. hw_ptr and appl_ptr. Does their behaviour changes while paused and running?

Offline GNUser

  • Wiki Author
  • Hero Member
  • *****
  • Posts: 1533
Re: how to detect audio playback using only alsa, without pulseaudio
« Reply #8 on: April 01, 2021, 02:10:20 PM »
Whether playback is paused or running, those numbers are constantly changing (seemingly randomly).

Offline jazzbiker

  • Hero Member
  • *****
  • Posts: 934
Re: how to detect audio playback using only alsa, without pulseaudio
« Reply #9 on: April 01, 2021, 02:16:32 PM »
Hmm, it means mpv continues sending zero samples... I use mplayer, in case playback is paused, it sends nothing, while keeping device owned. Seems curaga's proposal is the only possible way.
« Last Edit: April 01, 2021, 02:18:23 PM by jazzbiker »

Offline Rich

  • Administrator
  • Hero Member
  • *****
  • Posts: 11719
Re: how to detect audio playback using only alsa, without pulseaudio
« Reply #10 on: April 01, 2021, 04:52:21 PM »
Hi GNUser
I did a little experimenting and found:
Code: [Select]
/proc/asound/card0/pcm0p/sub0/infoand
Code: [Select]
/proc/asound/card0/pcm0p/infoshowed changes when playing/pausing YouTube videos.

The following lines showed this when playing:
Code: [Select]
subdevices_count: 1
subdevices_avail: 0
and this when paused:
Code: [Select]
subdevices_count: 1
subdevices_avail: 1

Offline GNUser

  • Wiki Author
  • Hero Member
  • *****
  • Posts: 1533
Re: how to detect audio playback using only alsa, without pulseaudio
« Reply #11 on: April 01, 2021, 11:47:50 PM »
Thanks for the tip, Rich. On my TCL11 x86_64 system, I loaded alsa only (no pulseaudio or apulse). Then I did some tests with mpv (compiled with  --disable-pulse  flag). When I cat the two info files you pointed out, I get this output whether mpv is playing or paused:

Code: [Select]
subdevices_count: 1
subdevices_avail: 0

So I'm still stuck. So far, I cannot find a way for a shell script to distinguish between "mpv playing" and "mpv paused" using only alsa.

P.S. In reply #6, "--without-pulse" is a mistake. I meant "--disable-pulse".


« Last Edit: April 01, 2021, 11:54:04 PM by GNUser »

Offline Rich

  • Administrator
  • Hero Member
  • *****
  • Posts: 11719
Re: how to detect audio playback using only alsa, without pulseaudio
« Reply #12 on: April 02, 2021, 12:03:55 AM »
Hi GNUser
... P.S. In reply #6, "--without-pulse" is a mistake. I meant "--disable-pulse".
Fixed. :)

Offline jazzbiker

  • Hero Member
  • *****
  • Posts: 934
Re: how to detect audio playback using only alsa, without pulseaudio
« Reply #13 on: April 02, 2021, 02:53:51 AM »
Hi, GNUser!

The matter is mpv behavior. What are mpv benefits over mplayer?
Another option is curaga's proposal - create additional alsa  device, duplicating Your sound, make short record of its output and check whether it is exceeding some limit. If this is acceptable, i can try to write .asoundrc for Your needs, I think it is not complicated, but I never wrote alsa configs.

Offline GNUser

  • Wiki Author
  • Hero Member
  • *****
  • Posts: 1533
Re: how to detect audio playback using only alsa, without pulseaudio
« Reply #14 on: April 02, 2021, 05:00:15 AM »
Rich,

mpv is what I use in my family media player. It has a pseudoGUI, which makes it easier for the wife and kids to use.

I submitted a bug report for mpv here: https://github.com/mpv-player/mpv/issues/8691

It's generous of you to offer to write the alsa config that sends output to both loopback and normal device. There is some guidance here (https://github.com/karlstav/cava#alsa-loopback-device-tricky) but I was too intimidated to try it. I'd be very happy to try what you put together. It would be rewarding to solve this using curaga's approach.