Snips / MPD gleichzeitige Soundausgabe

Begonnen von Che007, 13 Juni 2019, 09:26:09

Vorheriges Thema - Nächstes Thema

Che007

Hallo zusammen,

bezugnehmend auf meine Nachricht hier: https://forum.fhem.de/index.php/topic,89548.msg948407.html#msg948407 habe ich leider noch das Problem, dass Snips und MPD auf einem Satelitten nicht gleichzeitig funktionieren.

Setup:
2x Raspberry Pi
1. FHEM
2. Snips mit MPD Server für Radio

Ausgangspunkt war sobald ich per Sprachkommando das Radio gestartet habe, gab Snips seine Antwort aus, jedoch wurde das Radio gestoppt und konnte so nicht aktiviert werden.

Anbei die configs:

/etc/asound.conf
# The IPC key of dmix or dsnoop plugin must be unique
# If 555555 or 666666 is used by other processes, use another one


# use samplerate to resample as speexdsp resample is bad
defaults.pcm.rate_converter "samplerate"

pcm.!default {
    type asym
    playback.pcm "playback"
    capture.pcm "capture"
}

pcm.playback {
    type plug
    slave.pcm "Snips"
}

pcm.Snips {
    type softvol
    slave.pcm "dmixed"
    control {
        name "Snips"
        card "ALSA"
    }
}

ctl.Smips {
    type hw
    card "ALSA"
}

pcm.MPDplug {
    type plug
    slave.pcm "MPDvol"
}

pcm.MPDvol {
    type softvol
    slave.pcm "dmixed"
    control {
        name "MPDvolume"
        card "ALSA"
    }
}

ctl.MPDvol {
    type hw
    card "ALSA"
}

pcm.capture {
    type plug
    slave.pcm "array"
}

pcm.dmixed {
    type dmix
    ipc_key 555555
    ipc_perm 0666
    ipc_key_add_uid false
    slave {
    pcm "hw:ALSA"
    period_time 0
    period_size 1024
    buffer_size 8192
    }
    bindings {
        0 0
        1 1
    }
}

pcm.array {
    type dsnoop
    slave {
        pcm "hw:seeed4micvoicec"
        channels 2
    }
    ipc_key 666666
}


/etc/mpd.conf
# An example configuration file for MPD.
# Read the user manual for documentation: http://www.musicpd.org/doc/user/
# or /usr/share/doc/mpd/user-manual.html


# Files and directories #######################################################
#
# This setting controls the top directory which MPD will search to discover the
# available audio files and add them to the daemon's online database. This
# setting defaults to the XDG directory, otherwise the music directory will be
# be disabled and audio files will only be accepted over ipc socket (using
# file:// protocol) or streaming files over an accepted protocol.
#
music_directory         "/var/lib/mpd/music"
#
# This setting sets the MPD internal playlist directory. The purpose of this
# directory is storage for playlists created by MPD. The server will use
# playlist files not created by the server but only if they are in the MPD
# format. This setting defaults to playlist saving being disabled.
#
playlist_directory              "/var/lib/mpd/playlists"
#
# This setting sets the location of the MPD database. This file is used to
# load the database at server start up and store the database while the
# server is not up. This setting defaults to disabled which will allow
# MPD to accept files over ipc socket (using file:// protocol) or streaming
# files over an accepted protocol.
#
db_file                 "/var/lib/mpd/tag_cache"
#
# These settings are the locations for the daemon log files for the daemon.
# These logs are great for troubleshooting, depending on your log_level
# settings.
#
# The special value "syslog" makes MPD use the local syslog daemon. This
# setting defaults to logging to syslog, otherwise logging is disabled.
#
log_file                        "/var/log/mpd/mpd.log"
#
# This setting sets the location of the file which stores the process ID
# for use of mpd --kill and some init scripts. This setting is disabled by
# default and the pid file will not be stored.
#
pid_file                        "/run/mpd/pid"
#
# This setting sets the location of the file which contains information about
# most variables to get MPD back into the same general shape it was in before
# it was brought down. This setting is disabled by default and the server
# state will be reset on server start up.
#
state_file                      "/var/lib/mpd/state"
#
# The location of the sticker database.  This is a database which
# manages dynamic information attached to songs.
#
sticker_file                   "/var/lib/mpd/sticker.sql"
#
###############################################################################


