|
@@ -1590,7 +1590,10 @@ static int snd_trident_trigger(struct snd_pcm_substream *substream,
|
|
|
if (spdif_flag) {
|
|
|
if (trident->device != TRIDENT_DEVICE_ID_SI7018) {
|
|
|
outl(trident->spdif_pcm_bits, TRID_REG(trident, NX_SPCSTATUS));
|
|
|
- outb(trident->spdif_pcm_ctrl, TRID_REG(trident, NX_SPCTRL_SPCSO + 3));
|
|
|
+ val = trident->spdif_pcm_ctrl;
|
|
|
+ if (!go)
|
|
|
+ val &= ~(0x28);
|
|
|
+ outb(val, TRID_REG(trident, NX_SPCTRL_SPCSO + 3));
|
|
|
} else {
|
|
|
outl(trident->spdif_pcm_bits, TRID_REG(trident, SI_SPDIF_CS));
|
|
|
val = inl(TRID_REG(trident, SI_SERIAL_INTF_CTRL)) | SPDIF_EN;
|