Commit 62f00e40 authored by Takashi Sakamoto's avatar Takashi Sakamoto Committed by Takashi Iwai

ALSA: firewire-lib: enable the same feature as CIP_SKIP_INIT_DBC_CHECK flag

In former commit, drivers in ALSA firewire stack always starts IT context
before IR context. If IR context starts after packets are transmitted by
peer unit, packet discontinuity may be detected because the context starts
in the middle of packet streaming. This situation is rare because IT
context usually starts immediately. However, it's better to solve this
issue. This is suppressed with CIP_SKIP_INIT_DBC_CHECK flag.

This commit enables the same feature as CIP_SKIP_INIT_DBC_CHECK.
Signed-off-by: default avatarTakashi Sakamoto <o-takashi@sakamocchi.jp>
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent 390a1512
...@@ -723,8 +723,7 @@ int amdtp_stream_start(struct amdtp_stream *s, int channel, int speed) ...@@ -723,8 +723,7 @@ int amdtp_stream_start(struct amdtp_stream *s, int channel, int speed)
goto err_unlock; goto err_unlock;
} }
if (s->direction == AMDTP_IN_STREAM && if (s->direction == AMDTP_IN_STREAM)
s->flags & CIP_SKIP_INIT_DBC_CHECK)
s->data_block_counter = UINT_MAX; s->data_block_counter = UINT_MAX;
else else
s->data_block_counter = 0; s->data_block_counter = 0;
......
...@@ -24,8 +24,6 @@ ...@@ -24,8 +24,6 @@
* The value of data_block_quadlets is used instead of reported value. * The value of data_block_quadlets is used instead of reported value.
* @CIP_SKIP_DBC_ZERO_CHECK: Only for in-stream. Packets with zero in dbc is * @CIP_SKIP_DBC_ZERO_CHECK: Only for in-stream. Packets with zero in dbc is
* skipped for detecting discontinuity. * skipped for detecting discontinuity.
* @CIP_SKIP_INIT_DBC_CHECK: Only for in-stream. The value of dbc in first
* packet is not continuous from an initial value.
* @CIP_EMPTY_HAS_WRONG_DBC: Only for in-stream. The value of dbc in empty * @CIP_EMPTY_HAS_WRONG_DBC: Only for in-stream. The value of dbc in empty
* packet is wrong but the others are correct. * packet is wrong but the others are correct.
* @CIP_JUMBO_PAYLOAD: Only for in-stream. The number of data blocks in an * @CIP_JUMBO_PAYLOAD: Only for in-stream. The number of data blocks in an
...@@ -39,9 +37,8 @@ enum cip_flags { ...@@ -39,9 +37,8 @@ enum cip_flags {
CIP_DBC_IS_END_EVENT = 0x04, CIP_DBC_IS_END_EVENT = 0x04,
CIP_WRONG_DBS = 0x08, CIP_WRONG_DBS = 0x08,
CIP_SKIP_DBC_ZERO_CHECK = 0x10, CIP_SKIP_DBC_ZERO_CHECK = 0x10,
CIP_SKIP_INIT_DBC_CHECK = 0x20, CIP_EMPTY_HAS_WRONG_DBC = 0x20,
CIP_EMPTY_HAS_WRONG_DBC = 0x40, CIP_JUMBO_PAYLOAD = 0x40,
CIP_JUMBO_PAYLOAD = 0x80,
}; };
/** /**
......
...@@ -526,8 +526,6 @@ int snd_bebob_stream_init_duplex(struct snd_bebob *bebob) ...@@ -526,8 +526,6 @@ int snd_bebob_stream_init_duplex(struct snd_bebob *bebob)
goto end; goto end;
} }
bebob->tx_stream.flags |= CIP_SKIP_INIT_DBC_CHECK;
/* /*
* BeBoB v3 transfers packets with these qurks: * BeBoB v3 transfers packets with these qurks:
* - In the beginning of streaming, the value of dbc is incremented * - In the beginning of streaming, the value of dbc is incremented
......
...@@ -421,7 +421,7 @@ int amdtp_dot_init(struct amdtp_stream *s, struct fw_unit *unit, ...@@ -421,7 +421,7 @@ int amdtp_dot_init(struct amdtp_stream *s, struct fw_unit *unit,
/* Use different mode between incoming/outgoing. */ /* Use different mode between incoming/outgoing. */
if (dir == AMDTP_IN_STREAM) { if (dir == AMDTP_IN_STREAM) {
flags = CIP_NONBLOCKING | CIP_SKIP_INIT_DBC_CHECK; flags = CIP_NONBLOCKING;
process_data_blocks = process_tx_data_blocks; process_data_blocks = process_tx_data_blocks;
} else { } else {
flags = CIP_BLOCKING; flags = CIP_BLOCKING;
......
...@@ -242,8 +242,7 @@ int snd_oxfw_stream_init_simplex(struct snd_oxfw *oxfw, ...@@ -242,8 +242,7 @@ int snd_oxfw_stream_init_simplex(struct snd_oxfw *oxfw,
* blocks than IEC 61883-6 defines. * blocks than IEC 61883-6 defines.
*/ */
if (stream == &oxfw->tx_stream) { if (stream == &oxfw->tx_stream) {
oxfw->tx_stream.flags |= CIP_SKIP_INIT_DBC_CHECK | oxfw->tx_stream.flags |= CIP_JUMBO_PAYLOAD;
CIP_JUMBO_PAYLOAD;
if (oxfw->wrong_dbs) if (oxfw->wrong_dbs)
oxfw->tx_stream.flags |= CIP_WRONG_DBS; oxfw->tx_stream.flags |= CIP_WRONG_DBS;
} }
......
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