Commit 69efd5c4 authored by Takashi Sakamoto's avatar Takashi Sakamoto Committed by Takashi Iwai

ALSA: firewire-lib: use sequence of syt offset and data block on pool in AMDTP domain

In previous commit, the sequence of syt offset and the number of data
blocks per packet is calculated for pool in AMDTP domain structure in
advance of processing outgoing packets.

This commit uses the sequence for outgoing packet processing to obsolete
per-stream processing of the sequence.
Signed-off-by: default avatarTakashi Sakamoto <o-takashi@sakamocchi.jp>
Link: https://lore.kernel.org/r/20200508043635.349339-11-o-takashi@sakamocchi.jpSigned-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent 1a4be183
...@@ -747,34 +747,30 @@ static unsigned int compute_syt(unsigned int syt_offset, unsigned int cycle, ...@@ -747,34 +747,30 @@ static unsigned int compute_syt(unsigned int syt_offset, unsigned int cycle,
return syt & CIP_SYT_MASK; return syt & CIP_SYT_MASK;
} }
static void generate_ideal_pkt_descs(struct amdtp_stream *s, static void generate_pkt_descs(struct amdtp_stream *s, struct pkt_desc *descs,
struct pkt_desc *descs, const __be32 *ctx_header, unsigned int packets,
const __be32 *ctx_header, const struct seq_desc *seq_descs,
unsigned int packets) unsigned int seq_size)
{ {
unsigned int dbc = s->data_block_counter; unsigned int dbc = s->data_block_counter;
unsigned int seq_index = s->ctx_data.rx.seq_index;
int i; int i;
for (i = 0; i < packets; ++i) { for (i = 0; i < packets; ++i) {
struct pkt_desc *desc = descs + i; struct pkt_desc *desc = descs + i;
unsigned int index = (s->packet_index + i) % s->queue_size; unsigned int index = (s->packet_index + i) % s->queue_size;
unsigned int syt_offset; const struct seq_desc *seq = seq_descs + seq_index;
unsigned int syt;
desc->cycle = compute_it_cycle(*ctx_header, s->queue_size); desc->cycle = compute_it_cycle(*ctx_header, s->queue_size);
syt_offset = calculate_syt_offset(
&s->ctx_data.rx.last_syt_offset, syt = seq->syt_offset;
&s->ctx_data.rx.syt_offset_state, s->sfc); if (syt != CIP_SYT_NO_INFO) {
if (syt_offset != CIP_SYT_NO_INFO) { syt = compute_syt(syt, desc->cycle,
desc->syt = compute_syt(syt_offset, desc->cycle,
s->ctx_data.rx.transfer_delay); s->ctx_data.rx.transfer_delay);
} else {
desc->syt = syt_offset;
} }
desc->data_blocks = desc->syt = syt;
calculate_data_blocks(&s->ctx_data.rx.data_block_state, desc->data_blocks = seq->data_blocks;
!!(s->flags & CIP_BLOCKING),
desc->syt == CIP_SYT_NO_INFO,
s->syt_interval, s->sfc);
if (s->flags & CIP_DBC_IS_END_EVENT) if (s->flags & CIP_DBC_IS_END_EVENT)
dbc = (dbc + desc->data_blocks) & 0xff; dbc = (dbc + desc->data_blocks) & 0xff;
...@@ -786,10 +782,13 @@ static void generate_ideal_pkt_descs(struct amdtp_stream *s, ...@@ -786,10 +782,13 @@ static void generate_ideal_pkt_descs(struct amdtp_stream *s,
desc->ctx_payload = s->buffer.packets[index].buffer; desc->ctx_payload = s->buffer.packets[index].buffer;
seq_index = (seq_index + 1) % seq_size;
++ctx_header; ++ctx_header;
} }
s->data_block_counter = dbc; s->data_block_counter = dbc;
s->ctx_data.rx.seq_index = seq_index;
} }
static inline void cancel_stream(struct amdtp_stream *s) static inline void cancel_stream(struct amdtp_stream *s)
...@@ -818,6 +817,7 @@ static void out_stream_callback(struct fw_iso_context *context, u32 tstamp, ...@@ -818,6 +817,7 @@ static void out_stream_callback(struct fw_iso_context *context, u32 tstamp,
void *private_data) void *private_data)
{ {
struct amdtp_stream *s = private_data; struct amdtp_stream *s = private_data;
const struct amdtp_domain *d = s->domain;
const __be32 *ctx_header = header; const __be32 *ctx_header = header;
unsigned int events_per_period = s->ctx_data.rx.events_per_period; unsigned int events_per_period = s->ctx_data.rx.events_per_period;
unsigned int event_count = s->ctx_data.rx.event_count; unsigned int event_count = s->ctx_data.rx.event_count;
...@@ -830,7 +830,8 @@ static void out_stream_callback(struct fw_iso_context *context, u32 tstamp, ...@@ -830,7 +830,8 @@ static void out_stream_callback(struct fw_iso_context *context, u32 tstamp,
// Calculate the number of packets in buffer and check XRUN. // Calculate the number of packets in buffer and check XRUN.
packets = header_length / sizeof(*ctx_header); packets = header_length / sizeof(*ctx_header);
generate_ideal_pkt_descs(s, s->pkt_descs, ctx_header, packets); generate_pkt_descs(s, s->pkt_descs, ctx_header, packets, d->seq_descs,
d->seq_size);
process_ctx_payloads(s, s->pkt_descs, packets); process_ctx_payloads(s, s->pkt_descs, packets);
...@@ -1037,18 +1038,6 @@ static int amdtp_stream_start(struct amdtp_stream *s, int channel, int speed, ...@@ -1037,18 +1038,6 @@ static int amdtp_stream_start(struct amdtp_stream *s, int channel, int speed,
int start_cycle, unsigned int queue_size, int start_cycle, unsigned int queue_size,
unsigned int idle_irq_interval) unsigned int idle_irq_interval)
{ {
static const struct {
unsigned int data_block;
unsigned int syt_offset;
} *entry, initial_state[] = {
[CIP_SFC_32000] = { 4, 3072 },
[CIP_SFC_48000] = { 6, 1024 },
[CIP_SFC_96000] = { 12, 1024 },
[CIP_SFC_192000] = { 24, 1024 },
[CIP_SFC_44100] = { 0, 67 },
[CIP_SFC_88200] = { 0, 67 },
[CIP_SFC_176400] = { 0, 67 },
};
bool is_irq_target = (s == s->domain->irq_target); bool is_irq_target = (s == s->domain->irq_target);
unsigned int ctx_header_size; unsigned int ctx_header_size;
unsigned int max_ctx_payload_size; unsigned int max_ctx_payload_size;
...@@ -1072,12 +1061,7 @@ static int amdtp_stream_start(struct amdtp_stream *s, int channel, int speed, ...@@ -1072,12 +1061,7 @@ static int amdtp_stream_start(struct amdtp_stream *s, int channel, int speed,
s->data_block_counter = UINT_MAX; s->data_block_counter = UINT_MAX;
} else { } else {
entry = &initial_state[s->sfc];
s->data_block_counter = 0; s->data_block_counter = 0;
s->ctx_data.rx.data_block_state = entry->data_block;
s->ctx_data.rx.syt_offset_state = entry->syt_offset;
s->ctx_data.rx.last_syt_offset = TICKS_PER_CYCLE;
} }
/* initialize packet buffer */ /* initialize packet buffer */
......
...@@ -140,10 +140,6 @@ struct amdtp_stream { ...@@ -140,10 +140,6 @@ struct amdtp_stream {
unsigned int transfer_delay; unsigned int transfer_delay;
unsigned int seq_index; unsigned int seq_index;
unsigned int data_block_state;
unsigned int last_syt_offset;
unsigned int syt_offset_state;
// To generate CIP header. // To generate CIP header.
unsigned int fdf; unsigned int fdf;
int syt_override; int syt_override;
......
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