# General music daemon options ################################################
#
# This setting specifies the user that MPD will run as. MPD should never run as
# root and you may use this setting to make MPD change its user ID after
# initialization. This setting is disabled by default and MPD is run as the
# current user.
#
user                            "mpd"
#
# This setting specifies the group that MPD will run as. If not specified
# primary group of user specified with "user" setting will be used (if set).
# This is useful if MPD needs to be a member of group such as "audio" to
# have permission to use sound card.
#
#group                          "nogroup"
#
# This setting sets the address for the daemon to listen on. Careful attention
# should be paid if this is assigned to anything other then the default, any.
# This setting can deny access to control of the daemon. Choose any if you want
# to have mpd listen on every address. Not effective if systemd socket
# activation is in use.
#
# For network
bind_to_address         "192.168.0.33"
#
# And for Unix Socket
#bind_to_address                "/run/mpd/socket"
#
# This setting is the TCP port that is desired for the daemon to get assigned
# to.
#
port                            "6600"
#
# This setting controls the type of information which is logged. Available
# setting arguments are "default", "secure" or "verbose". The "verbose" setting
# argument is recommended for troubleshooting, though can quickly stretch
# available resources on limited hardware storage.
#
#log_level                      "default"
#
# If you have a problem with your MP3s ending abruptly it is recommended that
# you set this argument to "no" to attempt to fix the problem. If this solves
# the problem, it is highly recommended to fix the MP3 files with vbrfix
# (available as vbrfix in the debian archive), at which
# point gapless MP3 playback can be enabled.
#
#gapless_mp3_playback                   "yes"
#
# Setting "restore_paused" to "yes" puts MPD into pause mode instead
# of starting playback after startup.
#
#restore_paused "no"
#
# This setting enables MPD to create playlists in a format usable by other
# music players.
#
#save_absolute_paths_in_playlists       "no"
#
# This setting defines a list of tag types that will be extracted during the
# audio file discovery process. The complete list of possible values can be
# found in the mpd.conf man page.
#metadata_to_use        "artist,album,title,track,name,genre,date,composer,performer,disc"
#
# This setting enables automatic update of MPD's database when files in
# music_directory are changed.
#
#auto_update    "yes"
#
# Limit the depth of the directories being watched, 0 means only watch
# the music directory itself.  There is no limit by default.
#
#auto_update_depth "3"
#
###############################################################################


# Symbolic link behavior ######################################################
#
# If this setting is set to "yes", MPD will discover audio files by following
# symbolic links outside of the configured music_directory.
#
#follow_outside_symlinks        "yes"
#
# If this setting is set to "yes", MPD will discover audio files by following
# symbolic links inside of the configured music_directory.
#
#follow_inside_symlinks         "yes"
#
###############################################################################


# Zeroconf / Avahi Service Discovery ##########################################
#
# If this setting is set to "yes", service information will be published with
# Zeroconf / Avahi.
#
#zeroconf_enabled               "yes"
#
# The argument to this setting will be the Zeroconf / Avahi unique name for
# this MPD server on the network.
#
#zeroconf_name                  "Music Player"
#
###############################################################################


# Permissions #################################################################
#
# If this setting is set, MPD will require password authorization. The password
# can setting can be specified multiple times for different password profiles.
#
#password                        "password@read,add,control,admin"
#
# This setting specifies the permissions a user has who has not yet logged in.
#
#default_permissions             "read,add,control,admin"
#
###############################################################################


# Database #######################################################################
#

#database {
#       plugin "proxy"
#       host "other.mpd.host"
#       port "6600"
#}

# Input #######################################################################
#

input {
        plugin "curl"
#       proxy "proxy.isp.com:8080"
#       proxy_user "user"
#       proxy_password "password"
}

