Commit 51c29fd2 authored by Takashi Sakamoto's avatar Takashi Sakamoto Committed by Takashi Iwai

ALSA: firewire-lib: rename parameter setting function for AM824 with FDF field

The value of FDF field in CIP header is protocol-dependent. Thus, it's
better to allow data block processing layer to decide the value in any
timing.

In AM824 data format, the value of FDF field in CIP header indicates
N-flag and Nominal Sampling Frequency Code (sfc). The N-flag is for
switching 'Clock-based rate control mode' and 'Command-based rate control
mode'. In our implementation, 'Clock-based rate control mode' is just
supported. Therefore, When sampling transfer frequency is decided, then
the FDF can be set.

This commit replaces 'amdtp_stream_set_parameters' with
'amdtp_am824_set_parameters' to set the FDF. This is the same timing
to decide the ration between the number of data blocks and the number of
PCM frames.
Signed-off-by: default avatarTakashi Sakamoto <o-takashi@sakamocchi.jp>
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent 5955815e
...@@ -10,6 +10,48 @@ ...@@ -10,6 +10,48 @@
#define CIP_FMT_AM 0x10 #define CIP_FMT_AM 0x10
/* "Clock-based rate control mode" is just supported. */
#define AMDTP_FDF_AM824 0x00
/**
* amdtp_am824_set_parameters - set stream parameters
* @s: the AMDTP stream to configure
* @rate: the sample rate
* @pcm_channels: the number of PCM samples in each data block, to be encoded
* as AM824 multi-bit linear audio
* @midi_ports: the number of MIDI ports (i.e., MPX-MIDI Data Channels)
* @double_pcm_frames: one data block transfers two PCM frames
*
* The parameters must be set before the stream is started, and must not be
* changed while the stream is running.
*/
int amdtp_am824_set_parameters(struct amdtp_stream *s, unsigned int rate,
unsigned int pcm_channels,
unsigned int midi_ports,
bool double_pcm_frames)
{
int err;
err = amdtp_stream_set_parameters(s, rate, pcm_channels, midi_ports);
if (err < 0)
return err;
s->fdf = AMDTP_FDF_AM824 | s->sfc;
/*
* In IEC 61883-6, one data block represents one event. In ALSA, one
* event equals to one PCM frame. But Dice has a quirk at higher
* sampling rate to transfer two PCM frames in one data block.
*/
if (double_pcm_frames)
s->frame_multiplier = 2;
else
s->frame_multiplier = 1;
return 0;
}
EXPORT_SYMBOL_GPL(amdtp_am824_set_parameters);
/** /**
* amdtp_am824_init - initialize an AMDTP stream structure to handle AM824 * amdtp_am824_init - initialize an AMDTP stream structure to handle AM824
* data block * data block
......
...@@ -3,6 +3,11 @@ ...@@ -3,6 +3,11 @@
#include "amdtp-stream.h" #include "amdtp-stream.h"
int amdtp_am824_set_parameters(struct amdtp_stream *s, unsigned int rate,
unsigned int pcm_channels,
unsigned int midi_ports,
bool double_pcm_frames);
int amdtp_am824_init(struct amdtp_stream *s, struct fw_unit *unit, int amdtp_am824_init(struct amdtp_stream *s, struct fw_unit *unit,
enum amdtp_stream_direction dir, enum cip_flags flags); enum amdtp_stream_direction dir, enum cip_flags flags);
#endif #endif
...@@ -54,12 +54,8 @@ ...@@ -54,12 +54,8 @@
#define CIP_SYT_MASK 0x0000ffff #define CIP_SYT_MASK 0x0000ffff
#define CIP_SYT_NO_INFO 0xffff #define CIP_SYT_NO_INFO 0xffff
/* /* Audio and Music transfer protocol specific parameters */
* Audio and Music transfer protocol specific parameters
* only "Clock-based rate control mode" is supported
*/
#define CIP_FMT_AM 0x10 #define CIP_FMT_AM 0x10
#define AMDTP_FDF_AM824 0x00
#define AMDTP_FDF_NO_DATA 0xff #define AMDTP_FDF_NO_DATA 0xff
/* TODO: make these configurable */ /* TODO: make these configurable */
...@@ -204,8 +200,7 @@ EXPORT_SYMBOL(amdtp_stream_add_pcm_hw_constraints); ...@@ -204,8 +200,7 @@ EXPORT_SYMBOL(amdtp_stream_add_pcm_hw_constraints);
int amdtp_stream_set_parameters(struct amdtp_stream *s, int amdtp_stream_set_parameters(struct amdtp_stream *s,
unsigned int rate, unsigned int rate,
unsigned int pcm_channels, unsigned int pcm_channels,
unsigned int midi_ports, unsigned int midi_ports)
bool double_pcm_frames)
{ {
unsigned int i, sfc, midi_channels; unsigned int i, sfc, midi_channels;
...@@ -228,18 +223,6 @@ int amdtp_stream_set_parameters(struct amdtp_stream *s, ...@@ -228,18 +223,6 @@ int amdtp_stream_set_parameters(struct amdtp_stream *s,
s->data_block_quadlets = s->pcm_channels + midi_channels; s->data_block_quadlets = s->pcm_channels + midi_channels;
s->midi_ports = midi_ports; s->midi_ports = midi_ports;
s->fdf = AMDTP_FDF_AM824 | s->sfc;
/*
* In IEC 61883-6, one data block represents one event. In ALSA, one
* event equals to one PCM frame. But Dice has a quirk at higher
* sampling rate to transfer two PCM frames in one data block.
*/
if (double_pcm_frames)
s->frame_multiplier = 2;
else
s->frame_multiplier = 1;
s->syt_interval = amdtp_syt_intervals[sfc]; s->syt_interval = amdtp_syt_intervals[sfc];
/* default buffering in the device */ /* default buffering in the device */
......
...@@ -181,8 +181,7 @@ void amdtp_stream_destroy(struct amdtp_stream *s); ...@@ -181,8 +181,7 @@ void amdtp_stream_destroy(struct amdtp_stream *s);
int amdtp_stream_set_parameters(struct amdtp_stream *s, int amdtp_stream_set_parameters(struct amdtp_stream *s,
unsigned int rate, unsigned int rate,
unsigned int pcm_channels, unsigned int pcm_channels,
unsigned int midi_ports, unsigned int midi_ports);
bool double_pcm_frames);
unsigned int amdtp_stream_get_max_payload(struct amdtp_stream *s); unsigned int amdtp_stream_get_max_payload(struct amdtp_stream *s);
int amdtp_stream_start(struct amdtp_stream *s, int channel, int speed); int amdtp_stream_start(struct amdtp_stream *s, int channel, int speed);
......
...@@ -427,7 +427,7 @@ make_both_connections(struct snd_bebob *bebob, unsigned int rate) ...@@ -427,7 +427,7 @@ make_both_connections(struct snd_bebob *bebob, unsigned int rate)
index = get_formation_index(rate); index = get_formation_index(rate);
pcm_channels = bebob->tx_stream_formations[index].pcm; pcm_channels = bebob->tx_stream_formations[index].pcm;
midi_channels = bebob->tx_stream_formations[index].midi; midi_channels = bebob->tx_stream_formations[index].midi;
err = amdtp_stream_set_parameters(&bebob->tx_stream, rate, err = amdtp_am824_set_parameters(&bebob->tx_stream, rate,
pcm_channels, midi_channels * 8, pcm_channels, midi_channels * 8,
false); false);
if (err < 0) if (err < 0)
...@@ -435,7 +435,7 @@ make_both_connections(struct snd_bebob *bebob, unsigned int rate) ...@@ -435,7 +435,7 @@ make_both_connections(struct snd_bebob *bebob, unsigned int rate)
pcm_channels = bebob->rx_stream_formations[index].pcm; pcm_channels = bebob->rx_stream_formations[index].pcm;
midi_channels = bebob->rx_stream_formations[index].midi; midi_channels = bebob->rx_stream_formations[index].midi;
err = amdtp_stream_set_parameters(&bebob->rx_stream, rate, err = amdtp_am824_set_parameters(&bebob->rx_stream, rate,
pcm_channels, midi_channels * 8, pcm_channels, midi_channels * 8,
false); false);
if (err < 0) if (err < 0)
......
...@@ -132,8 +132,8 @@ static int start_stream(struct snd_dice *dice, struct amdtp_stream *stream, ...@@ -132,8 +132,8 @@ static int start_stream(struct snd_dice *dice, struct amdtp_stream *stream,
pcm_chs *= 2; pcm_chs *= 2;
} }
err = amdtp_stream_set_parameters(stream, rate, pcm_chs, midi_ports, err = amdtp_am824_set_parameters(stream, rate, pcm_chs, midi_ports,
false); double_pcm_frames);
if (err < 0) if (err < 0)
goto end; goto end;
......
...@@ -73,7 +73,7 @@ start_stream(struct snd_efw *efw, struct amdtp_stream *stream, ...@@ -73,7 +73,7 @@ start_stream(struct snd_efw *efw, struct amdtp_stream *stream,
midi_ports = efw->midi_in_ports; midi_ports = efw->midi_in_ports;
} }
err = amdtp_stream_set_parameters(stream, sampling_rate, err = amdtp_am824_set_parameters(stream, sampling_rate,
pcm_channels, midi_ports, false); pcm_channels, midi_ports, false);
if (err < 0) if (err < 0)
goto end; goto end;
......
...@@ -155,8 +155,8 @@ static int start_stream(struct snd_oxfw *oxfw, struct amdtp_stream *stream, ...@@ -155,8 +155,8 @@ static int start_stream(struct snd_oxfw *oxfw, struct amdtp_stream *stream,
err = -EINVAL; err = -EINVAL;
goto end; goto end;
} }
err = amdtp_stream_set_parameters(stream, rate, err = amdtp_am824_set_parameters(stream, rate, pcm_channels, midi_ports,
pcm_channels, midi_ports, false); false);
if (err < 0) if (err < 0)
goto end; goto end;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment