Make dsnoop card-specific. Its definition is moved to pcm/dsnoop.conf.
slave.pcm $SLAVE
}
-pcm.dsnoop {
- @args [ SLAVE FORMAT RATE ]
- @args.SLAVE {
- type string
- default "hw:0,0"
- }
- @args.FORMAT {
- type string
- default S16_LE
- }
- @args.RATE {
- type integer
- default 48000
- }
- type dsnoop
- ipc_key 5778293
- ipc_key_add_uid yes
- slave {
- pcm $SLAVE
- format $FORMAT
- rate $RATE
- }
-}
-
pcm.shm {
@args [ SOCKET PCM ]
@args.SOCKET {
pcm.default cards.pcm.default
pcm.dmix cards.pcm.dmix
+pcm.dsnoop cards.pcm.dsnoop
#
# Control interface
<confdir:pcm/default.conf>
<confdir:pcm/dmix.conf>
+<confdir:pcm/dsnoop.conf>
surround40.conf surround41.conf \
surround50.conf surround51.conf \
surround71.conf iec958.conf modem.conf \
- dmix.conf
+ dmix.conf dsnoop.conf
EXTRA_DIST = $(cfg_files)
--- /dev/null
+#
+# dsnoop
+#
+
+pcm.!dsnoop {
+ @args [ CARD DEV SUBDEV FORMAT RATE ]
+ @args.CARD {
+ type string
+ default 0
+ }
+ @args.DEV {
+ type string
+ default 0
+ }
+ @args.SUBDEV {
+ type string
+ default -1
+ }
+ @args.FORMAT {
+ type string
+ default S16_LE
+ }
+ @args.RATE {
+ type integer
+ default 48000
+ }
+ type dsnoop
+ ipc_key 5778293
+ ipc_key_add_uid yes
+ slave {
+ pcm {
+ type hw
+ card $CARD
+ device $DEV
+ subdevice $SUBDEV
+ }
+ format $FORMAT
+ rate $RATE
+ period_size {
+ @func refer
+ name {
+ @func concat
+ strings [
+ "cards."
+ {
+ @func card_driver
+ card $CARD
+ }
+ ".pcm.dsnoop.period_size"
+ ]
+ }
+ default 1024
+ }
+ period_time {
+ @func refer
+ name {
+ @func concat
+ strings [
+ "cards."
+ {
+ @func card_driver
+ card $CARD
+ }
+ ".pcm.dsnoop.period_time"
+ ]
+ }
+ default -1
+ }
+ periods {
+ @func refer
+ name {
+ @func concat
+ strings [
+ "cards."
+ {
+ @func card_driver
+ card $CARD
+ }
+ ".pcm.dsnoop.periods"
+ ]
+ }
+ default 16
+ }
+ }
+}