#
###############################################################################

# Audio Output ################################################################
#
# MPD supports various audio output types, as well as playing through multiple
# audio outputs at the same time, through multiple audio_output settings
# blocks. Setting this block is optional, though the server will only attempt
# autodetection for one sound card.
#
# An example of an ALSA output:
#
audio_output {
        type            "alsa"
        name            "My ALSA Device"
        device          "plug:MPDplug"  # optional
        mixer_type      "software"      # optional
        mixer_device    "MPDvol"        # optional
        mixer_control   "MPDvolume"     # optional
}
#
# An example of an OSS output:
#
#audio_output {
#       type            "oss"
#       name            "My OSS Device"
#       device          "/dev/dsp"      # optional
#       mixer_type      "hardware"      # optional
#       mixer_device    "/dev/mixer"    # optional
#       mixer_control   "PCM"           # optional
#}
#
# An example of a shout output (for streaming to Icecast):
#
#audio_output {
#       type            "shout"
#       encoder         "vorbis"                # optional
#       name            "My Shout Stream"
#       host            "localhost"
#       port            "8000"
#       mount           "/mpd.ogg"
#       password        "hackme"
#       quality         "5.0"
#       bitrate         "128"
#       format          "44100:16:1"
#       protocol        "icecast2"              # optional
#       user            "source"                # optional
#       description     "My Stream Description" # optional
#       url             "http://example.com"    # optional
#       genre           "jazz"                  # optional
#       public          "no"                    # optional
#       timeout         "2"                     # optional
#       mixer_type      "software"              # optional
#}
#
# An example of a recorder output:
#
#audio_output {
#       type            "recorder"
#       name            "My recorder"
#       encoder         "vorbis"                # optional, vorbis or lame
#       path            "/var/lib/mpd/recorder/mpd.ogg"
##      quality         "5.0"                   # do not define if bitrate is defined
#       bitrate         "128"                   # do not define if quality is defined
#       format          "44100:16:1"
#}
#
# An example of a httpd output (built-in HTTP streaming server):
#
#audio_output {
#       type            "httpd"
#       name            "My HTTP Stream"
#       encoder         "vorbis"                # optional, vorbis or lame
#       port            "8000"
#       bind_to_address "0.0.0.0"               # optional, IPv4 or IPv6
#       quality         "5.0"                   # do not define if bitrate is defined
#       bitrate         "128"                   # do not define if quality is defined
#       format          "44100:16:1"
#       max_clients     "0"                     # optional 0=no limit
#}
#
# An example of a pulseaudio output (streaming to a remote pulseaudio server)
# Please see README.Debian if you want mpd to play through the pulseaudio
# daemon started as part of your graphical desktop session!
#
#audio_output {
#       type            "pulse"
#       name            "My Pulse Output"
#       server          "remote_server"         # optional
#       sink            "remote_server_sink"    # optional
#}
#
# An example of a winmm output (Windows multimedia API).
#
#audio_output {
#       type            "winmm"
#       name            "My WinMM output"
#       device          "Digital Audio (S/PDIF) (High Definition Audio Device)" # optional
#               or
#       device          "0"             # optional
#       mixer_type      "hardware"      # optional
#}
#
# An example of an openal output.
#
#audio_output {
#       type            "openal"
#       name            "My OpenAL output"
#       device          "Digital Audio (S/PDIF) (High Definition Audio Device)" # optional
#}
#
## Example "pipe" output:
#
#audio_output {
#       type            "pipe"
#       name            "my pipe"
#       command         "aplay -f cd 2>/dev/null"
## Or if you're want to use AudioCompress
#       command         "AudioCompress -m | aplay -f cd 2>/dev/null"
## Or to send raw PCM stream through PCM:
#       command         "nc example.org 8765"
#       format          "44100:16:2"
#}
#
## An example of a null output (for no audio output):
#
#audio_output {
#       type            "null"
#       name            "My Null Output"
#       mixer_type      "none"                  # optional
#}
#
# If MPD has been compiled with libsamplerate support, this setting specifies
# the sample rate converter to use.  Possible values can be found in the
# mpd.conf man page or the libsamplerate documentation. By default, this is
# setting is disabled.
#
#samplerate_converter           "Fastest Sinc Interpolator"
#
###############################################################################


