ALSA: echoaudio: remove all snd_printk
removed all references of snd_printk with the standard dev_* macro. [a few places degraded to dev_dbg(), too -- tiwai] Signed-off-by: Sudip Mukherjee <sudip@vectorindia.org> Signed-off-by: Takashi Iwai <tiwai@suse.de>
This commit is contained in:
parent
e369086968
commit
b5b4a41b39
@ -33,12 +33,13 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
DE_INIT(("init_hw() - Darla20\n"));
|
dev_dbg(chip->card->dev, "init_hw() - Darla20\n");
|
||||||
if (snd_BUG_ON((subdevice_id & 0xfff0) != DARLA20))
|
if (snd_BUG_ON((subdevice_id & 0xfff0) != DARLA20))
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
if ((err = init_dsp_comm_page(chip))) {
|
if ((err = init_dsp_comm_page(chip))) {
|
||||||
DE_INIT(("init_hw - could not initialize DSP comm page\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"init_hw: could not initialize DSP comm page\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -57,7 +58,7 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
return err;
|
return err;
|
||||||
chip->bad_board = FALSE;
|
chip->bad_board = FALSE;
|
||||||
|
|
||||||
DE_INIT(("init_hw done\n"));
|
dev_dbg(chip->card->dev, "init_hw: done\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -33,12 +33,13 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
DE_INIT(("init_hw() - Darla24\n"));
|
dev_dbg(chip->card->dev, "init_hw() - Darla24\n");
|
||||||
if (snd_BUG_ON((subdevice_id & 0xfff0) != DARLA24))
|
if (snd_BUG_ON((subdevice_id & 0xfff0) != DARLA24))
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
if ((err = init_dsp_comm_page(chip))) {
|
if ((err = init_dsp_comm_page(chip))) {
|
||||||
DE_INIT(("init_hw - could not initialize DSP comm page\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"init_hw: could not initialize DSP comm page\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -56,7 +57,7 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
return err;
|
return err;
|
||||||
chip->bad_board = FALSE;
|
chip->bad_board = FALSE;
|
||||||
|
|
||||||
DE_INIT(("init_hw done\n"));
|
dev_dbg(chip->card->dev, "init_hw: done\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -128,15 +129,17 @@ static int set_sample_rate(struct echoaudio *chip, u32 rate)
|
|||||||
clock = GD24_8000;
|
clock = GD24_8000;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
DE_ACT(("set_sample_rate: Error, invalid sample rate %d\n",
|
dev_err(chip->card->dev,
|
||||||
rate));
|
"set_sample_rate: Error, invalid sample rate %d\n",
|
||||||
|
rate);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (wait_handshake(chip))
|
if (wait_handshake(chip))
|
||||||
return -EIO;
|
return -EIO;
|
||||||
|
|
||||||
DE_ACT(("set_sample_rate: %d clock %d\n", rate, clock));
|
dev_dbg(chip->card->dev,
|
||||||
|
"set_sample_rate: %d clock %d\n", rate, clock);
|
||||||
chip->sample_rate = rate;
|
chip->sample_rate = rate;
|
||||||
|
|
||||||
/* Override the sample rate if this card is set to Echo sync. */
|
/* Override the sample rate if this card is set to Echo sync. */
|
||||||
|
@ -46,12 +46,13 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
int err;
|
int err;
|
||||||
|
|
||||||
local_irq_enable();
|
local_irq_enable();
|
||||||
DE_INIT(("init_hw() - Echo3G\n"));
|
dev_dbg(chip->card->dev, "init_hw() - Echo3G\n");
|
||||||
if (snd_BUG_ON((subdevice_id & 0xfff0) != ECHO3G))
|
if (snd_BUG_ON((subdevice_id & 0xfff0) != ECHO3G))
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
if ((err = init_dsp_comm_page(chip))) {
|
if ((err = init_dsp_comm_page(chip))) {
|
||||||
DE_INIT(("init_hw - could not initialize DSP comm page\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"init_hw - could not initialize DSP comm page\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -98,7 +99,7 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
ECHOCAPS_HAS_DIGITAL_MODE_SPDIF_OPTICAL |
|
ECHOCAPS_HAS_DIGITAL_MODE_SPDIF_OPTICAL |
|
||||||
ECHOCAPS_HAS_DIGITAL_MODE_ADAT;
|
ECHOCAPS_HAS_DIGITAL_MODE_ADAT;
|
||||||
|
|
||||||
DE_INIT(("init_hw done\n"));
|
dev_dbg(chip->card->dev, "init_hw done\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -48,13 +48,16 @@ static int get_firmware(const struct firmware **fw_entry,
|
|||||||
|
|
||||||
#ifdef CONFIG_PM_SLEEP
|
#ifdef CONFIG_PM_SLEEP
|
||||||
if (chip->fw_cache[fw_index]) {
|
if (chip->fw_cache[fw_index]) {
|
||||||
DE_ACT(("firmware requested: %s is cached\n", card_fw[fw_index].data));
|
dev_dbg(chip->card->dev,
|
||||||
|
"firmware requested: %s is cached\n",
|
||||||
|
card_fw[fw_index].data);
|
||||||
*fw_entry = chip->fw_cache[fw_index];
|
*fw_entry = chip->fw_cache[fw_index];
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
DE_ACT(("firmware requested: %s\n", card_fw[fw_index].data));
|
dev_dbg(chip->card->dev,
|
||||||
|
"firmware requested: %s\n", card_fw[fw_index].data);
|
||||||
snprintf(name, sizeof(name), "ea/%s", card_fw[fw_index].data);
|
snprintf(name, sizeof(name), "ea/%s", card_fw[fw_index].data);
|
||||||
err = request_firmware(fw_entry, name, pci_device(chip));
|
err = request_firmware(fw_entry, name, pci_device(chip));
|
||||||
if (err < 0)
|
if (err < 0)
|
||||||
@ -73,10 +76,10 @@ static void free_firmware(const struct firmware *fw_entry,
|
|||||||
struct echoaudio *chip)
|
struct echoaudio *chip)
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_PM_SLEEP
|
#ifdef CONFIG_PM_SLEEP
|
||||||
DE_ACT(("firmware not released (kept in cache)\n"));
|
dev_dbg(chip->card->dev, "firmware not released (kept in cache)\n");
|
||||||
#else
|
#else
|
||||||
release_firmware(fw_entry);
|
release_firmware(fw_entry);
|
||||||
DE_ACT(("firmware released\n"));
|
dev_dbg(chip->card->dev, "firmware released\n");
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -90,10 +93,10 @@ static void free_firmware_cache(struct echoaudio *chip)
|
|||||||
for (i = 0; i < 8 ; i++)
|
for (i = 0; i < 8 ; i++)
|
||||||
if (chip->fw_cache[i]) {
|
if (chip->fw_cache[i]) {
|
||||||
release_firmware(chip->fw_cache[i]);
|
release_firmware(chip->fw_cache[i]);
|
||||||
DE_ACT(("release_firmware(%d)\n", i));
|
dev_dbg(chip->card->dev, "release_firmware(%d)\n", i);
|
||||||
}
|
}
|
||||||
|
|
||||||
DE_ACT(("firmware_cache released\n"));
|
dev_dbg(chip->card->dev, "firmware_cache released\n");
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -287,7 +290,7 @@ static int pcm_open(struct snd_pcm_substream *substream,
|
|||||||
|
|
||||||
/* Set up hw capabilities and contraints */
|
/* Set up hw capabilities and contraints */
|
||||||
memcpy(&pipe->hw, &pcm_hardware_skel, sizeof(struct snd_pcm_hardware));
|
memcpy(&pipe->hw, &pcm_hardware_skel, sizeof(struct snd_pcm_hardware));
|
||||||
DE_HWP(("max_channels=%d\n", max_channels));
|
dev_dbg(chip->card->dev, "max_channels=%d\n", max_channels);
|
||||||
pipe->constr.list = channels_list;
|
pipe->constr.list = channels_list;
|
||||||
pipe->constr.mask = 0;
|
pipe->constr.mask = 0;
|
||||||
for (i = 0; channels_list[i] <= max_channels; i++);
|
for (i = 0; channels_list[i] <= max_channels; i++);
|
||||||
@ -337,7 +340,7 @@ static int pcm_open(struct snd_pcm_substream *substream,
|
|||||||
if ((err = snd_dma_alloc_pages(SNDRV_DMA_TYPE_DEV,
|
if ((err = snd_dma_alloc_pages(SNDRV_DMA_TYPE_DEV,
|
||||||
snd_dma_pci_data(chip->pci),
|
snd_dma_pci_data(chip->pci),
|
||||||
PAGE_SIZE, &pipe->sgpage)) < 0) {
|
PAGE_SIZE, &pipe->sgpage)) < 0) {
|
||||||
DE_HWP(("s-g list allocation failed\n"));
|
dev_err(chip->card->dev, "s-g list allocation failed\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -351,7 +354,7 @@ static int pcm_analog_in_open(struct snd_pcm_substream *substream)
|
|||||||
struct echoaudio *chip = snd_pcm_substream_chip(substream);
|
struct echoaudio *chip = snd_pcm_substream_chip(substream);
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
DE_ACT(("pcm_analog_in_open\n"));
|
dev_dbg(chip->card->dev, "pcm_analog_in_open\n");
|
||||||
if ((err = pcm_open(substream, num_analog_busses_in(chip) -
|
if ((err = pcm_open(substream, num_analog_busses_in(chip) -
|
||||||
substream->number)) < 0)
|
substream->number)) < 0)
|
||||||
return err;
|
return err;
|
||||||
@ -368,9 +371,9 @@ static int pcm_analog_in_open(struct snd_pcm_substream *substream)
|
|||||||
atomic_inc(&chip->opencount);
|
atomic_inc(&chip->opencount);
|
||||||
if (atomic_read(&chip->opencount) > 1 && chip->rate_set)
|
if (atomic_read(&chip->opencount) > 1 && chip->rate_set)
|
||||||
chip->can_set_rate=0;
|
chip->can_set_rate=0;
|
||||||
DE_HWP(("pcm_analog_in_open cs=%d oc=%d r=%d\n",
|
dev_dbg(chip->card->dev, "pcm_analog_in_open cs=%d oc=%d r=%d\n",
|
||||||
chip->can_set_rate, atomic_read(&chip->opencount),
|
chip->can_set_rate, atomic_read(&chip->opencount),
|
||||||
chip->sample_rate));
|
chip->sample_rate);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -386,7 +389,7 @@ static int pcm_analog_out_open(struct snd_pcm_substream *substream)
|
|||||||
#else
|
#else
|
||||||
max_channels = num_analog_busses_out(chip);
|
max_channels = num_analog_busses_out(chip);
|
||||||
#endif
|
#endif
|
||||||
DE_ACT(("pcm_analog_out_open\n"));
|
dev_dbg(chip->card->dev, "pcm_analog_out_open\n");
|
||||||
if ((err = pcm_open(substream, max_channels - substream->number)) < 0)
|
if ((err = pcm_open(substream, max_channels - substream->number)) < 0)
|
||||||
return err;
|
return err;
|
||||||
if ((err = snd_pcm_hw_rule_add(substream->runtime, 0,
|
if ((err = snd_pcm_hw_rule_add(substream->runtime, 0,
|
||||||
@ -404,9 +407,9 @@ static int pcm_analog_out_open(struct snd_pcm_substream *substream)
|
|||||||
atomic_inc(&chip->opencount);
|
atomic_inc(&chip->opencount);
|
||||||
if (atomic_read(&chip->opencount) > 1 && chip->rate_set)
|
if (atomic_read(&chip->opencount) > 1 && chip->rate_set)
|
||||||
chip->can_set_rate=0;
|
chip->can_set_rate=0;
|
||||||
DE_HWP(("pcm_analog_out_open cs=%d oc=%d r=%d\n",
|
dev_dbg(chip->card->dev, "pcm_analog_out_open cs=%d oc=%d r=%d\n",
|
||||||
chip->can_set_rate, atomic_read(&chip->opencount),
|
chip->can_set_rate, atomic_read(&chip->opencount),
|
||||||
chip->sample_rate));
|
chip->sample_rate);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -419,7 +422,7 @@ static int pcm_digital_in_open(struct snd_pcm_substream *substream)
|
|||||||
struct echoaudio *chip = snd_pcm_substream_chip(substream);
|
struct echoaudio *chip = snd_pcm_substream_chip(substream);
|
||||||
int err, max_channels;
|
int err, max_channels;
|
||||||
|
|
||||||
DE_ACT(("pcm_digital_in_open\n"));
|
dev_dbg(chip->card->dev, "pcm_digital_in_open\n");
|
||||||
max_channels = num_digital_busses_in(chip) - substream->number;
|
max_channels = num_digital_busses_in(chip) - substream->number;
|
||||||
mutex_lock(&chip->mode_mutex);
|
mutex_lock(&chip->mode_mutex);
|
||||||
if (chip->digital_mode == DIGITAL_MODE_ADAT)
|
if (chip->digital_mode == DIGITAL_MODE_ADAT)
|
||||||
@ -461,7 +464,7 @@ static int pcm_digital_out_open(struct snd_pcm_substream *substream)
|
|||||||
struct echoaudio *chip = snd_pcm_substream_chip(substream);
|
struct echoaudio *chip = snd_pcm_substream_chip(substream);
|
||||||
int err, max_channels;
|
int err, max_channels;
|
||||||
|
|
||||||
DE_ACT(("pcm_digital_out_open\n"));
|
dev_dbg(chip->card->dev, "pcm_digital_out_open\n");
|
||||||
max_channels = num_digital_busses_out(chip) - substream->number;
|
max_channels = num_digital_busses_out(chip) - substream->number;
|
||||||
mutex_lock(&chip->mode_mutex);
|
mutex_lock(&chip->mode_mutex);
|
||||||
if (chip->digital_mode == DIGITAL_MODE_ADAT)
|
if (chip->digital_mode == DIGITAL_MODE_ADAT)
|
||||||
@ -508,18 +511,18 @@ static int pcm_close(struct snd_pcm_substream *substream)
|
|||||||
/* Nothing to do here. Audio is already off and pipe will be
|
/* Nothing to do here. Audio is already off and pipe will be
|
||||||
* freed by its callback
|
* freed by its callback
|
||||||
*/
|
*/
|
||||||
DE_ACT(("pcm_close\n"));
|
dev_dbg(chip->card->dev, "pcm_close\n");
|
||||||
|
|
||||||
atomic_dec(&chip->opencount);
|
atomic_dec(&chip->opencount);
|
||||||
oc = atomic_read(&chip->opencount);
|
oc = atomic_read(&chip->opencount);
|
||||||
DE_ACT(("pcm_close oc=%d cs=%d rs=%d\n", oc,
|
dev_dbg(chip->card->dev, "pcm_close oc=%d cs=%d rs=%d\n", oc,
|
||||||
chip->can_set_rate, chip->rate_set));
|
chip->can_set_rate, chip->rate_set);
|
||||||
if (oc < 2)
|
if (oc < 2)
|
||||||
chip->can_set_rate = 1;
|
chip->can_set_rate = 1;
|
||||||
if (oc == 0)
|
if (oc == 0)
|
||||||
chip->rate_set = 0;
|
chip->rate_set = 0;
|
||||||
DE_ACT(("pcm_close2 oc=%d cs=%d rs=%d\n", oc,
|
dev_dbg(chip->card->dev, "pcm_close2 oc=%d cs=%d rs=%d\n", oc,
|
||||||
chip->can_set_rate,chip->rate_set));
|
chip->can_set_rate, chip->rate_set);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -543,7 +546,7 @@ static int init_engine(struct snd_pcm_substream *substream,
|
|||||||
*/
|
*/
|
||||||
spin_lock_irq(&chip->lock);
|
spin_lock_irq(&chip->lock);
|
||||||
if (pipe->index >= 0) {
|
if (pipe->index >= 0) {
|
||||||
DE_HWP(("hwp_ie free(%d)\n", pipe->index));
|
dev_dbg(chip->card->dev, "hwp_ie free(%d)\n", pipe->index);
|
||||||
err = free_pipes(chip, pipe);
|
err = free_pipes(chip, pipe);
|
||||||
snd_BUG_ON(err);
|
snd_BUG_ON(err);
|
||||||
chip->substream[pipe->index] = NULL;
|
chip->substream[pipe->index] = NULL;
|
||||||
@ -552,16 +555,17 @@ static int init_engine(struct snd_pcm_substream *substream,
|
|||||||
err = allocate_pipes(chip, pipe, pipe_index, interleave);
|
err = allocate_pipes(chip, pipe, pipe_index, interleave);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
spin_unlock_irq(&chip->lock);
|
spin_unlock_irq(&chip->lock);
|
||||||
DE_ACT((KERN_NOTICE "allocate_pipes(%d) err=%d\n",
|
dev_err(chip->card->dev, "allocate_pipes(%d) err=%d\n",
|
||||||
pipe_index, err));
|
pipe_index, err);
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
spin_unlock_irq(&chip->lock);
|
spin_unlock_irq(&chip->lock);
|
||||||
DE_ACT((KERN_NOTICE "allocate_pipes()=%d\n", pipe_index));
|
dev_dbg(chip->card->dev, "allocate_pipes()=%d\n", pipe_index);
|
||||||
|
|
||||||
DE_HWP(("pcm_hw_params (bufsize=%dB periods=%d persize=%dB)\n",
|
dev_dbg(chip->card->dev,
|
||||||
|
"pcm_hw_params (bufsize=%dB periods=%d persize=%dB)\n",
|
||||||
params_buffer_bytes(hw_params), params_periods(hw_params),
|
params_buffer_bytes(hw_params), params_periods(hw_params),
|
||||||
params_period_bytes(hw_params)));
|
params_period_bytes(hw_params));
|
||||||
err = snd_pcm_lib_malloc_pages(substream,
|
err = snd_pcm_lib_malloc_pages(substream,
|
||||||
params_buffer_bytes(hw_params));
|
params_buffer_bytes(hw_params));
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
@ -616,7 +620,7 @@ static int init_engine(struct snd_pcm_substream *substream,
|
|||||||
spin_lock_irq(&chip->lock);
|
spin_lock_irq(&chip->lock);
|
||||||
set_sample_rate(chip, hw_params->rate_num / hw_params->rate_den);
|
set_sample_rate(chip, hw_params->rate_num / hw_params->rate_den);
|
||||||
spin_unlock_irq(&chip->lock);
|
spin_unlock_irq(&chip->lock);
|
||||||
DE_HWP(("pcm_hw_params ok\n"));
|
dev_dbg(chip->card->dev, "pcm_hw_params ok\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -680,14 +684,14 @@ static int pcm_hw_free(struct snd_pcm_substream *substream)
|
|||||||
|
|
||||||
spin_lock_irq(&chip->lock);
|
spin_lock_irq(&chip->lock);
|
||||||
if (pipe->index >= 0) {
|
if (pipe->index >= 0) {
|
||||||
DE_HWP(("pcm_hw_free(%d)\n", pipe->index));
|
dev_dbg(chip->card->dev, "pcm_hw_free(%d)\n", pipe->index);
|
||||||
free_pipes(chip, pipe);
|
free_pipes(chip, pipe);
|
||||||
chip->substream[pipe->index] = NULL;
|
chip->substream[pipe->index] = NULL;
|
||||||
pipe->index = -1;
|
pipe->index = -1;
|
||||||
}
|
}
|
||||||
spin_unlock_irq(&chip->lock);
|
spin_unlock_irq(&chip->lock);
|
||||||
|
|
||||||
DE_HWP(("pcm_hw_freed\n"));
|
dev_dbg(chip->card->dev, "pcm_hw_freed\n");
|
||||||
snd_pcm_lib_free_pages(substream);
|
snd_pcm_lib_free_pages(substream);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -701,8 +705,8 @@ static int pcm_prepare(struct snd_pcm_substream *substream)
|
|||||||
struct audioformat format;
|
struct audioformat format;
|
||||||
int pipe_index = ((struct audiopipe *)runtime->private_data)->index;
|
int pipe_index = ((struct audiopipe *)runtime->private_data)->index;
|
||||||
|
|
||||||
DE_HWP(("Prepare rate=%d format=%d channels=%d\n",
|
dev_dbg(chip->card->dev, "Prepare rate=%d format=%d channels=%d\n",
|
||||||
runtime->rate, runtime->format, runtime->channels));
|
runtime->rate, runtime->format, runtime->channels);
|
||||||
format.interleave = runtime->channels;
|
format.interleave = runtime->channels;
|
||||||
format.data_are_bigendian = 0;
|
format.data_are_bigendian = 0;
|
||||||
format.mono_to_stereo = 0;
|
format.mono_to_stereo = 0;
|
||||||
@ -722,8 +726,9 @@ static int pcm_prepare(struct snd_pcm_substream *substream)
|
|||||||
format.bits_per_sample = 32;
|
format.bits_per_sample = 32;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
DE_HWP(("Prepare error: unsupported format %d\n",
|
dev_err(chip->card->dev,
|
||||||
runtime->format));
|
"Prepare error: unsupported format %d\n",
|
||||||
|
runtime->format);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -758,10 +763,10 @@ static int pcm_trigger(struct snd_pcm_substream *substream, int cmd)
|
|||||||
spin_lock(&chip->lock);
|
spin_lock(&chip->lock);
|
||||||
switch (cmd) {
|
switch (cmd) {
|
||||||
case SNDRV_PCM_TRIGGER_RESUME:
|
case SNDRV_PCM_TRIGGER_RESUME:
|
||||||
DE_ACT(("pcm_trigger resume\n"));
|
dev_dbg(chip->card->dev, "pcm_trigger resume\n");
|
||||||
case SNDRV_PCM_TRIGGER_START:
|
case SNDRV_PCM_TRIGGER_START:
|
||||||
case SNDRV_PCM_TRIGGER_PAUSE_RELEASE:
|
case SNDRV_PCM_TRIGGER_PAUSE_RELEASE:
|
||||||
DE_ACT(("pcm_trigger start\n"));
|
dev_dbg(chip->card->dev, "pcm_trigger start\n");
|
||||||
for (i = 0; i < DSP_MAXPIPES; i++) {
|
for (i = 0; i < DSP_MAXPIPES; i++) {
|
||||||
if (channelmask & (1 << i)) {
|
if (channelmask & (1 << i)) {
|
||||||
pipe = chip->substream[i]->runtime->private_data;
|
pipe = chip->substream[i]->runtime->private_data;
|
||||||
@ -783,9 +788,9 @@ static int pcm_trigger(struct snd_pcm_substream *substream, int cmd)
|
|||||||
chip->pipe_cyclic_mask);
|
chip->pipe_cyclic_mask);
|
||||||
break;
|
break;
|
||||||
case SNDRV_PCM_TRIGGER_SUSPEND:
|
case SNDRV_PCM_TRIGGER_SUSPEND:
|
||||||
DE_ACT(("pcm_trigger suspend\n"));
|
dev_dbg(chip->card->dev, "pcm_trigger suspend\n");
|
||||||
case SNDRV_PCM_TRIGGER_STOP:
|
case SNDRV_PCM_TRIGGER_STOP:
|
||||||
DE_ACT(("pcm_trigger stop\n"));
|
dev_dbg(chip->card->dev, "pcm_trigger stop\n");
|
||||||
for (i = 0; i < DSP_MAXPIPES; i++) {
|
for (i = 0; i < DSP_MAXPIPES; i++) {
|
||||||
if (channelmask & (1 << i)) {
|
if (channelmask & (1 << i)) {
|
||||||
pipe = chip->substream[i]->runtime->private_data;
|
pipe = chip->substream[i]->runtime->private_data;
|
||||||
@ -795,7 +800,7 @@ static int pcm_trigger(struct snd_pcm_substream *substream, int cmd)
|
|||||||
err = stop_transport(chip, channelmask);
|
err = stop_transport(chip, channelmask);
|
||||||
break;
|
break;
|
||||||
case SNDRV_PCM_TRIGGER_PAUSE_PUSH:
|
case SNDRV_PCM_TRIGGER_PAUSE_PUSH:
|
||||||
DE_ACT(("pcm_trigger pause\n"));
|
dev_dbg(chip->card->dev, "pcm_trigger pause\n");
|
||||||
for (i = 0; i < DSP_MAXPIPES; i++) {
|
for (i = 0; i < DSP_MAXPIPES; i++) {
|
||||||
if (channelmask & (1 << i)) {
|
if (channelmask & (1 << i)) {
|
||||||
pipe = chip->substream[i]->runtime->private_data;
|
pipe = chip->substream[i]->runtime->private_data;
|
||||||
@ -932,7 +937,7 @@ static int snd_echo_new_pcm(struct echoaudio *chip)
|
|||||||
snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &analog_capture_ops);
|
snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &analog_capture_ops);
|
||||||
if ((err = snd_echo_preallocate_pages(pcm, snd_dma_pci_data(chip->pci))) < 0)
|
if ((err = snd_echo_preallocate_pages(pcm, snd_dma_pci_data(chip->pci))) < 0)
|
||||||
return err;
|
return err;
|
||||||
DE_INIT(("Analog PCM ok\n"));
|
dev_dbg(chip->card->dev, "Analog PCM ok\n");
|
||||||
|
|
||||||
#ifdef ECHOCARD_HAS_DIGITAL_IO
|
#ifdef ECHOCARD_HAS_DIGITAL_IO
|
||||||
/* PCM#1 Digital inputs, no outputs */
|
/* PCM#1 Digital inputs, no outputs */
|
||||||
@ -945,7 +950,7 @@ static int snd_echo_new_pcm(struct echoaudio *chip)
|
|||||||
snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &digital_capture_ops);
|
snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &digital_capture_ops);
|
||||||
if ((err = snd_echo_preallocate_pages(pcm, snd_dma_pci_data(chip->pci))) < 0)
|
if ((err = snd_echo_preallocate_pages(pcm, snd_dma_pci_data(chip->pci))) < 0)
|
||||||
return err;
|
return err;
|
||||||
DE_INIT(("Digital PCM ok\n"));
|
dev_dbg(chip->card->dev, "Digital PCM ok\n");
|
||||||
#endif /* ECHOCARD_HAS_DIGITAL_IO */
|
#endif /* ECHOCARD_HAS_DIGITAL_IO */
|
||||||
|
|
||||||
#else /* ECHOCARD_HAS_VMIXER */
|
#else /* ECHOCARD_HAS_VMIXER */
|
||||||
@ -967,7 +972,7 @@ static int snd_echo_new_pcm(struct echoaudio *chip)
|
|||||||
snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &analog_capture_ops);
|
snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &analog_capture_ops);
|
||||||
if ((err = snd_echo_preallocate_pages(pcm, snd_dma_pci_data(chip->pci))) < 0)
|
if ((err = snd_echo_preallocate_pages(pcm, snd_dma_pci_data(chip->pci))) < 0)
|
||||||
return err;
|
return err;
|
||||||
DE_INIT(("Analog PCM ok\n"));
|
dev_dbg(chip->card->dev, "Analog PCM ok\n");
|
||||||
|
|
||||||
#ifdef ECHOCARD_HAS_DIGITAL_IO
|
#ifdef ECHOCARD_HAS_DIGITAL_IO
|
||||||
/* PCM#1 Digital i/o */
|
/* PCM#1 Digital i/o */
|
||||||
@ -982,7 +987,7 @@ static int snd_echo_new_pcm(struct echoaudio *chip)
|
|||||||
snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &digital_capture_ops);
|
snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &digital_capture_ops);
|
||||||
if ((err = snd_echo_preallocate_pages(pcm, snd_dma_pci_data(chip->pci))) < 0)
|
if ((err = snd_echo_preallocate_pages(pcm, snd_dma_pci_data(chip->pci))) < 0)
|
||||||
return err;
|
return err;
|
||||||
DE_INIT(("Digital PCM ok\n"));
|
dev_dbg(chip->card->dev, "Digital PCM ok\n");
|
||||||
#endif /* ECHOCARD_HAS_DIGITAL_IO */
|
#endif /* ECHOCARD_HAS_DIGITAL_IO */
|
||||||
|
|
||||||
#endif /* ECHOCARD_HAS_VMIXER */
|
#endif /* ECHOCARD_HAS_VMIXER */
|
||||||
@ -1475,7 +1480,8 @@ static int snd_echo_digital_mode_put(struct snd_kcontrol *kcontrol,
|
|||||||
snd_ctl_notify(chip->card,
|
snd_ctl_notify(chip->card,
|
||||||
SNDRV_CTL_EVENT_MASK_VALUE,
|
SNDRV_CTL_EVENT_MASK_VALUE,
|
||||||
&chip->clock_src_ctl->id);
|
&chip->clock_src_ctl->id);
|
||||||
DE_ACT(("SDM() =%d\n", changed));
|
dev_dbg(chip->card->dev,
|
||||||
|
"SDM() =%d\n", changed);
|
||||||
}
|
}
|
||||||
if (changed >= 0)
|
if (changed >= 0)
|
||||||
changed = 1; /* No errors */
|
changed = 1; /* No errors */
|
||||||
@ -1602,7 +1608,8 @@ static int snd_echo_clock_source_put(struct snd_kcontrol *kcontrol,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (changed < 0)
|
if (changed < 0)
|
||||||
DE_ACT(("seticlk val%d err 0x%x\n", dclock, changed));
|
dev_dbg(chip->card->dev,
|
||||||
|
"seticlk val%d err 0x%x\n", dclock, changed);
|
||||||
|
|
||||||
return changed;
|
return changed;
|
||||||
}
|
}
|
||||||
@ -1859,7 +1866,7 @@ static irqreturn_t snd_echo_interrupt(int irq, void *dev_id)
|
|||||||
#ifdef ECHOCARD_HAS_MIDI
|
#ifdef ECHOCARD_HAS_MIDI
|
||||||
if (st > 0 && chip->midi_in) {
|
if (st > 0 && chip->midi_in) {
|
||||||
snd_rawmidi_receive(chip->midi_in, chip->midi_buffer, st);
|
snd_rawmidi_receive(chip->midi_in, chip->midi_buffer, st);
|
||||||
DE_MID(("rawmidi_iread=%d\n", st));
|
dev_dbg(chip->card->dev, "rawmidi_iread=%d\n", st);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
return IRQ_HANDLED;
|
return IRQ_HANDLED;
|
||||||
@ -1874,10 +1881,10 @@ static irqreturn_t snd_echo_interrupt(int irq, void *dev_id)
|
|||||||
|
|
||||||
static int snd_echo_free(struct echoaudio *chip)
|
static int snd_echo_free(struct echoaudio *chip)
|
||||||
{
|
{
|
||||||
DE_INIT(("Stop DSP...\n"));
|
dev_dbg(chip->card->dev, "Stop DSP...\n");
|
||||||
if (chip->comm_page)
|
if (chip->comm_page)
|
||||||
rest_in_peace(chip);
|
rest_in_peace(chip);
|
||||||
DE_INIT(("Stopped.\n"));
|
dev_dbg(chip->card->dev, "Stopped.\n");
|
||||||
|
|
||||||
if (chip->irq >= 0)
|
if (chip->irq >= 0)
|
||||||
free_irq(chip->irq, chip);
|
free_irq(chip->irq, chip);
|
||||||
@ -1891,14 +1898,14 @@ static int snd_echo_free(struct echoaudio *chip)
|
|||||||
if (chip->iores)
|
if (chip->iores)
|
||||||
release_and_free_resource(chip->iores);
|
release_and_free_resource(chip->iores);
|
||||||
|
|
||||||
DE_INIT(("MMIO freed.\n"));
|
dev_dbg(chip->card->dev, "MMIO freed.\n");
|
||||||
|
|
||||||
pci_disable_device(chip->pci);
|
pci_disable_device(chip->pci);
|
||||||
|
|
||||||
/* release chip data */
|
/* release chip data */
|
||||||
free_firmware_cache(chip);
|
free_firmware_cache(chip);
|
||||||
kfree(chip);
|
kfree(chip);
|
||||||
DE_INIT(("Chip freed.\n"));
|
dev_dbg(chip->card->dev, "Chip freed.\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1908,7 +1915,7 @@ static int snd_echo_dev_free(struct snd_device *device)
|
|||||||
{
|
{
|
||||||
struct echoaudio *chip = device->device_data;
|
struct echoaudio *chip = device->device_data;
|
||||||
|
|
||||||
DE_INIT(("snd_echo_dev_free()...\n"));
|
dev_dbg(chip->card->dev, "snd_echo_dev_free()...\n");
|
||||||
return snd_echo_free(chip);
|
return snd_echo_free(chip);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1941,7 +1948,7 @@ static int snd_echo_create(struct snd_card *card,
|
|||||||
pci_disable_device(pci);
|
pci_disable_device(pci);
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
DE_INIT(("chip=%p\n", chip));
|
dev_dbg(card->dev, "chip=%p\n", chip);
|
||||||
spin_lock_init(&chip->lock);
|
spin_lock_init(&chip->lock);
|
||||||
chip->card = card;
|
chip->card = card;
|
||||||
chip->pci = pci;
|
chip->pci = pci;
|
||||||
@ -1978,8 +1985,8 @@ static int snd_echo_create(struct snd_card *card,
|
|||||||
return -EBUSY;
|
return -EBUSY;
|
||||||
}
|
}
|
||||||
chip->irq = pci->irq;
|
chip->irq = pci->irq;
|
||||||
DE_INIT(("pci=%p irq=%d subdev=%04x Init hardware...\n",
|
dev_dbg(card->dev, "pci=%p irq=%d subdev=%04x Init hardware...\n",
|
||||||
chip->pci, chip->irq, chip->pci->subsystem_device));
|
chip->pci, chip->irq, chip->pci->subsystem_device);
|
||||||
|
|
||||||
/* Create the DSP comm page - this is the area of memory used for most
|
/* Create the DSP comm page - this is the area of memory used for most
|
||||||
of the communication with the DSP, which accesses it via bus mastering */
|
of the communication with the DSP, which accesses it via bus mastering */
|
||||||
@ -1997,11 +2004,11 @@ static int snd_echo_create(struct snd_card *card,
|
|||||||
if (err >= 0)
|
if (err >= 0)
|
||||||
err = set_mixer_defaults(chip);
|
err = set_mixer_defaults(chip);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
DE_INIT(("init_hw err=%d\n", err));
|
dev_err(card->dev, "init_hw err=%d\n", err);
|
||||||
snd_echo_free(chip);
|
snd_echo_free(chip);
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
DE_INIT(("Card init OK\n"));
|
dev_dbg(card->dev, "Card init OK\n");
|
||||||
|
|
||||||
if ((err = snd_device_new(card, SNDRV_DEV_LOWLEVEL, chip, &ops)) < 0) {
|
if ((err = snd_device_new(card, SNDRV_DEV_LOWLEVEL, chip, &ops)) < 0) {
|
||||||
snd_echo_free(chip);
|
snd_echo_free(chip);
|
||||||
@ -2031,7 +2038,7 @@ static int snd_echo_probe(struct pci_dev *pci,
|
|||||||
return -ENOENT;
|
return -ENOENT;
|
||||||
}
|
}
|
||||||
|
|
||||||
DE_INIT(("Echoaudio driver starting...\n"));
|
dev_dbg(&pci->dev, "Echoaudio driver starting...\n");
|
||||||
i = 0;
|
i = 0;
|
||||||
err = snd_card_new(&pci->dev, index[dev], id[dev], THIS_MODULE,
|
err = snd_card_new(&pci->dev, index[dev], id[dev], THIS_MODULE,
|
||||||
0, &card);
|
0, &card);
|
||||||
@ -2184,7 +2191,7 @@ static int snd_echo_suspend(struct device *dev)
|
|||||||
struct pci_dev *pci = to_pci_dev(dev);
|
struct pci_dev *pci = to_pci_dev(dev);
|
||||||
struct echoaudio *chip = dev_get_drvdata(dev);
|
struct echoaudio *chip = dev_get_drvdata(dev);
|
||||||
|
|
||||||
DE_INIT(("suspend start\n"));
|
dev_dbg(dev, "suspend start\n");
|
||||||
snd_pcm_suspend_all(chip->analog_pcm);
|
snd_pcm_suspend_all(chip->analog_pcm);
|
||||||
snd_pcm_suspend_all(chip->digital_pcm);
|
snd_pcm_suspend_all(chip->digital_pcm);
|
||||||
|
|
||||||
@ -2211,7 +2218,7 @@ static int snd_echo_suspend(struct device *dev)
|
|||||||
pci_save_state(pci);
|
pci_save_state(pci);
|
||||||
pci_disable_device(pci);
|
pci_disable_device(pci);
|
||||||
|
|
||||||
DE_INIT(("suspend done\n"));
|
dev_dbg(dev, "suspend done\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2225,7 +2232,7 @@ static int snd_echo_resume(struct device *dev)
|
|||||||
u32 pipe_alloc_mask;
|
u32 pipe_alloc_mask;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
DE_INIT(("resume start\n"));
|
dev_dbg(dev, "resume start\n");
|
||||||
pci_restore_state(pci);
|
pci_restore_state(pci);
|
||||||
commpage_bak = kmalloc(sizeof(struct echoaudio), GFP_KERNEL);
|
commpage_bak = kmalloc(sizeof(struct echoaudio), GFP_KERNEL);
|
||||||
if (commpage_bak == NULL)
|
if (commpage_bak == NULL)
|
||||||
@ -2236,11 +2243,11 @@ static int snd_echo_resume(struct device *dev)
|
|||||||
err = init_hw(chip, chip->pci->device, chip->pci->subsystem_device);
|
err = init_hw(chip, chip->pci->device, chip->pci->subsystem_device);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
kfree(commpage_bak);
|
kfree(commpage_bak);
|
||||||
DE_INIT(("resume init_hw err=%d\n", err));
|
dev_err(dev, "resume init_hw err=%d\n", err);
|
||||||
snd_echo_free(chip);
|
snd_echo_free(chip);
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
DE_INIT(("resume init OK\n"));
|
dev_dbg(dev, "resume init OK\n");
|
||||||
|
|
||||||
/* Temporarily set chip->pipe_alloc_mask=0 otherwise
|
/* Temporarily set chip->pipe_alloc_mask=0 otherwise
|
||||||
* restore_dsp_settings() fails.
|
* restore_dsp_settings() fails.
|
||||||
@ -2253,7 +2260,7 @@ static int snd_echo_resume(struct device *dev)
|
|||||||
kfree(commpage_bak);
|
kfree(commpage_bak);
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
DE_INIT(("resume restore OK\n"));
|
dev_dbg(dev, "resume restore OK\n");
|
||||||
|
|
||||||
memcpy(&commpage->audio_format, &commpage_bak->audio_format,
|
memcpy(&commpage->audio_format, &commpage_bak->audio_format,
|
||||||
sizeof(commpage->audio_format));
|
sizeof(commpage->audio_format));
|
||||||
@ -2270,7 +2277,7 @@ static int snd_echo_resume(struct device *dev)
|
|||||||
return -EBUSY;
|
return -EBUSY;
|
||||||
}
|
}
|
||||||
chip->irq = pci->irq;
|
chip->irq = pci->irq;
|
||||||
DE_INIT(("resume irq=%d\n", chip->irq));
|
dev_dbg(dev, "resume irq=%d\n", chip->irq);
|
||||||
|
|
||||||
#ifdef ECHOCARD_HAS_MIDI
|
#ifdef ECHOCARD_HAS_MIDI
|
||||||
if (chip->midi_input_enabled)
|
if (chip->midi_input_enabled)
|
||||||
@ -2279,7 +2286,7 @@ static int snd_echo_resume(struct device *dev)
|
|||||||
snd_echo_midi_output_trigger(chip->midi_out, 1);
|
snd_echo_midi_output_trigger(chip->midi_out, 1);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
DE_INIT(("resume done\n"));
|
dev_dbg(dev, "resume done\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -295,34 +295,6 @@
|
|||||||
#define PIPE_STATE_PENDING 3 /* Pipe has pending start */
|
#define PIPE_STATE_PENDING 3 /* Pipe has pending start */
|
||||||
|
|
||||||
|
|
||||||
/* Debug initialization */
|
|
||||||
#ifdef CONFIG_SND_DEBUG
|
|
||||||
#define DE_INIT(x) snd_printk x
|
|
||||||
#else
|
|
||||||
#define DE_INIT(x)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Debug hw_params callbacks */
|
|
||||||
#ifdef CONFIG_SND_DEBUG
|
|
||||||
#define DE_HWP(x) snd_printk x
|
|
||||||
#else
|
|
||||||
#define DE_HWP(x)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Debug normal activity (open, start, stop...) */
|
|
||||||
#ifdef CONFIG_SND_DEBUG
|
|
||||||
#define DE_ACT(x) snd_printk x
|
|
||||||
#else
|
|
||||||
#define DE_ACT(x)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Debug midi activity */
|
|
||||||
#ifdef CONFIG_SND_DEBUG
|
|
||||||
#define DE_MID(x) snd_printk x
|
|
||||||
#else
|
|
||||||
#define DE_MID(x)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
struct audiopipe {
|
struct audiopipe {
|
||||||
volatile u32 *dma_counter; /* Commpage register that contains
|
volatile u32 *dma_counter; /* Commpage register that contains
|
||||||
|
@ -51,7 +51,7 @@ static int check_asic_status(struct echoaudio *chip)
|
|||||||
}
|
}
|
||||||
|
|
||||||
box_status = le32_to_cpu(chip->comm_page->ext_box_status);
|
box_status = le32_to_cpu(chip->comm_page->ext_box_status);
|
||||||
DE_INIT(("box_status=%x\n", box_status));
|
dev_dbg(chip->card->dev, "box_status=%x\n", box_status);
|
||||||
if (box_status == E3G_ASIC_NOT_LOADED)
|
if (box_status == E3G_ASIC_NOT_LOADED)
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
@ -76,7 +76,8 @@ static int write_control_reg(struct echoaudio *chip, u32 ctl, u32 frq,
|
|||||||
if (wait_handshake(chip))
|
if (wait_handshake(chip))
|
||||||
return -EIO;
|
return -EIO;
|
||||||
|
|
||||||
DE_ACT(("WriteControlReg: Setting 0x%x, 0x%x\n", ctl, frq));
|
dev_dbg(chip->card->dev,
|
||||||
|
"WriteControlReg: Setting 0x%x, 0x%x\n", ctl, frq);
|
||||||
|
|
||||||
ctl = cpu_to_le32(ctl);
|
ctl = cpu_to_le32(ctl);
|
||||||
frq = cpu_to_le32(frq);
|
frq = cpu_to_le32(frq);
|
||||||
@ -89,7 +90,7 @@ static int write_control_reg(struct echoaudio *chip, u32 ctl, u32 frq,
|
|||||||
return send_vector(chip, DSP_VC_WRITE_CONTROL_REG);
|
return send_vector(chip, DSP_VC_WRITE_CONTROL_REG);
|
||||||
}
|
}
|
||||||
|
|
||||||
DE_ACT(("WriteControlReg: not written, no change\n"));
|
dev_dbg(chip->card->dev, "WriteControlReg: not written, no change\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -258,8 +259,8 @@ static int set_sample_rate(struct echoaudio *chip, u32 rate)
|
|||||||
|
|
||||||
/* Only set the clock for internal mode. */
|
/* Only set the clock for internal mode. */
|
||||||
if (chip->input_clock != ECHO_CLOCK_INTERNAL) {
|
if (chip->input_clock != ECHO_CLOCK_INTERNAL) {
|
||||||
DE_ACT(("set_sample_rate: Cannot set sample rate - "
|
dev_warn(chip->card->dev,
|
||||||
"clock not set to CLK_CLOCKININTERNAL\n"));
|
"Cannot set sample rate - clock not set to CLK_CLOCKININTERNAL\n");
|
||||||
/* Save the rate anyhow */
|
/* Save the rate anyhow */
|
||||||
chip->comm_page->sample_rate = cpu_to_le32(rate);
|
chip->comm_page->sample_rate = cpu_to_le32(rate);
|
||||||
chip->sample_rate = rate;
|
chip->sample_rate = rate;
|
||||||
@ -313,7 +314,8 @@ static int set_sample_rate(struct echoaudio *chip, u32 rate)
|
|||||||
|
|
||||||
chip->comm_page->sample_rate = cpu_to_le32(rate); /* ignored by the DSP */
|
chip->comm_page->sample_rate = cpu_to_le32(rate); /* ignored by the DSP */
|
||||||
chip->sample_rate = rate;
|
chip->sample_rate = rate;
|
||||||
DE_ACT(("SetSampleRate: %d clock %x\n", rate, control_reg));
|
dev_dbg(chip->card->dev,
|
||||||
|
"SetSampleRate: %d clock %x\n", rate, control_reg);
|
||||||
|
|
||||||
/* Tell the DSP about it - DSP reads both control reg & freq reg */
|
/* Tell the DSP about it - DSP reads both control reg & freq reg */
|
||||||
return write_control_reg(chip, control_reg, frq_reg, 0);
|
return write_control_reg(chip, control_reg, frq_reg, 0);
|
||||||
@ -326,7 +328,7 @@ static int set_input_clock(struct echoaudio *chip, u16 clock)
|
|||||||
{
|
{
|
||||||
u32 control_reg, clocks_from_dsp;
|
u32 control_reg, clocks_from_dsp;
|
||||||
|
|
||||||
DE_ACT(("set_input_clock:\n"));
|
dev_dbg(chip->card->dev, "set_input_clock:\n");
|
||||||
|
|
||||||
/* Mask off the clock select bits */
|
/* Mask off the clock select bits */
|
||||||
control_reg = le32_to_cpu(chip->comm_page->control_register) &
|
control_reg = le32_to_cpu(chip->comm_page->control_register) &
|
||||||
@ -335,13 +337,13 @@ static int set_input_clock(struct echoaudio *chip, u16 clock)
|
|||||||
|
|
||||||
switch (clock) {
|
switch (clock) {
|
||||||
case ECHO_CLOCK_INTERNAL:
|
case ECHO_CLOCK_INTERNAL:
|
||||||
DE_ACT(("Set Echo3G clock to INTERNAL\n"));
|
dev_dbg(chip->card->dev, "Set Echo3G clock to INTERNAL\n");
|
||||||
chip->input_clock = ECHO_CLOCK_INTERNAL;
|
chip->input_clock = ECHO_CLOCK_INTERNAL;
|
||||||
return set_sample_rate(chip, chip->sample_rate);
|
return set_sample_rate(chip, chip->sample_rate);
|
||||||
case ECHO_CLOCK_SPDIF:
|
case ECHO_CLOCK_SPDIF:
|
||||||
if (chip->digital_mode == DIGITAL_MODE_ADAT)
|
if (chip->digital_mode == DIGITAL_MODE_ADAT)
|
||||||
return -EAGAIN;
|
return -EAGAIN;
|
||||||
DE_ACT(("Set Echo3G clock to SPDIF\n"));
|
dev_dbg(chip->card->dev, "Set Echo3G clock to SPDIF\n");
|
||||||
control_reg |= E3G_SPDIF_CLOCK;
|
control_reg |= E3G_SPDIF_CLOCK;
|
||||||
if (clocks_from_dsp & E3G_CLOCK_DETECT_BIT_SPDIF96)
|
if (clocks_from_dsp & E3G_CLOCK_DETECT_BIT_SPDIF96)
|
||||||
control_reg |= E3G_DOUBLE_SPEED_MODE;
|
control_reg |= E3G_DOUBLE_SPEED_MODE;
|
||||||
@ -351,12 +353,12 @@ static int set_input_clock(struct echoaudio *chip, u16 clock)
|
|||||||
case ECHO_CLOCK_ADAT:
|
case ECHO_CLOCK_ADAT:
|
||||||
if (chip->digital_mode != DIGITAL_MODE_ADAT)
|
if (chip->digital_mode != DIGITAL_MODE_ADAT)
|
||||||
return -EAGAIN;
|
return -EAGAIN;
|
||||||
DE_ACT(("Set Echo3G clock to ADAT\n"));
|
dev_dbg(chip->card->dev, "Set Echo3G clock to ADAT\n");
|
||||||
control_reg |= E3G_ADAT_CLOCK;
|
control_reg |= E3G_ADAT_CLOCK;
|
||||||
control_reg &= ~E3G_DOUBLE_SPEED_MODE;
|
control_reg &= ~E3G_DOUBLE_SPEED_MODE;
|
||||||
break;
|
break;
|
||||||
case ECHO_CLOCK_WORD:
|
case ECHO_CLOCK_WORD:
|
||||||
DE_ACT(("Set Echo3G clock to WORD\n"));
|
dev_dbg(chip->card->dev, "Set Echo3G clock to WORD\n");
|
||||||
control_reg |= E3G_WORD_CLOCK;
|
control_reg |= E3G_WORD_CLOCK;
|
||||||
if (clocks_from_dsp & E3G_CLOCK_DETECT_BIT_WORD96)
|
if (clocks_from_dsp & E3G_CLOCK_DETECT_BIT_WORD96)
|
||||||
control_reg |= E3G_DOUBLE_SPEED_MODE;
|
control_reg |= E3G_DOUBLE_SPEED_MODE;
|
||||||
@ -364,7 +366,8 @@ static int set_input_clock(struct echoaudio *chip, u16 clock)
|
|||||||
control_reg &= ~E3G_DOUBLE_SPEED_MODE;
|
control_reg &= ~E3G_DOUBLE_SPEED_MODE;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
DE_ACT(("Input clock 0x%x not supported for Echo3G\n", clock));
|
dev_err(chip->card->dev,
|
||||||
|
"Input clock 0x%x not supported for Echo3G\n", clock);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -392,7 +395,8 @@ static int dsp_set_digital_mode(struct echoaudio *chip, u8 mode)
|
|||||||
incompatible_clock = TRUE;
|
incompatible_clock = TRUE;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
DE_ACT(("Digital mode not supported: %d\n", mode));
|
dev_err(chip->card->dev,
|
||||||
|
"Digital mode not supported: %d\n", mode);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -427,6 +431,6 @@ static int dsp_set_digital_mode(struct echoaudio *chip, u8 mode)
|
|||||||
return err;
|
return err;
|
||||||
chip->digital_mode = mode;
|
chip->digital_mode = mode;
|
||||||
|
|
||||||
DE_ACT(("set_digital_mode(%d)\n", chip->digital_mode));
|
dev_dbg(chip->card->dev, "set_digital_mode(%d)\n", chip->digital_mode);
|
||||||
return incompatible_clock;
|
return incompatible_clock;
|
||||||
}
|
}
|
||||||
|
@ -80,7 +80,7 @@ static int send_vector(struct echoaudio *chip, u32 command)
|
|||||||
udelay(1);
|
udelay(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
DE_ACT((KERN_ERR "timeout on send_vector\n"));
|
dev_err(chip->card->dev, "timeout on send_vector\n");
|
||||||
return -EBUSY;
|
return -EBUSY;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -104,7 +104,7 @@ static int write_dsp(struct echoaudio *chip, u32 data)
|
|||||||
}
|
}
|
||||||
|
|
||||||
chip->bad_board = TRUE; /* Set TRUE until DSP re-loaded */
|
chip->bad_board = TRUE; /* Set TRUE until DSP re-loaded */
|
||||||
DE_ACT((KERN_ERR "write_dsp: Set bad_board to TRUE\n"));
|
dev_dbg(chip->card->dev, "write_dsp: Set bad_board to TRUE\n");
|
||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -127,7 +127,7 @@ static int read_dsp(struct echoaudio *chip, u32 *data)
|
|||||||
}
|
}
|
||||||
|
|
||||||
chip->bad_board = TRUE; /* Set TRUE until DSP re-loaded */
|
chip->bad_board = TRUE; /* Set TRUE until DSP re-loaded */
|
||||||
DE_INIT((KERN_ERR "read_dsp: Set bad_board to TRUE\n"));
|
dev_err(chip->card->dev, "read_dsp: Set bad_board to TRUE\n");
|
||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -154,8 +154,9 @@ static int read_sn(struct echoaudio *chip)
|
|||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
DE_INIT(("Read serial number %08x %08x %08x %08x %08x\n",
|
dev_dbg(chip->card->dev,
|
||||||
sn[0], sn[1], sn[2], sn[3], sn[4]));
|
"Read serial number %08x %08x %08x %08x %08x\n",
|
||||||
|
sn[0], sn[1], sn[2], sn[3], sn[4]);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -205,12 +206,12 @@ static int load_asic_generic(struct echoaudio *chip, u32 cmd, short asic)
|
|||||||
goto la_error;
|
goto la_error;
|
||||||
}
|
}
|
||||||
|
|
||||||
DE_INIT(("ASIC loaded\n"));
|
dev_dbg(chip->card->dev, "ASIC loaded\n");
|
||||||
free_firmware(fw, chip);
|
free_firmware(fw, chip);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
la_error:
|
la_error:
|
||||||
DE_INIT(("failed on write_dsp\n"));
|
dev_err(chip->card->dev, "failed on write_dsp\n");
|
||||||
free_firmware(fw, chip);
|
free_firmware(fw, chip);
|
||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
@ -241,8 +242,9 @@ static int install_resident_loader(struct echoaudio *chip)
|
|||||||
loader is already installed, host flag 5 will be on. */
|
loader is already installed, host flag 5 will be on. */
|
||||||
status = get_dsp_register(chip, CHI32_STATUS_REG);
|
status = get_dsp_register(chip, CHI32_STATUS_REG);
|
||||||
if (status & CHI32_STATUS_REG_HF5) {
|
if (status & CHI32_STATUS_REG_HF5) {
|
||||||
DE_INIT(("Resident loader already installed; status is 0x%x\n",
|
dev_dbg(chip->card->dev,
|
||||||
status));
|
"Resident loader already installed; status is 0x%x\n",
|
||||||
|
status);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -283,12 +285,14 @@ static int install_resident_loader(struct echoaudio *chip)
|
|||||||
|
|
||||||
/* Write the count to the DSP */
|
/* Write the count to the DSP */
|
||||||
if (write_dsp(chip, words)) {
|
if (write_dsp(chip, words)) {
|
||||||
DE_INIT(("install_resident_loader: Failed to write word count!\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"install_resident_loader: Failed to write word count!\n");
|
||||||
goto irl_error;
|
goto irl_error;
|
||||||
}
|
}
|
||||||
/* Write the DSP address */
|
/* Write the DSP address */
|
||||||
if (write_dsp(chip, address)) {
|
if (write_dsp(chip, address)) {
|
||||||
DE_INIT(("install_resident_loader: Failed to write DSP address!\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"install_resident_loader: Failed to write DSP address!\n");
|
||||||
goto irl_error;
|
goto irl_error;
|
||||||
}
|
}
|
||||||
/* Write out this block of code to the DSP */
|
/* Write out this block of code to the DSP */
|
||||||
@ -297,7 +301,8 @@ static int install_resident_loader(struct echoaudio *chip)
|
|||||||
|
|
||||||
data = ((u32)code[index] << 16) + code[index + 1];
|
data = ((u32)code[index] << 16) + code[index + 1];
|
||||||
if (write_dsp(chip, data)) {
|
if (write_dsp(chip, data)) {
|
||||||
DE_INIT(("install_resident_loader: Failed to write DSP code\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"install_resident_loader: Failed to write DSP code\n");
|
||||||
goto irl_error;
|
goto irl_error;
|
||||||
}
|
}
|
||||||
index += 2;
|
index += 2;
|
||||||
@ -312,11 +317,11 @@ static int install_resident_loader(struct echoaudio *chip)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (i == 200) {
|
if (i == 200) {
|
||||||
DE_INIT(("Resident loader failed to set HF5\n"));
|
dev_err(chip->card->dev, "Resident loader failed to set HF5\n");
|
||||||
goto irl_error;
|
goto irl_error;
|
||||||
}
|
}
|
||||||
|
|
||||||
DE_INIT(("Resident loader successfully installed\n"));
|
dev_dbg(chip->card->dev, "Resident loader successfully installed\n");
|
||||||
free_firmware(fw, chip);
|
free_firmware(fw, chip);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
@ -334,14 +339,14 @@ static int load_dsp(struct echoaudio *chip, u16 *code)
|
|||||||
int index, words, i;
|
int index, words, i;
|
||||||
|
|
||||||
if (chip->dsp_code == code) {
|
if (chip->dsp_code == code) {
|
||||||
DE_INIT(("DSP is already loaded!\n"));
|
dev_warn(chip->card->dev, "DSP is already loaded!\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
chip->bad_board = TRUE; /* Set TRUE until DSP loaded */
|
chip->bad_board = TRUE; /* Set TRUE until DSP loaded */
|
||||||
chip->dsp_code = NULL; /* Current DSP code not loaded */
|
chip->dsp_code = NULL; /* Current DSP code not loaded */
|
||||||
chip->asic_loaded = FALSE; /* Loading the DSP code will reset the ASIC */
|
chip->asic_loaded = FALSE; /* Loading the DSP code will reset the ASIC */
|
||||||
|
|
||||||
DE_INIT(("load_dsp: Set bad_board to TRUE\n"));
|
dev_dbg(chip->card->dev, "load_dsp: Set bad_board to TRUE\n");
|
||||||
|
|
||||||
/* If this board requires a resident loader, install it. */
|
/* If this board requires a resident loader, install it. */
|
||||||
#ifdef DSP_56361
|
#ifdef DSP_56361
|
||||||
@ -351,7 +356,8 @@ static int load_dsp(struct echoaudio *chip, u16 *code)
|
|||||||
|
|
||||||
/* Send software reset command */
|
/* Send software reset command */
|
||||||
if (send_vector(chip, DSP_VC_RESET) < 0) {
|
if (send_vector(chip, DSP_VC_RESET) < 0) {
|
||||||
DE_INIT(("LoadDsp: send_vector DSP_VC_RESET failed, Critical Failure\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"LoadDsp: send_vector DSP_VC_RESET failed, Critical Failure\n");
|
||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
/* Delay 10us */
|
/* Delay 10us */
|
||||||
@ -366,7 +372,8 @@ static int load_dsp(struct echoaudio *chip, u16 *code)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (i == 1000) {
|
if (i == 1000) {
|
||||||
DE_INIT(("load_dsp: Timeout waiting for CHI32_STATUS_REG_HF3\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"load_dsp: Timeout waiting for CHI32_STATUS_REG_HF3\n");
|
||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -403,29 +410,34 @@ static int load_dsp(struct echoaudio *chip, u16 *code)
|
|||||||
index += 2;
|
index += 2;
|
||||||
|
|
||||||
if (write_dsp(chip, words) < 0) {
|
if (write_dsp(chip, words) < 0) {
|
||||||
DE_INIT(("load_dsp: failed to write number of DSP words\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"load_dsp: failed to write number of DSP words\n");
|
||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
if (write_dsp(chip, address) < 0) {
|
if (write_dsp(chip, address) < 0) {
|
||||||
DE_INIT(("load_dsp: failed to write DSP address\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"load_dsp: failed to write DSP address\n");
|
||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
if (write_dsp(chip, mem_type) < 0) {
|
if (write_dsp(chip, mem_type) < 0) {
|
||||||
DE_INIT(("load_dsp: failed to write DSP memory type\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"load_dsp: failed to write DSP memory type\n");
|
||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
/* Code */
|
/* Code */
|
||||||
for (i = 0; i < words; i++, index+=2) {
|
for (i = 0; i < words; i++, index+=2) {
|
||||||
data = ((u32)code[index] << 16) + code[index + 1];
|
data = ((u32)code[index] << 16) + code[index + 1];
|
||||||
if (write_dsp(chip, data) < 0) {
|
if (write_dsp(chip, data) < 0) {
|
||||||
DE_INIT(("load_dsp: failed to write DSP data\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"load_dsp: failed to write DSP data\n");
|
||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (write_dsp(chip, 0) < 0) { /* We're done!!! */
|
if (write_dsp(chip, 0) < 0) { /* We're done!!! */
|
||||||
DE_INIT(("load_dsp: Failed to write final zero\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"load_dsp: Failed to write final zero\n");
|
||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
udelay(10);
|
udelay(10);
|
||||||
@ -438,12 +450,14 @@ static int load_dsp(struct echoaudio *chip, u16 *code)
|
|||||||
get_dsp_register(chip, CHI32_CONTROL_REG) & ~0x1b00);
|
get_dsp_register(chip, CHI32_CONTROL_REG) & ~0x1b00);
|
||||||
|
|
||||||
if (write_dsp(chip, DSP_FNC_SET_COMMPAGE_ADDR) < 0) {
|
if (write_dsp(chip, DSP_FNC_SET_COMMPAGE_ADDR) < 0) {
|
||||||
DE_INIT(("load_dsp: Failed to write DSP_FNC_SET_COMMPAGE_ADDR\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"load_dsp: Failed to write DSP_FNC_SET_COMMPAGE_ADDR\n");
|
||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (write_dsp(chip, chip->comm_page_phys) < 0) {
|
if (write_dsp(chip, chip->comm_page_phys) < 0) {
|
||||||
DE_INIT(("load_dsp: Failed to write comm page address\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"load_dsp: Failed to write comm page address\n");
|
||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -452,19 +466,21 @@ static int load_dsp(struct echoaudio *chip, u16 *code)
|
|||||||
We don't actually use the serial number but we have to
|
We don't actually use the serial number but we have to
|
||||||
get it as part of the DSP init voodoo. */
|
get it as part of the DSP init voodoo. */
|
||||||
if (read_sn(chip) < 0) {
|
if (read_sn(chip) < 0) {
|
||||||
DE_INIT(("load_dsp: Failed to read serial number\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"load_dsp: Failed to read serial number\n");
|
||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
|
|
||||||
chip->dsp_code = code; /* Show which DSP code loaded */
|
chip->dsp_code = code; /* Show which DSP code loaded */
|
||||||
chip->bad_board = FALSE; /* DSP OK */
|
chip->bad_board = FALSE; /* DSP OK */
|
||||||
DE_INIT(("load_dsp: OK!\n"));
|
dev_dbg(chip->card->dev, "load_dsp: OK!\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
udelay(100);
|
udelay(100);
|
||||||
}
|
}
|
||||||
|
|
||||||
DE_INIT(("load_dsp: DSP load timed out waiting for HF4\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"load_dsp: DSP load timed out waiting for HF4\n");
|
||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -658,7 +674,7 @@ static void get_audio_meters(struct echoaudio *chip, long *meters)
|
|||||||
static int restore_dsp_rettings(struct echoaudio *chip)
|
static int restore_dsp_rettings(struct echoaudio *chip)
|
||||||
{
|
{
|
||||||
int i, o, err;
|
int i, o, err;
|
||||||
DE_INIT(("restore_dsp_settings\n"));
|
dev_dbg(chip->card->dev, "restore_dsp_settings\n");
|
||||||
|
|
||||||
if ((err = check_asic_status(chip)) < 0)
|
if ((err = check_asic_status(chip)) < 0)
|
||||||
return err;
|
return err;
|
||||||
@ -755,7 +771,7 @@ static int restore_dsp_rettings(struct echoaudio *chip)
|
|||||||
if (send_vector(chip, DSP_VC_UPDATE_FLAGS) < 0)
|
if (send_vector(chip, DSP_VC_UPDATE_FLAGS) < 0)
|
||||||
return -EIO;
|
return -EIO;
|
||||||
|
|
||||||
DE_INIT(("restore_dsp_rettings done\n"));
|
dev_dbg(chip->card->dev, "restore_dsp_rettings done\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -835,7 +851,8 @@ static void set_audio_format(struct echoaudio *chip, u16 pipe_index,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
DE_ACT(("set_audio_format[%d] = %x\n", pipe_index, dsp_format));
|
dev_dbg(chip->card->dev,
|
||||||
|
"set_audio_format[%d] = %x\n", pipe_index, dsp_format);
|
||||||
chip->comm_page->audio_format[pipe_index] = cpu_to_le16(dsp_format);
|
chip->comm_page->audio_format[pipe_index] = cpu_to_le16(dsp_format);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -848,7 +865,7 @@ Same thing for pause_ and stop_ -trasport below. */
|
|||||||
static int start_transport(struct echoaudio *chip, u32 channel_mask,
|
static int start_transport(struct echoaudio *chip, u32 channel_mask,
|
||||||
u32 cyclic_mask)
|
u32 cyclic_mask)
|
||||||
{
|
{
|
||||||
DE_ACT(("start_transport %x\n", channel_mask));
|
dev_dbg(chip->card->dev, "start_transport %x\n", channel_mask);
|
||||||
|
|
||||||
if (wait_handshake(chip))
|
if (wait_handshake(chip))
|
||||||
return -EIO;
|
return -EIO;
|
||||||
@ -866,7 +883,7 @@ static int start_transport(struct echoaudio *chip, u32 channel_mask,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
DE_ACT(("start_transport: No pipes to start!\n"));
|
dev_err(chip->card->dev, "start_transport: No pipes to start!\n");
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -874,7 +891,7 @@ static int start_transport(struct echoaudio *chip, u32 channel_mask,
|
|||||||
|
|
||||||
static int pause_transport(struct echoaudio *chip, u32 channel_mask)
|
static int pause_transport(struct echoaudio *chip, u32 channel_mask)
|
||||||
{
|
{
|
||||||
DE_ACT(("pause_transport %x\n", channel_mask));
|
dev_dbg(chip->card->dev, "pause_transport %x\n", channel_mask);
|
||||||
|
|
||||||
if (wait_handshake(chip))
|
if (wait_handshake(chip))
|
||||||
return -EIO;
|
return -EIO;
|
||||||
@ -893,7 +910,7 @@ static int pause_transport(struct echoaudio *chip, u32 channel_mask)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
DE_ACT(("pause_transport: No pipes to stop!\n"));
|
dev_warn(chip->card->dev, "pause_transport: No pipes to stop!\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -901,7 +918,7 @@ static int pause_transport(struct echoaudio *chip, u32 channel_mask)
|
|||||||
|
|
||||||
static int stop_transport(struct echoaudio *chip, u32 channel_mask)
|
static int stop_transport(struct echoaudio *chip, u32 channel_mask)
|
||||||
{
|
{
|
||||||
DE_ACT(("stop_transport %x\n", channel_mask));
|
dev_dbg(chip->card->dev, "stop_transport %x\n", channel_mask);
|
||||||
|
|
||||||
if (wait_handshake(chip))
|
if (wait_handshake(chip))
|
||||||
return -EIO;
|
return -EIO;
|
||||||
@ -920,7 +937,7 @@ static int stop_transport(struct echoaudio *chip, u32 channel_mask)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
DE_ACT(("stop_transport: No pipes to stop!\n"));
|
dev_warn(chip->card->dev, "stop_transport: No pipes to stop!\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -937,7 +954,8 @@ static inline int is_pipe_allocated(struct echoaudio *chip, u16 pipe_index)
|
|||||||
stopped and unallocated. */
|
stopped and unallocated. */
|
||||||
static int rest_in_peace(struct echoaudio *chip)
|
static int rest_in_peace(struct echoaudio *chip)
|
||||||
{
|
{
|
||||||
DE_ACT(("rest_in_peace() open=%x\n", chip->pipe_alloc_mask));
|
dev_dbg(chip->card->dev,
|
||||||
|
"rest_in_peace() open=%x\n", chip->pipe_alloc_mask);
|
||||||
|
|
||||||
/* Stops all active pipes (just to be sure) */
|
/* Stops all active pipes (just to be sure) */
|
||||||
stop_transport(chip, chip->active_mask);
|
stop_transport(chip, chip->active_mask);
|
||||||
@ -965,7 +983,8 @@ static int init_dsp_comm_page(struct echoaudio *chip)
|
|||||||
{
|
{
|
||||||
/* Check if the compiler added extra padding inside the structure */
|
/* Check if the compiler added extra padding inside the structure */
|
||||||
if (offsetof(struct comm_page, midi_output) != 0xbe0) {
|
if (offsetof(struct comm_page, midi_output) != 0xbe0) {
|
||||||
DE_INIT(("init_dsp_comm_page() - Invalid struct comm_page structure\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"init_dsp_comm_page() - Invalid struct comm_page structure\n");
|
||||||
return -EPERM;
|
return -EPERM;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -999,7 +1018,7 @@ static int init_dsp_comm_page(struct echoaudio *chip)
|
|||||||
*/
|
*/
|
||||||
static int init_line_levels(struct echoaudio *chip)
|
static int init_line_levels(struct echoaudio *chip)
|
||||||
{
|
{
|
||||||
DE_INIT(("init_line_levels\n"));
|
dev_dbg(chip->card->dev, "init_line_levels\n");
|
||||||
memset(chip->output_gain, ECHOGAIN_MUTED, sizeof(chip->output_gain));
|
memset(chip->output_gain, ECHOGAIN_MUTED, sizeof(chip->output_gain));
|
||||||
memset(chip->input_gain, ECHOGAIN_MUTED, sizeof(chip->input_gain));
|
memset(chip->input_gain, ECHOGAIN_MUTED, sizeof(chip->input_gain));
|
||||||
memset(chip->monitor_gain, ECHOGAIN_MUTED, sizeof(chip->monitor_gain));
|
memset(chip->monitor_gain, ECHOGAIN_MUTED, sizeof(chip->monitor_gain));
|
||||||
@ -1051,7 +1070,8 @@ static int allocate_pipes(struct echoaudio *chip, struct audiopipe *pipe,
|
|||||||
u32 channel_mask;
|
u32 channel_mask;
|
||||||
char is_cyclic;
|
char is_cyclic;
|
||||||
|
|
||||||
DE_ACT(("allocate_pipes: ch=%d int=%d\n", pipe_index, interleave));
|
dev_dbg(chip->card->dev,
|
||||||
|
"allocate_pipes: ch=%d int=%d\n", pipe_index, interleave);
|
||||||
|
|
||||||
if (chip->bad_board)
|
if (chip->bad_board)
|
||||||
return -EIO;
|
return -EIO;
|
||||||
@ -1061,7 +1081,8 @@ static int allocate_pipes(struct echoaudio *chip, struct audiopipe *pipe,
|
|||||||
for (channel_mask = i = 0; i < interleave; i++)
|
for (channel_mask = i = 0; i < interleave; i++)
|
||||||
channel_mask |= 1 << (pipe_index + i);
|
channel_mask |= 1 << (pipe_index + i);
|
||||||
if (chip->pipe_alloc_mask & channel_mask) {
|
if (chip->pipe_alloc_mask & channel_mask) {
|
||||||
DE_ACT(("allocate_pipes: channel already open\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"allocate_pipes: channel already open\n");
|
||||||
return -EAGAIN;
|
return -EAGAIN;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1078,7 +1099,7 @@ static int allocate_pipes(struct echoaudio *chip, struct audiopipe *pipe,
|
|||||||
it moves data. The DMA counter is in units of bytes, not samples. */
|
it moves data. The DMA counter is in units of bytes, not samples. */
|
||||||
pipe->dma_counter = &chip->comm_page->position[pipe_index];
|
pipe->dma_counter = &chip->comm_page->position[pipe_index];
|
||||||
*pipe->dma_counter = 0;
|
*pipe->dma_counter = 0;
|
||||||
DE_ACT(("allocate_pipes: ok\n"));
|
dev_dbg(chip->card->dev, "allocate_pipes: ok\n");
|
||||||
return pipe_index;
|
return pipe_index;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1089,7 +1110,7 @@ static int free_pipes(struct echoaudio *chip, struct audiopipe *pipe)
|
|||||||
u32 channel_mask;
|
u32 channel_mask;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
DE_ACT(("free_pipes: Pipe %d\n", pipe->index));
|
dev_dbg(chip->card->dev, "free_pipes: Pipe %d\n", pipe->index);
|
||||||
if (snd_BUG_ON(!is_pipe_allocated(chip, pipe->index)))
|
if (snd_BUG_ON(!is_pipe_allocated(chip, pipe->index)))
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
if (snd_BUG_ON(pipe->state != PIPE_STATE_STOPPED))
|
if (snd_BUG_ON(pipe->state != PIPE_STATE_STOPPED))
|
||||||
@ -1131,7 +1152,7 @@ static int sglist_add_mapping(struct echoaudio *chip, struct audiopipe *pipe,
|
|||||||
list[head].size = cpu_to_le32(length);
|
list[head].size = cpu_to_le32(length);
|
||||||
pipe->sglist_head++;
|
pipe->sglist_head++;
|
||||||
} else {
|
} else {
|
||||||
DE_ACT(("SGlist: too many fragments\n"));
|
dev_err(chip->card->dev, "SGlist: too many fragments\n");
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -46,7 +46,8 @@ static int check_asic_status(struct echoaudio *chip)
|
|||||||
/* The DSP will return a value to indicate whether or not the
|
/* The DSP will return a value to indicate whether or not the
|
||||||
ASIC is currently loaded */
|
ASIC is currently loaded */
|
||||||
if (read_dsp(chip, &asic_status) < 0) {
|
if (read_dsp(chip, &asic_status) < 0) {
|
||||||
DE_INIT(("check_asic_status: failed on read_dsp\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"check_asic_status: failed on read_dsp\n");
|
||||||
chip->asic_loaded = FALSE;
|
chip->asic_loaded = FALSE;
|
||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
@ -68,7 +69,7 @@ static int write_control_reg(struct echoaudio *chip, u32 value, char force)
|
|||||||
else
|
else
|
||||||
value &= ~GML_DIGITAL_IN_AUTO_MUTE;
|
value &= ~GML_DIGITAL_IN_AUTO_MUTE;
|
||||||
|
|
||||||
DE_ACT(("write_control_reg: 0x%x\n", value));
|
dev_dbg(chip->card->dev, "write_control_reg: 0x%x\n", value);
|
||||||
|
|
||||||
/* Write the control register */
|
/* Write the control register */
|
||||||
value = cpu_to_le32(value);
|
value = cpu_to_le32(value);
|
||||||
@ -91,7 +92,7 @@ If the auto-mute is disabled, the digital inputs are enabled regardless of
|
|||||||
what the input clock is set or what is connected. */
|
what the input clock is set or what is connected. */
|
||||||
static int set_input_auto_mute(struct echoaudio *chip, int automute)
|
static int set_input_auto_mute(struct echoaudio *chip, int automute)
|
||||||
{
|
{
|
||||||
DE_ACT(("set_input_auto_mute %d\n", automute));
|
dev_dbg(chip->card->dev, "set_input_auto_mute %d\n", automute);
|
||||||
|
|
||||||
chip->digital_in_automute = automute;
|
chip->digital_in_automute = automute;
|
||||||
|
|
||||||
@ -194,7 +195,7 @@ static int set_professional_spdif(struct echoaudio *chip, char prof)
|
|||||||
if ((err = write_control_reg(chip, control_reg, FALSE)))
|
if ((err = write_control_reg(chip, control_reg, FALSE)))
|
||||||
return err;
|
return err;
|
||||||
chip->professional_spdif = prof;
|
chip->professional_spdif = prof;
|
||||||
DE_ACT(("set_professional_spdif to %s\n",
|
dev_dbg(chip->card->dev, "set_professional_spdif to %s\n",
|
||||||
prof ? "Professional" : "Consumer"));
|
prof ? "Professional" : "Consumer");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -37,12 +37,13 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
DE_INIT(("init_hw() - Gina20\n"));
|
dev_dbg(chip->card->dev, "init_hw() - Gina20\n");
|
||||||
if (snd_BUG_ON((subdevice_id & 0xfff0) != GINA20))
|
if (snd_BUG_ON((subdevice_id & 0xfff0) != GINA20))
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
if ((err = init_dsp_comm_page(chip))) {
|
if ((err = init_dsp_comm_page(chip))) {
|
||||||
DE_INIT(("init_hw - could not initialize DSP comm page\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"init_hw - could not initialize DSP comm page\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -62,7 +63,7 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
return err;
|
return err;
|
||||||
chip->bad_board = FALSE;
|
chip->bad_board = FALSE;
|
||||||
|
|
||||||
DE_INIT(("init_hw done\n"));
|
dev_dbg(chip->card->dev, "init_hw done\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -149,7 +150,7 @@ static int set_sample_rate(struct echoaudio *chip, u32 rate)
|
|||||||
|
|
||||||
static int set_input_clock(struct echoaudio *chip, u16 clock)
|
static int set_input_clock(struct echoaudio *chip, u16 clock)
|
||||||
{
|
{
|
||||||
DE_ACT(("set_input_clock:\n"));
|
dev_dbg(chip->card->dev, "set_input_clock:\n");
|
||||||
|
|
||||||
switch (clock) {
|
switch (clock) {
|
||||||
case ECHO_CLOCK_INTERNAL:
|
case ECHO_CLOCK_INTERNAL:
|
||||||
@ -158,7 +159,7 @@ static int set_input_clock(struct echoaudio *chip, u16 clock)
|
|||||||
chip->spdif_status = GD_SPDIF_STATUS_UNDEF;
|
chip->spdif_status = GD_SPDIF_STATUS_UNDEF;
|
||||||
set_sample_rate(chip, chip->sample_rate);
|
set_sample_rate(chip, chip->sample_rate);
|
||||||
chip->input_clock = clock;
|
chip->input_clock = clock;
|
||||||
DE_ACT(("Set Gina clock to INTERNAL\n"));
|
dev_dbg(chip->card->dev, "Set Gina clock to INTERNAL\n");
|
||||||
break;
|
break;
|
||||||
case ECHO_CLOCK_SPDIF:
|
case ECHO_CLOCK_SPDIF:
|
||||||
chip->comm_page->gd_clock_state = GD_CLOCK_SPDIFIN;
|
chip->comm_page->gd_clock_state = GD_CLOCK_SPDIFIN;
|
||||||
@ -166,7 +167,7 @@ static int set_input_clock(struct echoaudio *chip, u16 clock)
|
|||||||
clear_handshake(chip);
|
clear_handshake(chip);
|
||||||
send_vector(chip, DSP_VC_SET_GD_AUDIO_STATE);
|
send_vector(chip, DSP_VC_SET_GD_AUDIO_STATE);
|
||||||
chip->clock_state = GD_CLOCK_SPDIFIN;
|
chip->clock_state = GD_CLOCK_SPDIFIN;
|
||||||
DE_ACT(("Set Gina20 clock to SPDIF\n"));
|
dev_dbg(chip->card->dev, "Set Gina20 clock to SPDIF\n");
|
||||||
chip->input_clock = clock;
|
chip->input_clock = clock;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
@ -208,7 +209,7 @@ static int update_flags(struct echoaudio *chip)
|
|||||||
|
|
||||||
static int set_professional_spdif(struct echoaudio *chip, char prof)
|
static int set_professional_spdif(struct echoaudio *chip, char prof)
|
||||||
{
|
{
|
||||||
DE_ACT(("set_professional_spdif %d\n", prof));
|
dev_dbg(chip->card->dev, "set_professional_spdif %d\n", prof);
|
||||||
if (prof)
|
if (prof)
|
||||||
chip->comm_page->flags |=
|
chip->comm_page->flags |=
|
||||||
cpu_to_le32(DSP_FLAG_PROFESSIONAL_SPDIF);
|
cpu_to_le32(DSP_FLAG_PROFESSIONAL_SPDIF);
|
||||||
|
@ -41,12 +41,13 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
DE_INIT(("init_hw() - Gina24\n"));
|
dev_dbg(chip->card->dev, "init_hw() - Gina24\n");
|
||||||
if (snd_BUG_ON((subdevice_id & 0xfff0) != GINA24))
|
if (snd_BUG_ON((subdevice_id & 0xfff0) != GINA24))
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
if ((err = init_dsp_comm_page(chip))) {
|
if ((err = init_dsp_comm_page(chip))) {
|
||||||
DE_INIT(("init_hw - could not initialize DSP comm page\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"init_hw - could not initialize DSP comm page\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -78,7 +79,7 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
return err;
|
return err;
|
||||||
chip->bad_board = FALSE;
|
chip->bad_board = FALSE;
|
||||||
|
|
||||||
DE_INIT(("init_hw done\n"));
|
dev_dbg(chip->card->dev, "init_hw done\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -155,7 +156,7 @@ static int load_asic(struct echoaudio *chip)
|
|||||||
control_reg = GML_CONVERTER_ENABLE | GML_48KHZ;
|
control_reg = GML_CONVERTER_ENABLE | GML_48KHZ;
|
||||||
err = write_control_reg(chip, control_reg, TRUE);
|
err = write_control_reg(chip, control_reg, TRUE);
|
||||||
}
|
}
|
||||||
DE_INIT(("load_asic() done\n"));
|
dev_dbg(chip->card->dev, "load_asic() done\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -171,8 +172,8 @@ static int set_sample_rate(struct echoaudio *chip, u32 rate)
|
|||||||
|
|
||||||
/* Only set the clock for internal mode. */
|
/* Only set the clock for internal mode. */
|
||||||
if (chip->input_clock != ECHO_CLOCK_INTERNAL) {
|
if (chip->input_clock != ECHO_CLOCK_INTERNAL) {
|
||||||
DE_ACT(("set_sample_rate: Cannot set sample rate - "
|
dev_warn(chip->card->dev,
|
||||||
"clock not set to CLK_CLOCKININTERNAL\n"));
|
"Cannot set sample rate - clock not set to CLK_CLOCKININTERNAL\n");
|
||||||
/* Save the rate anyhow */
|
/* Save the rate anyhow */
|
||||||
chip->comm_page->sample_rate = cpu_to_le32(rate);
|
chip->comm_page->sample_rate = cpu_to_le32(rate);
|
||||||
chip->sample_rate = rate;
|
chip->sample_rate = rate;
|
||||||
@ -217,7 +218,8 @@ static int set_sample_rate(struct echoaudio *chip, u32 rate)
|
|||||||
clock = GML_8KHZ;
|
clock = GML_8KHZ;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
DE_ACT(("set_sample_rate: %d invalid!\n", rate));
|
dev_err(chip->card->dev,
|
||||||
|
"set_sample_rate: %d invalid!\n", rate);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -225,7 +227,7 @@ static int set_sample_rate(struct echoaudio *chip, u32 rate)
|
|||||||
|
|
||||||
chip->comm_page->sample_rate = cpu_to_le32(rate); /* ignored by the DSP */
|
chip->comm_page->sample_rate = cpu_to_le32(rate); /* ignored by the DSP */
|
||||||
chip->sample_rate = rate;
|
chip->sample_rate = rate;
|
||||||
DE_ACT(("set_sample_rate: %d clock %d\n", rate, clock));
|
dev_dbg(chip->card->dev, "set_sample_rate: %d clock %d\n", rate, clock);
|
||||||
|
|
||||||
return write_control_reg(chip, control_reg, FALSE);
|
return write_control_reg(chip, control_reg, FALSE);
|
||||||
}
|
}
|
||||||
@ -236,7 +238,7 @@ static int set_input_clock(struct echoaudio *chip, u16 clock)
|
|||||||
{
|
{
|
||||||
u32 control_reg, clocks_from_dsp;
|
u32 control_reg, clocks_from_dsp;
|
||||||
|
|
||||||
DE_ACT(("set_input_clock:\n"));
|
dev_dbg(chip->card->dev, "set_input_clock:\n");
|
||||||
|
|
||||||
/* Mask off the clock select bits */
|
/* Mask off the clock select bits */
|
||||||
control_reg = le32_to_cpu(chip->comm_page->control_register) &
|
control_reg = le32_to_cpu(chip->comm_page->control_register) &
|
||||||
@ -245,13 +247,13 @@ static int set_input_clock(struct echoaudio *chip, u16 clock)
|
|||||||
|
|
||||||
switch (clock) {
|
switch (clock) {
|
||||||
case ECHO_CLOCK_INTERNAL:
|
case ECHO_CLOCK_INTERNAL:
|
||||||
DE_ACT(("Set Gina24 clock to INTERNAL\n"));
|
dev_dbg(chip->card->dev, "Set Gina24 clock to INTERNAL\n");
|
||||||
chip->input_clock = ECHO_CLOCK_INTERNAL;
|
chip->input_clock = ECHO_CLOCK_INTERNAL;
|
||||||
return set_sample_rate(chip, chip->sample_rate);
|
return set_sample_rate(chip, chip->sample_rate);
|
||||||
case ECHO_CLOCK_SPDIF:
|
case ECHO_CLOCK_SPDIF:
|
||||||
if (chip->digital_mode == DIGITAL_MODE_ADAT)
|
if (chip->digital_mode == DIGITAL_MODE_ADAT)
|
||||||
return -EAGAIN;
|
return -EAGAIN;
|
||||||
DE_ACT(("Set Gina24 clock to SPDIF\n"));
|
dev_dbg(chip->card->dev, "Set Gina24 clock to SPDIF\n");
|
||||||
control_reg |= GML_SPDIF_CLOCK;
|
control_reg |= GML_SPDIF_CLOCK;
|
||||||
if (clocks_from_dsp & GML_CLOCK_DETECT_BIT_SPDIF96)
|
if (clocks_from_dsp & GML_CLOCK_DETECT_BIT_SPDIF96)
|
||||||
control_reg |= GML_DOUBLE_SPEED_MODE;
|
control_reg |= GML_DOUBLE_SPEED_MODE;
|
||||||
@ -261,21 +263,22 @@ static int set_input_clock(struct echoaudio *chip, u16 clock)
|
|||||||
case ECHO_CLOCK_ADAT:
|
case ECHO_CLOCK_ADAT:
|
||||||
if (chip->digital_mode != DIGITAL_MODE_ADAT)
|
if (chip->digital_mode != DIGITAL_MODE_ADAT)
|
||||||
return -EAGAIN;
|
return -EAGAIN;
|
||||||
DE_ACT(("Set Gina24 clock to ADAT\n"));
|
dev_dbg(chip->card->dev, "Set Gina24 clock to ADAT\n");
|
||||||
control_reg |= GML_ADAT_CLOCK;
|
control_reg |= GML_ADAT_CLOCK;
|
||||||
control_reg &= ~GML_DOUBLE_SPEED_MODE;
|
control_reg &= ~GML_DOUBLE_SPEED_MODE;
|
||||||
break;
|
break;
|
||||||
case ECHO_CLOCK_ESYNC:
|
case ECHO_CLOCK_ESYNC:
|
||||||
DE_ACT(("Set Gina24 clock to ESYNC\n"));
|
dev_dbg(chip->card->dev, "Set Gina24 clock to ESYNC\n");
|
||||||
control_reg |= GML_ESYNC_CLOCK;
|
control_reg |= GML_ESYNC_CLOCK;
|
||||||
control_reg &= ~GML_DOUBLE_SPEED_MODE;
|
control_reg &= ~GML_DOUBLE_SPEED_MODE;
|
||||||
break;
|
break;
|
||||||
case ECHO_CLOCK_ESYNC96:
|
case ECHO_CLOCK_ESYNC96:
|
||||||
DE_ACT(("Set Gina24 clock to ESYNC96\n"));
|
dev_dbg(chip->card->dev, "Set Gina24 clock to ESYNC96\n");
|
||||||
control_reg |= GML_ESYNC_CLOCK | GML_DOUBLE_SPEED_MODE;
|
control_reg |= GML_ESYNC_CLOCK | GML_DOUBLE_SPEED_MODE;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
DE_ACT(("Input clock 0x%x not supported for Gina24\n", clock));
|
dev_err(chip->card->dev,
|
||||||
|
"Input clock 0x%x not supported for Gina24\n", clock);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -304,7 +307,8 @@ static int dsp_set_digital_mode(struct echoaudio *chip, u8 mode)
|
|||||||
incompatible_clock = TRUE;
|
incompatible_clock = TRUE;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
DE_ACT(("Digital mode not supported: %d\n", mode));
|
dev_err(chip->card->dev,
|
||||||
|
"Digital mode not supported: %d\n", mode);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -344,6 +348,7 @@ static int dsp_set_digital_mode(struct echoaudio *chip, u8 mode)
|
|||||||
return err;
|
return err;
|
||||||
chip->digital_mode = mode;
|
chip->digital_mode = mode;
|
||||||
|
|
||||||
DE_ACT(("set_digital_mode to %d\n", chip->digital_mode));
|
dev_dbg(chip->card->dev,
|
||||||
|
"set_digital_mode to %d\n", chip->digital_mode);
|
||||||
return incompatible_clock;
|
return incompatible_clock;
|
||||||
}
|
}
|
||||||
|
@ -38,12 +38,13 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
DE_INIT(("init_hw() - Indigo\n"));
|
dev_dbg(chip->card->dev, "init_hw() - Indigo\n");
|
||||||
if (snd_BUG_ON((subdevice_id & 0xfff0) != INDIGO))
|
if (snd_BUG_ON((subdevice_id & 0xfff0) != INDIGO))
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
if ((err = init_dsp_comm_page(chip))) {
|
if ((err = init_dsp_comm_page(chip))) {
|
||||||
DE_INIT(("init_hw - could not initialize DSP comm page\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"init_hw - could not initialize DSP comm page\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -60,7 +61,7 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
return err;
|
return err;
|
||||||
chip->bad_board = FALSE;
|
chip->bad_board = FALSE;
|
||||||
|
|
||||||
DE_INIT(("init_hw done\n"));
|
dev_dbg(chip->card->dev, "init_hw done\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -109,7 +110,8 @@ static int set_sample_rate(struct echoaudio *chip, u32 rate)
|
|||||||
control_reg = MIA_32000;
|
control_reg = MIA_32000;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
DE_ACT(("set_sample_rate: %d invalid!\n", rate));
|
dev_err(chip->card->dev,
|
||||||
|
"set_sample_rate: %d invalid!\n", rate);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -147,7 +149,8 @@ static int set_vmixer_gain(struct echoaudio *chip, u16 output, u16 pipe,
|
|||||||
index = output * num_pipes_out(chip) + pipe;
|
index = output * num_pipes_out(chip) + pipe;
|
||||||
chip->comm_page->vmixer[index] = gain;
|
chip->comm_page->vmixer[index] = gain;
|
||||||
|
|
||||||
DE_ACT(("set_vmixer_gain: pipe %d, out %d = %d\n", pipe, output, gain));
|
dev_dbg(chip->card->dev,
|
||||||
|
"set_vmixer_gain: pipe %d, out %d = %d\n", pipe, output, gain);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -61,7 +61,8 @@ static int set_sample_rate(struct echoaudio *chip, u32 rate)
|
|||||||
|
|
||||||
control_reg |= clock;
|
control_reg |= clock;
|
||||||
if (control_reg != old_control_reg) {
|
if (control_reg != old_control_reg) {
|
||||||
DE_ACT(("set_sample_rate: %d clock %d\n", rate, clock));
|
dev_dbg(chip->card->dev,
|
||||||
|
"set_sample_rate: %d clock %d\n", rate, clock);
|
||||||
chip->comm_page->control_register = cpu_to_le32(control_reg);
|
chip->comm_page->control_register = cpu_to_le32(control_reg);
|
||||||
chip->sample_rate = rate;
|
chip->sample_rate = rate;
|
||||||
clear_handshake(chip);
|
clear_handshake(chip);
|
||||||
@ -89,7 +90,8 @@ static int set_vmixer_gain(struct echoaudio *chip, u16 output, u16 pipe,
|
|||||||
index = output * num_pipes_out(chip) + pipe;
|
index = output * num_pipes_out(chip) + pipe;
|
||||||
chip->comm_page->vmixer[index] = gain;
|
chip->comm_page->vmixer[index] = gain;
|
||||||
|
|
||||||
DE_ACT(("set_vmixer_gain: pipe %d, out %d = %d\n", pipe, output, gain));
|
dev_dbg(chip->card->dev,
|
||||||
|
"set_vmixer_gain: pipe %d, out %d = %d\n", pipe, output, gain);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -38,12 +38,13 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
DE_INIT(("init_hw() - Indigo DJ\n"));
|
dev_dbg(chip->card->dev, "init_hw() - Indigo DJ\n");
|
||||||
if (snd_BUG_ON((subdevice_id & 0xfff0) != INDIGO_DJ))
|
if (snd_BUG_ON((subdevice_id & 0xfff0) != INDIGO_DJ))
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
if ((err = init_dsp_comm_page(chip))) {
|
if ((err = init_dsp_comm_page(chip))) {
|
||||||
DE_INIT(("init_hw - could not initialize DSP comm page\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"init_hw - could not initialize DSP comm page\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -60,7 +61,7 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
return err;
|
return err;
|
||||||
chip->bad_board = FALSE;
|
chip->bad_board = FALSE;
|
||||||
|
|
||||||
DE_INIT(("init_hw done\n"));
|
dev_dbg(chip->card->dev, "init_hw done\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -109,7 +110,8 @@ static int set_sample_rate(struct echoaudio *chip, u32 rate)
|
|||||||
control_reg = MIA_32000;
|
control_reg = MIA_32000;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
DE_ACT(("set_sample_rate: %d invalid!\n", rate));
|
dev_err(chip->card->dev,
|
||||||
|
"set_sample_rate: %d invalid!\n", rate);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -147,7 +149,8 @@ static int set_vmixer_gain(struct echoaudio *chip, u16 output, u16 pipe,
|
|||||||
index = output * num_pipes_out(chip) + pipe;
|
index = output * num_pipes_out(chip) + pipe;
|
||||||
chip->comm_page->vmixer[index] = gain;
|
chip->comm_page->vmixer[index] = gain;
|
||||||
|
|
||||||
DE_ACT(("set_vmixer_gain: pipe %d, out %d = %d\n", pipe, output, gain));
|
dev_dbg(chip->card->dev,
|
||||||
|
"set_vmixer_gain: pipe %d, out %d = %d\n", pipe, output, gain);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -35,13 +35,14 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
DE_INIT(("init_hw() - Indigo DJx\n"));
|
dev_dbg(chip->card->dev, "init_hw() - Indigo DJx\n");
|
||||||
if (snd_BUG_ON((subdevice_id & 0xfff0) != INDIGO_DJX))
|
if (snd_BUG_ON((subdevice_id & 0xfff0) != INDIGO_DJX))
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
err = init_dsp_comm_page(chip);
|
err = init_dsp_comm_page(chip);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
DE_INIT(("init_hw - could not initialize DSP comm page\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"init_hw - could not initialize DSP comm page\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -59,7 +60,7 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
return err;
|
return err;
|
||||||
chip->bad_board = FALSE;
|
chip->bad_board = FALSE;
|
||||||
|
|
||||||
DE_INIT(("init_hw done\n"));
|
dev_dbg(chip->card->dev, "init_hw done\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -38,12 +38,13 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
DE_INIT(("init_hw() - Indigo IO\n"));
|
dev_dbg(chip->card->dev, "init_hw() - Indigo IO\n");
|
||||||
if (snd_BUG_ON((subdevice_id & 0xfff0) != INDIGO_IO))
|
if (snd_BUG_ON((subdevice_id & 0xfff0) != INDIGO_IO))
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
if ((err = init_dsp_comm_page(chip))) {
|
if ((err = init_dsp_comm_page(chip))) {
|
||||||
DE_INIT(("init_hw - could not initialize DSP comm page\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"init_hw - could not initialize DSP comm page\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -60,7 +61,7 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
return err;
|
return err;
|
||||||
chip->bad_board = FALSE;
|
chip->bad_board = FALSE;
|
||||||
|
|
||||||
DE_INIT(("init_hw done\n"));
|
dev_dbg(chip->card->dev, "init_hw done\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -118,7 +119,8 @@ static int set_vmixer_gain(struct echoaudio *chip, u16 output, u16 pipe,
|
|||||||
index = output * num_pipes_out(chip) + pipe;
|
index = output * num_pipes_out(chip) + pipe;
|
||||||
chip->comm_page->vmixer[index] = gain;
|
chip->comm_page->vmixer[index] = gain;
|
||||||
|
|
||||||
DE_ACT(("set_vmixer_gain: pipe %d, out %d = %d\n", pipe, output, gain));
|
dev_dbg(chip->card->dev,
|
||||||
|
"set_vmixer_gain: pipe %d, out %d = %d\n", pipe, output, gain);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -35,13 +35,14 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
DE_INIT(("init_hw() - Indigo IOx\n"));
|
dev_dbg(chip->card->dev, "init_hw() - Indigo IOx\n");
|
||||||
if (snd_BUG_ON((subdevice_id & 0xfff0) != INDIGO_IOX))
|
if (snd_BUG_ON((subdevice_id & 0xfff0) != INDIGO_IOX))
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
err = init_dsp_comm_page(chip);
|
err = init_dsp_comm_page(chip);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
DE_INIT(("init_hw - could not initialize DSP comm page\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"init_hw - could not initialize DSP comm page\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -59,7 +60,7 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
return err;
|
return err;
|
||||||
chip->bad_board = FALSE;
|
chip->bad_board = FALSE;
|
||||||
|
|
||||||
DE_INIT(("init_hw done\n"));
|
dev_dbg(chip->card->dev, "init_hw done\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -40,12 +40,13 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
DE_INIT(("init_hw() - Layla20\n"));
|
dev_dbg(chip->card->dev, "init_hw() - Layla20\n");
|
||||||
if (snd_BUG_ON((subdevice_id & 0xfff0) != LAYLA20))
|
if (snd_BUG_ON((subdevice_id & 0xfff0) != LAYLA20))
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
if ((err = init_dsp_comm_page(chip))) {
|
if ((err = init_dsp_comm_page(chip))) {
|
||||||
DE_INIT(("init_hw - could not initialize DSP comm page\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"init_hw - could not initialize DSP comm page\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -64,7 +65,7 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
return err;
|
return err;
|
||||||
chip->bad_board = FALSE;
|
chip->bad_board = FALSE;
|
||||||
|
|
||||||
DE_INIT(("init_hw done\n"));
|
dev_dbg(chip->card->dev, "init_hw done\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -121,7 +122,8 @@ static int check_asic_status(struct echoaudio *chip)
|
|||||||
/* The DSP will return a value to indicate whether or not
|
/* The DSP will return a value to indicate whether or not
|
||||||
the ASIC is currently loaded */
|
the ASIC is currently loaded */
|
||||||
if (read_dsp(chip, &asic_status) < 0) {
|
if (read_dsp(chip, &asic_status) < 0) {
|
||||||
DE_ACT(("check_asic_status: failed on read_dsp\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"check_asic_status: failed on read_dsp\n");
|
||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -164,8 +166,8 @@ static int set_sample_rate(struct echoaudio *chip, u32 rate)
|
|||||||
/* Only set the clock for internal mode. Do not return failure,
|
/* Only set the clock for internal mode. Do not return failure,
|
||||||
simply treat it as a non-event. */
|
simply treat it as a non-event. */
|
||||||
if (chip->input_clock != ECHO_CLOCK_INTERNAL) {
|
if (chip->input_clock != ECHO_CLOCK_INTERNAL) {
|
||||||
DE_ACT(("set_sample_rate: Cannot set sample rate - "
|
dev_warn(chip->card->dev,
|
||||||
"clock not set to CLK_CLOCKININTERNAL\n"));
|
"Cannot set sample rate - clock not set to CLK_CLOCKININTERNAL\n");
|
||||||
chip->comm_page->sample_rate = cpu_to_le32(rate);
|
chip->comm_page->sample_rate = cpu_to_le32(rate);
|
||||||
chip->sample_rate = rate;
|
chip->sample_rate = rate;
|
||||||
return 0;
|
return 0;
|
||||||
@ -174,7 +176,7 @@ static int set_sample_rate(struct echoaudio *chip, u32 rate)
|
|||||||
if (wait_handshake(chip))
|
if (wait_handshake(chip))
|
||||||
return -EIO;
|
return -EIO;
|
||||||
|
|
||||||
DE_ACT(("set_sample_rate(%d)\n", rate));
|
dev_dbg(chip->card->dev, "set_sample_rate(%d)\n", rate);
|
||||||
chip->sample_rate = rate;
|
chip->sample_rate = rate;
|
||||||
chip->comm_page->sample_rate = cpu_to_le32(rate);
|
chip->comm_page->sample_rate = cpu_to_le32(rate);
|
||||||
clear_handshake(chip);
|
clear_handshake(chip);
|
||||||
@ -188,29 +190,30 @@ static int set_input_clock(struct echoaudio *chip, u16 clock_source)
|
|||||||
u16 clock;
|
u16 clock;
|
||||||
u32 rate;
|
u32 rate;
|
||||||
|
|
||||||
DE_ACT(("set_input_clock:\n"));
|
dev_dbg(chip->card->dev, "set_input_clock:\n");
|
||||||
rate = 0;
|
rate = 0;
|
||||||
switch (clock_source) {
|
switch (clock_source) {
|
||||||
case ECHO_CLOCK_INTERNAL:
|
case ECHO_CLOCK_INTERNAL:
|
||||||
DE_ACT(("Set Layla20 clock to INTERNAL\n"));
|
dev_dbg(chip->card->dev, "Set Layla20 clock to INTERNAL\n");
|
||||||
rate = chip->sample_rate;
|
rate = chip->sample_rate;
|
||||||
clock = LAYLA20_CLOCK_INTERNAL;
|
clock = LAYLA20_CLOCK_INTERNAL;
|
||||||
break;
|
break;
|
||||||
case ECHO_CLOCK_SPDIF:
|
case ECHO_CLOCK_SPDIF:
|
||||||
DE_ACT(("Set Layla20 clock to SPDIF\n"));
|
dev_dbg(chip->card->dev, "Set Layla20 clock to SPDIF\n");
|
||||||
clock = LAYLA20_CLOCK_SPDIF;
|
clock = LAYLA20_CLOCK_SPDIF;
|
||||||
break;
|
break;
|
||||||
case ECHO_CLOCK_WORD:
|
case ECHO_CLOCK_WORD:
|
||||||
DE_ACT(("Set Layla20 clock to WORD\n"));
|
dev_dbg(chip->card->dev, "Set Layla20 clock to WORD\n");
|
||||||
clock = LAYLA20_CLOCK_WORD;
|
clock = LAYLA20_CLOCK_WORD;
|
||||||
break;
|
break;
|
||||||
case ECHO_CLOCK_SUPER:
|
case ECHO_CLOCK_SUPER:
|
||||||
DE_ACT(("Set Layla20 clock to SUPER\n"));
|
dev_dbg(chip->card->dev, "Set Layla20 clock to SUPER\n");
|
||||||
clock = LAYLA20_CLOCK_SUPER;
|
clock = LAYLA20_CLOCK_SUPER;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
DE_ACT(("Input clock 0x%x not supported for Layla24\n",
|
dev_err(chip->card->dev,
|
||||||
clock_source));
|
"Input clock 0x%x not supported for Layla24\n",
|
||||||
|
clock_source);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
chip->input_clock = clock_source;
|
chip->input_clock = clock_source;
|
||||||
@ -229,7 +232,7 @@ static int set_input_clock(struct echoaudio *chip, u16 clock_source)
|
|||||||
|
|
||||||
static int set_output_clock(struct echoaudio *chip, u16 clock)
|
static int set_output_clock(struct echoaudio *chip, u16 clock)
|
||||||
{
|
{
|
||||||
DE_ACT(("set_output_clock: %d\n", clock));
|
dev_dbg(chip->card->dev, "set_output_clock: %d\n", clock);
|
||||||
switch (clock) {
|
switch (clock) {
|
||||||
case ECHO_CLOCK_SUPER:
|
case ECHO_CLOCK_SUPER:
|
||||||
clock = LAYLA20_OUTPUT_CLOCK_SUPER;
|
clock = LAYLA20_OUTPUT_CLOCK_SUPER;
|
||||||
@ -238,7 +241,7 @@ static int set_output_clock(struct echoaudio *chip, u16 clock)
|
|||||||
clock = LAYLA20_OUTPUT_CLOCK_WORD;
|
clock = LAYLA20_OUTPUT_CLOCK_WORD;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
DE_ACT(("set_output_clock wrong clock\n"));
|
dev_err(chip->card->dev, "set_output_clock wrong clock\n");
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -283,7 +286,7 @@ static int update_flags(struct echoaudio *chip)
|
|||||||
|
|
||||||
static int set_professional_spdif(struct echoaudio *chip, char prof)
|
static int set_professional_spdif(struct echoaudio *chip, char prof)
|
||||||
{
|
{
|
||||||
DE_ACT(("set_professional_spdif %d\n", prof));
|
dev_dbg(chip->card->dev, "set_professional_spdif %d\n", prof);
|
||||||
if (prof)
|
if (prof)
|
||||||
chip->comm_page->flags |=
|
chip->comm_page->flags |=
|
||||||
cpu_to_le32(DSP_FLAG_PROFESSIONAL_SPDIF);
|
cpu_to_le32(DSP_FLAG_PROFESSIONAL_SPDIF);
|
||||||
|
@ -40,12 +40,13 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
DE_INIT(("init_hw() - Layla24\n"));
|
dev_dbg(chip->card->dev, "init_hw() - Layla24\n");
|
||||||
if (snd_BUG_ON((subdevice_id & 0xfff0) != LAYLA24))
|
if (snd_BUG_ON((subdevice_id & 0xfff0) != LAYLA24))
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
if ((err = init_dsp_comm_page(chip))) {
|
if ((err = init_dsp_comm_page(chip))) {
|
||||||
DE_INIT(("init_hw - could not initialize DSP comm page\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"init_hw - could not initialize DSP comm page\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -69,7 +70,7 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
if ((err = init_line_levels(chip)) < 0)
|
if ((err = init_line_levels(chip)) < 0)
|
||||||
return err;
|
return err;
|
||||||
|
|
||||||
DE_INIT(("init_hw done\n"));
|
dev_dbg(chip->card->dev, "init_hw done\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -117,7 +118,7 @@ static int load_asic(struct echoaudio *chip)
|
|||||||
if (chip->asic_loaded)
|
if (chip->asic_loaded)
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
DE_INIT(("load_asic\n"));
|
dev_dbg(chip->card->dev, "load_asic\n");
|
||||||
|
|
||||||
/* Give the DSP a few milliseconds to settle down */
|
/* Give the DSP a few milliseconds to settle down */
|
||||||
mdelay(10);
|
mdelay(10);
|
||||||
@ -151,7 +152,7 @@ static int load_asic(struct echoaudio *chip)
|
|||||||
err = write_control_reg(chip, GML_CONVERTER_ENABLE | GML_48KHZ,
|
err = write_control_reg(chip, GML_CONVERTER_ENABLE | GML_48KHZ,
|
||||||
TRUE);
|
TRUE);
|
||||||
|
|
||||||
DE_INIT(("load_asic() done\n"));
|
dev_dbg(chip->card->dev, "load_asic() done\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -167,8 +168,8 @@ static int set_sample_rate(struct echoaudio *chip, u32 rate)
|
|||||||
|
|
||||||
/* Only set the clock for internal mode. */
|
/* Only set the clock for internal mode. */
|
||||||
if (chip->input_clock != ECHO_CLOCK_INTERNAL) {
|
if (chip->input_clock != ECHO_CLOCK_INTERNAL) {
|
||||||
DE_ACT(("set_sample_rate: Cannot set sample rate - "
|
dev_warn(chip->card->dev,
|
||||||
"clock not set to CLK_CLOCKININTERNAL\n"));
|
"Cannot set sample rate - clock not set to CLK_CLOCKININTERNAL\n");
|
||||||
/* Save the rate anyhow */
|
/* Save the rate anyhow */
|
||||||
chip->comm_page->sample_rate = cpu_to_le32(rate);
|
chip->comm_page->sample_rate = cpu_to_le32(rate);
|
||||||
chip->sample_rate = rate;
|
chip->sample_rate = rate;
|
||||||
@ -241,7 +242,8 @@ static int set_sample_rate(struct echoaudio *chip, u32 rate)
|
|||||||
|
|
||||||
chip->comm_page->sample_rate = cpu_to_le32(rate); /* ignored by the DSP ? */
|
chip->comm_page->sample_rate = cpu_to_le32(rate); /* ignored by the DSP ? */
|
||||||
chip->sample_rate = rate;
|
chip->sample_rate = rate;
|
||||||
DE_ACT(("set_sample_rate: %d clock %d\n", rate, control_reg));
|
dev_dbg(chip->card->dev,
|
||||||
|
"set_sample_rate: %d clock %d\n", rate, control_reg);
|
||||||
|
|
||||||
return write_control_reg(chip, control_reg, FALSE);
|
return write_control_reg(chip, control_reg, FALSE);
|
||||||
}
|
}
|
||||||
@ -260,7 +262,7 @@ static int set_input_clock(struct echoaudio *chip, u16 clock)
|
|||||||
/* Pick the new clock */
|
/* Pick the new clock */
|
||||||
switch (clock) {
|
switch (clock) {
|
||||||
case ECHO_CLOCK_INTERNAL:
|
case ECHO_CLOCK_INTERNAL:
|
||||||
DE_ACT(("Set Layla24 clock to INTERNAL\n"));
|
dev_dbg(chip->card->dev, "Set Layla24 clock to INTERNAL\n");
|
||||||
chip->input_clock = ECHO_CLOCK_INTERNAL;
|
chip->input_clock = ECHO_CLOCK_INTERNAL;
|
||||||
return set_sample_rate(chip, chip->sample_rate);
|
return set_sample_rate(chip, chip->sample_rate);
|
||||||
case ECHO_CLOCK_SPDIF:
|
case ECHO_CLOCK_SPDIF:
|
||||||
@ -269,7 +271,7 @@ static int set_input_clock(struct echoaudio *chip, u16 clock)
|
|||||||
control_reg |= GML_SPDIF_CLOCK;
|
control_reg |= GML_SPDIF_CLOCK;
|
||||||
/* Layla24 doesn't support 96KHz S/PDIF */
|
/* Layla24 doesn't support 96KHz S/PDIF */
|
||||||
control_reg &= ~GML_DOUBLE_SPEED_MODE;
|
control_reg &= ~GML_DOUBLE_SPEED_MODE;
|
||||||
DE_ACT(("Set Layla24 clock to SPDIF\n"));
|
dev_dbg(chip->card->dev, "Set Layla24 clock to SPDIF\n");
|
||||||
break;
|
break;
|
||||||
case ECHO_CLOCK_WORD:
|
case ECHO_CLOCK_WORD:
|
||||||
control_reg |= GML_WORD_CLOCK;
|
control_reg |= GML_WORD_CLOCK;
|
||||||
@ -277,17 +279,18 @@ static int set_input_clock(struct echoaudio *chip, u16 clock)
|
|||||||
control_reg |= GML_DOUBLE_SPEED_MODE;
|
control_reg |= GML_DOUBLE_SPEED_MODE;
|
||||||
else
|
else
|
||||||
control_reg &= ~GML_DOUBLE_SPEED_MODE;
|
control_reg &= ~GML_DOUBLE_SPEED_MODE;
|
||||||
DE_ACT(("Set Layla24 clock to WORD\n"));
|
dev_dbg(chip->card->dev, "Set Layla24 clock to WORD\n");
|
||||||
break;
|
break;
|
||||||
case ECHO_CLOCK_ADAT:
|
case ECHO_CLOCK_ADAT:
|
||||||
if (chip->digital_mode != DIGITAL_MODE_ADAT)
|
if (chip->digital_mode != DIGITAL_MODE_ADAT)
|
||||||
return -EAGAIN;
|
return -EAGAIN;
|
||||||
control_reg |= GML_ADAT_CLOCK;
|
control_reg |= GML_ADAT_CLOCK;
|
||||||
control_reg &= ~GML_DOUBLE_SPEED_MODE;
|
control_reg &= ~GML_DOUBLE_SPEED_MODE;
|
||||||
DE_ACT(("Set Layla24 clock to ADAT\n"));
|
dev_dbg(chip->card->dev, "Set Layla24 clock to ADAT\n");
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
DE_ACT(("Input clock 0x%x not supported for Layla24\n", clock));
|
dev_err(chip->card->dev,
|
||||||
|
"Input clock 0x%x not supported for Layla24\n", clock);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -353,7 +356,8 @@ static int dsp_set_digital_mode(struct echoaudio *chip, u8 mode)
|
|||||||
asic = FW_LAYLA24_2A_ASIC;
|
asic = FW_LAYLA24_2A_ASIC;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
DE_ACT(("Digital mode not supported: %d\n", mode));
|
dev_err(chip->card->dev,
|
||||||
|
"Digital mode not supported: %d\n", mode);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -393,6 +397,6 @@ static int dsp_set_digital_mode(struct echoaudio *chip, u8 mode)
|
|||||||
return err;
|
return err;
|
||||||
chip->digital_mode = mode;
|
chip->digital_mode = mode;
|
||||||
|
|
||||||
DE_ACT(("set_digital_mode to %d\n", mode));
|
dev_dbg(chip->card->dev, "set_digital_mode to %d\n", mode);
|
||||||
return incompatible_clock;
|
return incompatible_clock;
|
||||||
}
|
}
|
||||||
|
@ -41,12 +41,13 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
DE_INIT(("init_hw() - Mia\n"));
|
dev_dbg(chip->card->dev, "init_hw() - Mia\n");
|
||||||
if (snd_BUG_ON((subdevice_id & 0xfff0) != MIA))
|
if (snd_BUG_ON((subdevice_id & 0xfff0) != MIA))
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
if ((err = init_dsp_comm_page(chip))) {
|
if ((err = init_dsp_comm_page(chip))) {
|
||||||
DE_INIT(("init_hw - could not initialize DSP comm page\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"init_hw - could not initialize DSP comm page\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -66,7 +67,7 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
return err;
|
return err;
|
||||||
chip->bad_board = FALSE;
|
chip->bad_board = FALSE;
|
||||||
|
|
||||||
DE_INIT(("init_hw done\n"));
|
dev_dbg(chip->card->dev, "init_hw done\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -126,7 +127,8 @@ static int set_sample_rate(struct echoaudio *chip, u32 rate)
|
|||||||
control_reg = MIA_32000;
|
control_reg = MIA_32000;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
DE_ACT(("set_sample_rate: %d invalid!\n", rate));
|
dev_err(chip->card->dev,
|
||||||
|
"set_sample_rate: %d invalid!\n", rate);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -153,7 +155,7 @@ static int set_sample_rate(struct echoaudio *chip, u32 rate)
|
|||||||
|
|
||||||
static int set_input_clock(struct echoaudio *chip, u16 clock)
|
static int set_input_clock(struct echoaudio *chip, u16 clock)
|
||||||
{
|
{
|
||||||
DE_ACT(("set_input_clock(%d)\n", clock));
|
dev_dbg(chip->card->dev, "set_input_clock(%d)\n", clock);
|
||||||
if (snd_BUG_ON(clock != ECHO_CLOCK_INTERNAL &&
|
if (snd_BUG_ON(clock != ECHO_CLOCK_INTERNAL &&
|
||||||
clock != ECHO_CLOCK_SPDIF))
|
clock != ECHO_CLOCK_SPDIF))
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
@ -181,7 +183,8 @@ static int set_vmixer_gain(struct echoaudio *chip, u16 output, u16 pipe,
|
|||||||
index = output * num_pipes_out(chip) + pipe;
|
index = output * num_pipes_out(chip) + pipe;
|
||||||
chip->comm_page->vmixer[index] = gain;
|
chip->comm_page->vmixer[index] = gain;
|
||||||
|
|
||||||
DE_ACT(("set_vmixer_gain: pipe %d, out %d = %d\n", pipe, output, gain));
|
dev_dbg(chip->card->dev,
|
||||||
|
"set_vmixer_gain: pipe %d, out %d = %d\n", pipe, output, gain);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -211,7 +214,7 @@ static int update_flags(struct echoaudio *chip)
|
|||||||
|
|
||||||
static int set_professional_spdif(struct echoaudio *chip, char prof)
|
static int set_professional_spdif(struct echoaudio *chip, char prof)
|
||||||
{
|
{
|
||||||
DE_ACT(("set_professional_spdif %d\n", prof));
|
dev_dbg(chip->card->dev, "set_professional_spdif %d\n", prof);
|
||||||
if (prof)
|
if (prof)
|
||||||
chip->comm_page->flags |=
|
chip->comm_page->flags |=
|
||||||
cpu_to_le32(DSP_FLAG_PROFESSIONAL_SPDIF);
|
cpu_to_le32(DSP_FLAG_PROFESSIONAL_SPDIF);
|
||||||
|
@ -36,7 +36,7 @@
|
|||||||
/* Start and stop Midi input */
|
/* Start and stop Midi input */
|
||||||
static int enable_midi_input(struct echoaudio *chip, char enable)
|
static int enable_midi_input(struct echoaudio *chip, char enable)
|
||||||
{
|
{
|
||||||
DE_MID(("enable_midi_input(%d)\n", enable));
|
dev_dbg(chip->card->dev, "enable_midi_input(%d)\n", enable);
|
||||||
|
|
||||||
if (wait_handshake(chip))
|
if (wait_handshake(chip))
|
||||||
return -EIO;
|
return -EIO;
|
||||||
@ -74,7 +74,7 @@ static int write_midi(struct echoaudio *chip, u8 *data, int bytes)
|
|||||||
chip->comm_page->midi_out_free_count = 0;
|
chip->comm_page->midi_out_free_count = 0;
|
||||||
clear_handshake(chip);
|
clear_handshake(chip);
|
||||||
send_vector(chip, DSP_VC_MIDI_WRITE);
|
send_vector(chip, DSP_VC_MIDI_WRITE);
|
||||||
DE_MID(("write_midi: %d\n", bytes));
|
dev_dbg(chip->card->dev, "write_midi: %d\n", bytes);
|
||||||
return bytes;
|
return bytes;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -157,7 +157,7 @@ static int snd_echo_midi_input_open(struct snd_rawmidi_substream *substream)
|
|||||||
struct echoaudio *chip = substream->rmidi->private_data;
|
struct echoaudio *chip = substream->rmidi->private_data;
|
||||||
|
|
||||||
chip->midi_in = substream;
|
chip->midi_in = substream;
|
||||||
DE_MID(("rawmidi_iopen\n"));
|
dev_dbg(chip->card->dev, "rawmidi_iopen\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -183,7 +183,7 @@ static int snd_echo_midi_input_close(struct snd_rawmidi_substream *substream)
|
|||||||
struct echoaudio *chip = substream->rmidi->private_data;
|
struct echoaudio *chip = substream->rmidi->private_data;
|
||||||
|
|
||||||
chip->midi_in = NULL;
|
chip->midi_in = NULL;
|
||||||
DE_MID(("rawmidi_iclose\n"));
|
dev_dbg(chip->card->dev, "rawmidi_iclose\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -196,7 +196,7 @@ static int snd_echo_midi_output_open(struct snd_rawmidi_substream *substream)
|
|||||||
chip->tinuse = 0;
|
chip->tinuse = 0;
|
||||||
chip->midi_full = 0;
|
chip->midi_full = 0;
|
||||||
chip->midi_out = substream;
|
chip->midi_out = substream;
|
||||||
DE_MID(("rawmidi_oopen\n"));
|
dev_dbg(chip->card->dev, "rawmidi_open\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -209,7 +209,7 @@ static void snd_echo_midi_output_write(unsigned long data)
|
|||||||
int bytes, sent, time;
|
int bytes, sent, time;
|
||||||
unsigned char buf[MIDI_OUT_BUFFER_SIZE - 1];
|
unsigned char buf[MIDI_OUT_BUFFER_SIZE - 1];
|
||||||
|
|
||||||
DE_MID(("snd_echo_midi_output_write\n"));
|
dev_dbg(chip->card->dev, "snd_echo_midi_output_write\n");
|
||||||
/* No interrupts are involved: we have to check at regular intervals
|
/* No interrupts are involved: we have to check at regular intervals
|
||||||
if the card's output buffer has room for new data. */
|
if the card's output buffer has room for new data. */
|
||||||
sent = bytes = 0;
|
sent = bytes = 0;
|
||||||
@ -218,7 +218,7 @@ static void snd_echo_midi_output_write(unsigned long data)
|
|||||||
if (!snd_rawmidi_transmit_empty(chip->midi_out)) {
|
if (!snd_rawmidi_transmit_empty(chip->midi_out)) {
|
||||||
bytes = snd_rawmidi_transmit_peek(chip->midi_out, buf,
|
bytes = snd_rawmidi_transmit_peek(chip->midi_out, buf,
|
||||||
MIDI_OUT_BUFFER_SIZE - 1);
|
MIDI_OUT_BUFFER_SIZE - 1);
|
||||||
DE_MID(("Try to send %d bytes...\n", bytes));
|
dev_dbg(chip->card->dev, "Try to send %d bytes...\n", bytes);
|
||||||
sent = write_midi(chip, buf, bytes);
|
sent = write_midi(chip, buf, bytes);
|
||||||
if (sent < 0) {
|
if (sent < 0) {
|
||||||
dev_err(chip->card->dev,
|
dev_err(chip->card->dev,
|
||||||
@ -227,12 +227,12 @@ static void snd_echo_midi_output_write(unsigned long data)
|
|||||||
sent = 9000;
|
sent = 9000;
|
||||||
chip->midi_full = 1;
|
chip->midi_full = 1;
|
||||||
} else if (sent > 0) {
|
} else if (sent > 0) {
|
||||||
DE_MID(("%d bytes sent\n", sent));
|
dev_dbg(chip->card->dev, "%d bytes sent\n", sent);
|
||||||
snd_rawmidi_transmit_ack(chip->midi_out, sent);
|
snd_rawmidi_transmit_ack(chip->midi_out, sent);
|
||||||
} else {
|
} else {
|
||||||
/* Buffer is full. DSP's internal buffer is 64 (128 ?)
|
/* Buffer is full. DSP's internal buffer is 64 (128 ?)
|
||||||
bytes long. Let's wait until half of them are sent */
|
bytes long. Let's wait until half of them are sent */
|
||||||
DE_MID(("Full\n"));
|
dev_dbg(chip->card->dev, "Full\n");
|
||||||
sent = 32;
|
sent = 32;
|
||||||
chip->midi_full = 1;
|
chip->midi_full = 1;
|
||||||
}
|
}
|
||||||
@ -244,7 +244,8 @@ static void snd_echo_midi_output_write(unsigned long data)
|
|||||||
sent */
|
sent */
|
||||||
time = (sent << 3) / 25 + 1; /* 8/25=0.32ms to send a byte */
|
time = (sent << 3) / 25 + 1; /* 8/25=0.32ms to send a byte */
|
||||||
mod_timer(&chip->timer, jiffies + (time * HZ + 999) / 1000);
|
mod_timer(&chip->timer, jiffies + (time * HZ + 999) / 1000);
|
||||||
DE_MID(("Timer armed(%d)\n", ((time * HZ + 999) / 1000)));
|
dev_dbg(chip->card->dev,
|
||||||
|
"Timer armed(%d)\n", ((time * HZ + 999) / 1000));
|
||||||
}
|
}
|
||||||
spin_unlock_irqrestore(&chip->lock, flags);
|
spin_unlock_irqrestore(&chip->lock, flags);
|
||||||
}
|
}
|
||||||
@ -256,7 +257,7 @@ static void snd_echo_midi_output_trigger(struct snd_rawmidi_substream *substream
|
|||||||
{
|
{
|
||||||
struct echoaudio *chip = substream->rmidi->private_data;
|
struct echoaudio *chip = substream->rmidi->private_data;
|
||||||
|
|
||||||
DE_MID(("snd_echo_midi_output_trigger(%d)\n", up));
|
dev_dbg(chip->card->dev, "snd_echo_midi_output_trigger(%d)\n", up);
|
||||||
spin_lock_irq(&chip->lock);
|
spin_lock_irq(&chip->lock);
|
||||||
if (up) {
|
if (up) {
|
||||||
if (!chip->tinuse) {
|
if (!chip->tinuse) {
|
||||||
@ -270,7 +271,7 @@ static void snd_echo_midi_output_trigger(struct snd_rawmidi_substream *substream
|
|||||||
chip->tinuse = 0;
|
chip->tinuse = 0;
|
||||||
spin_unlock_irq(&chip->lock);
|
spin_unlock_irq(&chip->lock);
|
||||||
del_timer_sync(&chip->timer);
|
del_timer_sync(&chip->timer);
|
||||||
DE_MID(("Timer removed\n"));
|
dev_dbg(chip->card->dev, "Timer removed\n");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -287,7 +288,7 @@ static int snd_echo_midi_output_close(struct snd_rawmidi_substream *substream)
|
|||||||
struct echoaudio *chip = substream->rmidi->private_data;
|
struct echoaudio *chip = substream->rmidi->private_data;
|
||||||
|
|
||||||
chip->midi_out = NULL;
|
chip->midi_out = NULL;
|
||||||
DE_MID(("rawmidi_oclose\n"));
|
dev_dbg(chip->card->dev, "rawmidi_oclose\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -327,6 +328,6 @@ static int snd_echo_midi_create(struct snd_card *card,
|
|||||||
|
|
||||||
chip->rmidi->info_flags |= SNDRV_RAWMIDI_INFO_OUTPUT |
|
chip->rmidi->info_flags |= SNDRV_RAWMIDI_INFO_OUTPUT |
|
||||||
SNDRV_RAWMIDI_INFO_INPUT | SNDRV_RAWMIDI_INFO_DUPLEX;
|
SNDRV_RAWMIDI_INFO_INPUT | SNDRV_RAWMIDI_INFO_DUPLEX;
|
||||||
DE_INIT(("MIDI ok\n"));
|
dev_dbg(chip->card->dev, "MIDI ok\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -41,12 +41,13 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
DE_INIT(("init_hw() - Mona\n"));
|
dev_dbg(chip->card->dev, "init_hw() - Mona\n");
|
||||||
if (snd_BUG_ON((subdevice_id & 0xfff0) != MONA))
|
if (snd_BUG_ON((subdevice_id & 0xfff0) != MONA))
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
if ((err = init_dsp_comm_page(chip))) {
|
if ((err = init_dsp_comm_page(chip))) {
|
||||||
DE_INIT(("init_hw - could not initialize DSP comm page\n"));
|
dev_err(chip->card->dev,
|
||||||
|
"init_hw - could not initialize DSP comm page\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -71,7 +72,7 @@ static int init_hw(struct echoaudio *chip, u16 device_id, u16 subdevice_id)
|
|||||||
return err;
|
return err;
|
||||||
chip->bad_board = FALSE;
|
chip->bad_board = FALSE;
|
||||||
|
|
||||||
DE_INIT(("init_hw done\n"));
|
dev_dbg(chip->card->dev, "init_hw done\n");
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -202,8 +203,8 @@ static int set_sample_rate(struct echoaudio *chip, u32 rate)
|
|||||||
|
|
||||||
/* Only set the clock for internal mode. */
|
/* Only set the clock for internal mode. */
|
||||||
if (chip->input_clock != ECHO_CLOCK_INTERNAL) {
|
if (chip->input_clock != ECHO_CLOCK_INTERNAL) {
|
||||||
DE_ACT(("set_sample_rate: Cannot set sample rate - "
|
dev_dbg(chip->card->dev,
|
||||||
"clock not set to CLK_CLOCKININTERNAL\n"));
|
"Cannot set sample rate - clock not set to CLK_CLOCKININTERNAL\n");
|
||||||
/* Save the rate anyhow */
|
/* Save the rate anyhow */
|
||||||
chip->comm_page->sample_rate = cpu_to_le32(rate);
|
chip->comm_page->sample_rate = cpu_to_le32(rate);
|
||||||
chip->sample_rate = rate;
|
chip->sample_rate = rate;
|
||||||
@ -279,7 +280,8 @@ static int set_sample_rate(struct echoaudio *chip, u32 rate)
|
|||||||
clock = GML_8KHZ;
|
clock = GML_8KHZ;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
DE_ACT(("set_sample_rate: %d invalid!\n", rate));
|
dev_err(chip->card->dev,
|
||||||
|
"set_sample_rate: %d invalid!\n", rate);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -287,7 +289,8 @@ static int set_sample_rate(struct echoaudio *chip, u32 rate)
|
|||||||
|
|
||||||
chip->comm_page->sample_rate = cpu_to_le32(rate); /* ignored by the DSP */
|
chip->comm_page->sample_rate = cpu_to_le32(rate); /* ignored by the DSP */
|
||||||
chip->sample_rate = rate;
|
chip->sample_rate = rate;
|
||||||
DE_ACT(("set_sample_rate: %d clock %d\n", rate, clock));
|
dev_dbg(chip->card->dev,
|
||||||
|
"set_sample_rate: %d clock %d\n", rate, clock);
|
||||||
|
|
||||||
return write_control_reg(chip, control_reg, force_write);
|
return write_control_reg(chip, control_reg, force_write);
|
||||||
}
|
}
|
||||||
@ -299,7 +302,7 @@ static int set_input_clock(struct echoaudio *chip, u16 clock)
|
|||||||
u32 control_reg, clocks_from_dsp;
|
u32 control_reg, clocks_from_dsp;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
DE_ACT(("set_input_clock:\n"));
|
dev_dbg(chip->card->dev, "set_input_clock:\n");
|
||||||
|
|
||||||
/* Prevent two simultaneous calls to switch_asic() */
|
/* Prevent two simultaneous calls to switch_asic() */
|
||||||
if (atomic_read(&chip->opencount))
|
if (atomic_read(&chip->opencount))
|
||||||
@ -312,7 +315,7 @@ static int set_input_clock(struct echoaudio *chip, u16 clock)
|
|||||||
|
|
||||||
switch (clock) {
|
switch (clock) {
|
||||||
case ECHO_CLOCK_INTERNAL:
|
case ECHO_CLOCK_INTERNAL:
|
||||||
DE_ACT(("Set Mona clock to INTERNAL\n"));
|
dev_dbg(chip->card->dev, "Set Mona clock to INTERNAL\n");
|
||||||
chip->input_clock = ECHO_CLOCK_INTERNAL;
|
chip->input_clock = ECHO_CLOCK_INTERNAL;
|
||||||
return set_sample_rate(chip, chip->sample_rate);
|
return set_sample_rate(chip, chip->sample_rate);
|
||||||
case ECHO_CLOCK_SPDIF:
|
case ECHO_CLOCK_SPDIF:
|
||||||
@ -324,7 +327,7 @@ static int set_input_clock(struct echoaudio *chip, u16 clock)
|
|||||||
spin_lock_irq(&chip->lock);
|
spin_lock_irq(&chip->lock);
|
||||||
if (err < 0)
|
if (err < 0)
|
||||||
return err;
|
return err;
|
||||||
DE_ACT(("Set Mona clock to SPDIF\n"));
|
dev_dbg(chip->card->dev, "Set Mona clock to SPDIF\n");
|
||||||
control_reg |= GML_SPDIF_CLOCK;
|
control_reg |= GML_SPDIF_CLOCK;
|
||||||
if (clocks_from_dsp & GML_CLOCK_DETECT_BIT_SPDIF96)
|
if (clocks_from_dsp & GML_CLOCK_DETECT_BIT_SPDIF96)
|
||||||
control_reg |= GML_DOUBLE_SPEED_MODE;
|
control_reg |= GML_DOUBLE_SPEED_MODE;
|
||||||
@ -332,7 +335,7 @@ static int set_input_clock(struct echoaudio *chip, u16 clock)
|
|||||||
control_reg &= ~GML_DOUBLE_SPEED_MODE;
|
control_reg &= ~GML_DOUBLE_SPEED_MODE;
|
||||||
break;
|
break;
|
||||||
case ECHO_CLOCK_WORD:
|
case ECHO_CLOCK_WORD:
|
||||||
DE_ACT(("Set Mona clock to WORD\n"));
|
dev_dbg(chip->card->dev, "Set Mona clock to WORD\n");
|
||||||
spin_unlock_irq(&chip->lock);
|
spin_unlock_irq(&chip->lock);
|
||||||
err = switch_asic(chip, clocks_from_dsp &
|
err = switch_asic(chip, clocks_from_dsp &
|
||||||
GML_CLOCK_DETECT_BIT_WORD96);
|
GML_CLOCK_DETECT_BIT_WORD96);
|
||||||
@ -346,14 +349,15 @@ static int set_input_clock(struct echoaudio *chip, u16 clock)
|
|||||||
control_reg &= ~GML_DOUBLE_SPEED_MODE;
|
control_reg &= ~GML_DOUBLE_SPEED_MODE;
|
||||||
break;
|
break;
|
||||||
case ECHO_CLOCK_ADAT:
|
case ECHO_CLOCK_ADAT:
|
||||||
DE_ACT(("Set Mona clock to ADAT\n"));
|
dev_dbg(chip->card->dev, "Set Mona clock to ADAT\n");
|
||||||
if (chip->digital_mode != DIGITAL_MODE_ADAT)
|
if (chip->digital_mode != DIGITAL_MODE_ADAT)
|
||||||
return -EAGAIN;
|
return -EAGAIN;
|
||||||
control_reg |= GML_ADAT_CLOCK;
|
control_reg |= GML_ADAT_CLOCK;
|
||||||
control_reg &= ~GML_DOUBLE_SPEED_MODE;
|
control_reg &= ~GML_DOUBLE_SPEED_MODE;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
DE_ACT(("Input clock 0x%x not supported for Mona\n", clock));
|
dev_err(chip->card->dev,
|
||||||
|
"Input clock 0x%x not supported for Mona\n", clock);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -381,7 +385,8 @@ static int dsp_set_digital_mode(struct echoaudio *chip, u8 mode)
|
|||||||
incompatible_clock = TRUE;
|
incompatible_clock = TRUE;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
DE_ACT(("Digital mode not supported: %d\n", mode));
|
dev_err(chip->card->dev,
|
||||||
|
"Digital mode not supported: %d\n", mode);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -422,6 +427,6 @@ static int dsp_set_digital_mode(struct echoaudio *chip, u8 mode)
|
|||||||
return err;
|
return err;
|
||||||
chip->digital_mode = mode;
|
chip->digital_mode = mode;
|
||||||
|
|
||||||
DE_ACT(("set_digital_mode to %d\n", mode));
|
dev_dbg(chip->card->dev, "set_digital_mode to %d\n", mode);
|
||||||
return incompatible_clock;
|
return incompatible_clock;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user