2018-05-02 18:16:44 +08:00
|
|
|
// SPDX-License-Identifier: GPL-2.0
|
|
|
|
/*
|
|
|
|
* dice-alesis.c - a part of driver for DICE based devices
|
|
|
|
*
|
|
|
|
* Copyright (c) 2018 Takashi Sakamoto
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "dice.h"
|
|
|
|
|
|
|
|
static const unsigned int
|
|
|
|
alesis_io14_tx_pcm_chs[MAX_STREAMS][SND_DICE_RATE_MODE_COUNT] = {
|
|
|
|
{6, 6, 4}, /* Tx0 = Analog + S/PDIF. */
|
|
|
|
{8, 4, 0}, /* Tx1 = ADAT1. */
|
|
|
|
};
|
|
|
|
|
|
|
|
static const unsigned int
|
|
|
|
alesis_io26_tx_pcm_chs[MAX_STREAMS][SND_DICE_RATE_MODE_COUNT] = {
|
2019-09-16 18:18:51 +08:00
|
|
|
{10, 10, 4}, /* Tx0 = Analog + S/PDIF. */
|
2018-05-02 18:16:44 +08:00
|
|
|
{16, 8, 0}, /* Tx1 = ADAT1 + ADAT2. */
|
|
|
|
};
|
|
|
|
|
|
|
|
int snd_dice_detect_alesis_formats(struct snd_dice *dice)
|
|
|
|
{
|
|
|
|
__be32 reg;
|
|
|
|
u32 data;
|
|
|
|
int i;
|
|
|
|
int err;
|
|
|
|
|
|
|
|
err = snd_dice_transaction_read_tx(dice, TX_NUMBER_AUDIO, ®,
|
|
|
|
sizeof(reg));
|
|
|
|
if (err < 0)
|
|
|
|
return err;
|
|
|
|
data = be32_to_cpu(reg);
|
|
|
|
|
|
|
|
if (data == 4 || data == 6) {
|
|
|
|
memcpy(dice->tx_pcm_chs, alesis_io14_tx_pcm_chs,
|
|
|
|
MAX_STREAMS * SND_DICE_RATE_MODE_COUNT *
|
|
|
|
sizeof(unsigned int));
|
|
|
|
} else {
|
2018-08-06 15:14:06 +08:00
|
|
|
memcpy(dice->tx_pcm_chs, alesis_io26_tx_pcm_chs,
|
2018-05-02 18:16:44 +08:00
|
|
|
MAX_STREAMS * SND_DICE_RATE_MODE_COUNT *
|
|
|
|
sizeof(unsigned int));
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i = 0; i < SND_DICE_RATE_MODE_COUNT; ++i)
|
|
|
|
dice->rx_pcm_chs[0][i] = 8;
|
|
|
|
|
|
|
|
dice->tx_midi_ports[0] = 1;
|
|
|
|
dice->rx_midi_ports[0] = 1;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|