# Normalization automatic volume adjustments ##################################
#
# This setting specifies the type of ReplayGain to use. This setting can have
# the argument "off", "album", "track" or "auto". "auto" is a special mode that
# chooses between "track" and "album" depending on the current state of
# random playback. If random playback is enabled then "track" mode is used.
# See <http://www.replaygain.org> for more details about ReplayGain.
# This setting is off by default.
#
#replaygain                     "album"
#
# This setting sets the pre-amp used for files that have ReplayGain tags. By
# default this setting is disabled.
#
#replaygain_preamp              "0"
#
# This setting sets the pre-amp used for files that do NOT have ReplayGain tags.
# By default this setting is disabled.
#
#replaygain_missing_preamp      "0"
#
# This setting enables or disables ReplayGain limiting.
# MPD calculates actual amplification based on the ReplayGain tags
# and replaygain_preamp / replaygain_missing_preamp setting.
# If replaygain_limit is enabled MPD will never amplify audio signal
# above its original level. If replaygain_limit is disabled such amplification
# might occur. By default this setting is enabled.
#
#replaygain_limit               "yes"
#
# This setting enables on-the-fly normalization volume adjustment. This will
# result in the volume of all playing audio to be adjusted so the output has
# equal "loudness". This setting is disabled by default.
#
#volume_normalization           "no"
#
###############################################################################


# Character Encoding ##########################################################
#
# If file or directory names do not display correctly for your locale then you
# may need to modify this setting.
#
filesystem_charset              "UTF-8"
#
# This setting controls the encoding that ID3v1 tags should be converted from.
#
id3v1_encoding                  "UTF-8"
#
###############################################################################


# SIDPlay decoder #############################################################
#
# songlength_database:
#  Location of your songlengths file, as distributed with the HVSC.
#  The sidplay plugin checks this for matching MD5 fingerprints.
#  See http://www.c64.org/HVSC/DOCUMENTS/Songlengths.faq
#
# default_songlength:
#  This is the default playing time in seconds for songs not in the
#  songlength database, or in case you're not using a database.
#  A value of 0 means play indefinitely.
#
# filter:
#  Turns the SID filter emulation on or off.
#
#decoder {
#       plugin                  "sidplay"
#       songlength_database     "/media/C64Music/DOCUMENTS/Songlengths.txt"
#       default_songlength      "120"
#       filter "true"
#}
#
###############################################################################


In diesem Bereich
audio_output {
        type            "alsa"
        name            "My ALSA Device"
        device          "plug:MPDplug"  # optional
        mixer_type      "software"      # optional
        mixer_device    "MPDvol"        # optional
        mixer_control   "MPDvolume"     # optional
}


wenn ich das device auf "plug:MPDplug" änder, habe ich nun das Problem, dass das FHEM hängenbleibt, sobald ich das Radio starte. Trage ich als Device die hardwareID ein funktioniert Radio, jedoch die Audio Ausgabe von Snips nicht.

mpd.log
ALSA lib pcm_dmix.c:1109:(snd_pcm_dmix_open) unable to open slave
Jun 13 06:30 : alsa_output: Failed to open "My ALSA Device" [alsa]: Failed to open ALSA device "plug:MPDplug": Invalid argument
Jun 13 06:30 : output: Failed to open audio output
Jun 13 06:30 : client: [9] closed
Jun 13 07:03 : player: played "http://wdr-wdr2-rheinland.icecast.wdr.de/wdr/wdr2/rheinland/mp3/128/stream.mp3?ar-distributor=ffa1"
Jun 13 07:03 : zeroconf: No global port, disabling zeroconf
Jun 13 07:03 : config: option 'mixer_device' on line 217 was not recognized
Jun 13 07:03 : config: option 'mixer_control' on line 218 was not recognized
Jun 13 07:03 : curl: curl failed:
Jun 13 07:03 : player: played "http://wdr-wdr2-rheinland.icecast.wdr.de/wdr/wdr2/rheinland/mp3/128/stream.mp3?ar-distributor=ffa1"
Jun 13 07:04 : client: [0] opened from 192.168.0.32:34060
Jun 13 07:04 : client: [1] opened from 192.168.0.32:34064
Jun 13 07:04 : client: [1] closed


Bin für jeden Rat dankbar.


CBSnake

Hi,

ich häng mich mal mit ran, ich hab ein ähnliches Problem bzw hatte da ich es aktuell quick n dirty gelöst habe, evtl gibts da ne besseren Ansatz.

Kurzüberblick:

- MPD und Snips gehen zeitgleich, Snips ist aber leiser als MPD, entweder ist das Radio viel zu laut oder Snips nicht zu verstehen
- Snips reicht seine erkannten Kommandos an Talk2fhem, dort wird dann alles (Snips und Telegram) ausgewertet und verarbeitet
- Ablauf:

z.B. Radio läuft

Kommando Hey Snips, über DOIF wird dann das Radio gestoppt und die Lautstärke am Snips PI erhöht um Snips zu verstehen, nach 15 sekunden Lautstärke wieder runter, nach 20 sekunden Radio wieder an - klappt ganz gut unschön ist nur folgendes:

Anschalten des Radio über Snips:

- Hey Snips....Radio an
- Radio beginnt kurz, Snips will aber das Commando bestätigen ;-)
- Radio stoppt
- Snips bestätigt
- 20 sekunden später Radio läuft wieder an


Hier mal die asound.conf

pcm.!default {
  type asym
  playback.pcm {
    type plug
    slave.pcm "hw:0,0"
  }
  capture.pcm {
    type plug
    slave.pcm "hw:1,0"
  }
}


und hier der Bereich aus mpd.conf

audio_output {
        type            "alsa"
        name            "My ALSA Device"
#       device          "hw:0,0"        # optional
#       mixer_type      "hardware"      # optional
#       mixer_device    "default"       # optional
#       mixer_control   "PCM"           # optional
#       mixer_index     "0"             # optional


Grüße
Achim
FHEM auf Debian 10, HM-Wlan, JeeLink-Wlan, Wlanduino, ConBee, TP-Link Steckdose, GHoma Steckdosen, Shelly Steckdosen

Wernieman

#2
Eine Hardware (wie z.B. Soundcarte) kann nur von einem Programm exklusiv genutzt werden. Ihr müste also von der direkten Ansteuerung weg und über einen Sounddeamon gehen (wie z.B. PulseAudio).

Da ich Snips nicht kenne, kann ich dort keine Hilfe geben. MPD läuft bei mir über PulseAudio
- Bitte um Input für Output
- When there is a Shell, there is a Way
- Wann war Dein letztes Backup?

Wie man Fragen stellt: https://tty1.net/smart-questions_de.html

Che007

Mit dem Software ALSA Mixer komme ich nicht wirklich weiter.
Hast du freundlicherweise die configs für Pulseaudio und mpd?

Wernieman

Ich lasse pulseaudio über den mpd user laufen .. wie ich das eingerichtet habe, ist eine guuuuute Frage ...

in mpd selber:
audio_output {
        type            "pulse"
        name            "My Pulse Output"
#       server          "localhost"             # optional
#       sink            "remote_server_sink"    # optional
        mixer_type      "software"
}


Bei mir brauchte ich den Schalter mixer_type wegen der Hardware, besser wäre es, wenn es ohne geht.
- Bitte um Input für Output
- When there is a Shell, there is a Way
- Wann war Dein letztes Backup?

Wie man Fragen stellt: https://tty1.net/smart-questions_de.html

Che007

Vermutlich liegt mein Problem auch daran, dass ich damals für den Snips den folgenden Eintrag in der Datei sudo nano /etc/systemd/system/multi-user.target.wants/snips-audio-server.service
machen musste um den u.a. Fehler zu beheben.
Eintrag:
[Service]
Environment="PA_ALSA_PLUGHW=1"

Ansonsten hatte ich bei der Audio Ausgabe von Snips diese Fehler:
Jun 13 11:11:04 jarvis snips-audio-server[649]: INFO:snips_audio_portaudio      : Playing "c15da6c8-1ebe-4fbe-9d54-135d49fdc97f" using output "default", wav spec: WavSpec { channels: 1, sample_rate: 16000, bits_per_sample: 16, sample_format: Int }
Jun 13 11:11:04 jarvis snips-audio-server[649]: ALSA lib pcm_dmix.c:1109:(snd_pcm_dmix_open) unable to open slave
Jun 13 11:11:04 jarvis snips-audio-server[649]: Expression 'ret' failed in 'src/hostapi/alsa/pa_linux_alsa.c', line: 1735
Jun 13 11:11:04 jarvis snips-audio-server[649]: Expression 'AlsaOpen( &alsaApi->baseHostApiRep, params, streamDir, &self->pcm )' failed in 'src/hostapi/alsa/pa_linux_alsa.c', line: 1902
Jun 13 11:11:04 jarvis snips-audio-server[649]: Expression 'PaAlsaStreamComponent_Initialize( &self->playback, alsaApi, outParams, StreamDirection_Out, NULL != callback )' failed in 'src/hostapi/alsa/pa_linux_alsa.c', line: 2170
Jun 13 11:11:04 jarvis snips-audio-server[649]: Expression 'PaAlsaStream_Initialize( stream, alsaHostApi, inputParameters, outputParameters, sampleRate, framesPerBuffer, callback, streamFlags, userData )' failed in 'src/hostapi/alsa/pa_linux_alsa.c', line: 2835
Jun 13 11:11:04 jarvis snips-audio-server[649]: thread 'portaudio.player' panicked at 'called `Result::unwrap()` on an `Err` value: "SendError(..)"', src/libcore/result.rs:997:5
Jun 13 11:11:04 jarvis snips-audio-server[649]: ERROR:snips_audio_server_hermes  : could not play "c15da6c8-1ebe-4fbe-9d54-135d49fdc97f"
Jun 13 11:11:04 jarvis snips-audio-server[649]:  -> caused by: BadIODeviceCombination
Jun 13 11:11:49 jarvis systemd[1]: Started Music Player Daemon.

Wernieman

Portaudio ist auch ein Sounddeamon .. ich weiß aber nicht, wie mpd dazu überredet wird, mit portaudio zu laufen ...
- Bitte um Input für Output
- When there is a Shell, there is a Way
- Wann war Dein letztes Backup?

Wie man Fragen stellt: https://tty1.net/smart-questions_de.html

Che007

Scheint wohl nur mit externen Lautsprechern zu funktionieren und nicht  mehr der analogen Klinke.
https://forum.snips.ai/t/microphone-for-room-with-music/614/61


JensS

ALSA kann verschiedene Quellen gleichzeitig abspielen. Dazu gibt es dmix, was die Signale zusammenführt und auf der definierten Soundkarte ausgibt. Man darf die Karte nur nicht direkt aus den Programmen ansprechen. Dann blockiert sich alles gegenseitig.
Die Configs habe ich bei mir erfolgreich im Einsatz. https://forum.fhem.de/index.php/topic,89548.msg945876.html#msg945876
Snips scheint generell "playback" als Ausgang und "capture" als Eingang zu verwenden.
Beim Raspi von Che007 sind nur die Bezeichnungen anders. Für "ALSA" kann man in der asound.conf auch "hw:0,0" schreiben.
Man möge mich berichtigen, sollte ich mich irren.

Gruß Jens
Debian auf APU2C4, HM-CFG-USB2, SIGNALduino, HM-ES-PMSw1-Pl, TFA 30.3121, TFA 30.3125, ITS-150, PIR-5000, configurable Firmata USB & LAN, 1-wire: DS-18B20, DS-18S20, DS-2408, DS-2413, diverse I2C-Komponenten, zigbee2mqtt, ESPEasy etc.

Che007

#9
Am Ende des Monats kommt mein USB China Lautsprecher dann werde ich es noch einmal probieren. Denke auch, dass es gehen muss, aber entweder hängt sich der MPD Server auf oder der exlusive Soundkartenzugriff blockiert.

Ich werden es für die Übergangszeit wie CBSnake machen. Alles zurück zum Urspungszustand. Die Snips Ansage stoppt das Radio. Ich werde über FHEM eine Pause einbauen und das Radio einfach verzögert, quasi nach der Snips Ansage, einschalten.


JensS

Sorry, ich habe mich doch geirrt. Habe die Konstellation nachgestellt und festgestellt, dass der Analogausgang vom RPi dmix scheinbar nicht unterstützt.

Gruß Jens
Debian auf APU2C4, HM-CFG-USB2, SIGNALduino, HM-ES-PMSw1-Pl, TFA 30.3121, TFA 30.3125, ITS-150, PIR-5000, configurable Firmata USB & LAN, 1-wire: DS-18B20, DS-18S20, DS-2408, DS-2413, diverse I2C-Komponenten, zigbee2mqtt, ESPEasy etc.

JensS

#11
Nun habe ich ein Seeed-6Mic-Array und es erst nicht parallel mit mpd zum laufen bekommen. Nach Herstellerinfo:
ZitatLimit for developer using 6-Mic Circular Array Kit(or 4-Mics Linear Array Kit) doing capture & playback the same time:
-1. capture must be start first, or else the capture channels will possibly be disorder.
-2. playback output channels must fill with 8 same channels data or 4 same stereo channels data, or else the speaker or headphone will output nothing possibly.
-3. If you want to play and record at the same time, the aplay music file must be mono, or you can not use this command to play.
habe ich die Channels und die Bindings gelöscht, sowie eine Samplingrate von 44100 eingetragen.# The IPC key of dmix or dsnoop plugin must be unique
# If 555555 or 666666 is used by other processes, use another one


# use samplerate to resample as speexdsp resample is bad
defaults.pcm.rate_converter "samplerate"

pcm.!default {
    type asym
    playback.pcm "playback"
    capture.pcm "capture"
}

pcm.playback {
    type plug
    slave.pcm "Snips"
}

pcm.Snips {
    type softvol
    slave.pcm "dmixed"
    control {
name "Snips"
card "seeed8micvoicec"
    }
}

ctl.Snips {
    type hw
    card "seed8micvoicec"
}

pcm.MPDplug {
    type plug
    slave.pcm "MPDvol"
}

pcm.MPDvol {
    type softvol
    slave.pcm "dmixed"
    control {
name "MPDvolume"
card "seeed8micvoicec"
    }
}

ctl.MPDvol {
    type hw
    card "seed8micvoicec"
}

pcm.capture {
    type plug
    slave.pcm "array"
}

pcm.dmixed {
    type dmix
    ipc_key 555555
    ipc_perm 0666
    ipc_key_add_uid false
    slave {
    pcm "hw:seeed8micvoicec"
    period_time 0
    period_size 1024
    buffer_size 8192
    rate 44100
    }
}

pcm.array {
    type dsnoop
    slave {
        pcm "hw:seeed8micvoicec"
     }
    ipc_key 666666
}

Jetzt läufts wieder.

Gruß Jens
Debian auf APU2C4, HM-CFG-USB2, SIGNALduino, HM-ES-PMSw1-Pl, TFA 30.3121, TFA 30.3125, ITS-150, PIR-5000, configurable Firmata USB & LAN, 1-wire: DS-18B20, DS-18S20, DS-2408, DS-2413, diverse I2C-Komponenten, zigbee2mqtt, ESPEasy etc.

Che007

Hi Jens,

konnte jetzt auch mit USB Lautsprechern nachstellen, dass deine asound.conf funktioniert.
Danke dafür.

Kleiner Typo bei dir:

ctl.smips - < das m