Commit 9a2820c1 authored by Takashi Sakamoto's avatar Takashi Sakamoto Committed by Takashi Iwai

ALSA: firewire-lib: macro arrangement for code cleanup

Some macros include my misunderstanding for IEC 61883-1 or -6.
Additionally, some fixed values appear on codes.

This commit replaces these with macros with proper names.
Signed-off-by: default avatarTakashi Sakamoto <o-takashi@sakamocchi.jp>
Acked-by: default avatarClemens Ladisch <clemens@ladisch.de>
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent 29bcae20
...@@ -40,24 +40,28 @@ ...@@ -40,24 +40,28 @@
#define TAG_CIP 1 #define TAG_CIP 1
/* common isochronous packet header parameters */ /* common isochronous packet header parameters */
#define CIP_EOH (1u << 31) #define CIP_EOH_SHIFT 31
#define CIP_EOH (1u << CIP_EOH_SHIFT)
#define CIP_EOH_MASK 0x80000000 #define CIP_EOH_MASK 0x80000000
#define CIP_FMT_AM (0x10 << 24) #define CIP_SID_SHIFT 24
#define CIP_SID_MASK 0x3f000000
#define CIP_DBS_MASK 0x00ff0000
#define CIP_DBS_SHIFT 16
#define CIP_DBC_MASK 0x000000ff
#define CIP_FMT_SHIFT 24
#define CIP_FMT_MASK 0x3f000000 #define CIP_FMT_MASK 0x3f000000
#define CIP_FDF_MASK 0x00ff0000
#define CIP_FDF_SHIFT 16
#define CIP_SYT_MASK 0x0000ffff #define CIP_SYT_MASK 0x0000ffff
#define CIP_SYT_NO_INFO 0xffff #define CIP_SYT_NO_INFO 0xffff
#define CIP_FDF_MASK 0x00ff0000
#define CIP_FDF_SFC_SHIFT 16
/* /*
* Audio and Music transfer protocol specific parameters * Audio and Music transfer protocol specific parameters
* only "Clock-based rate control mode" is supported * only "Clock-based rate control mode" is supported
*/ */
#define AMDTP_FDF_AM824 (0 << (CIP_FDF_SFC_SHIFT + 3)) #define CIP_FMT_AM (0x10 << CIP_FMT_SHIFT)
#define AMDTP_FDF_AM824 (0 << (CIP_FDF_SHIFT + 3))
#define AMDTP_FDF_NO_DATA 0xff #define AMDTP_FDF_NO_DATA 0xff
#define AMDTP_DBS_MASK 0x00ff0000
#define AMDTP_DBS_SHIFT 16
#define AMDTP_DBC_MASK 0x000000ff
/* TODO: make these configurable */ /* TODO: make these configurable */
#define INTERRUPT_INTERVAL 16 #define INTERRUPT_INTERVAL 16
...@@ -656,10 +660,10 @@ static int handle_out_packet(struct amdtp_stream *s, unsigned int data_blocks, ...@@ -656,10 +660,10 @@ static int handle_out_packet(struct amdtp_stream *s, unsigned int data_blocks,
buffer = s->buffer.packets[s->packet_index].buffer; buffer = s->buffer.packets[s->packet_index].buffer;
buffer[0] = cpu_to_be32(ACCESS_ONCE(s->source_node_id_field) | buffer[0] = cpu_to_be32(ACCESS_ONCE(s->source_node_id_field) |
(s->data_block_quadlets << AMDTP_DBS_SHIFT) | (s->data_block_quadlets << CIP_DBS_SHIFT) |
s->data_block_counter); s->data_block_counter);
buffer[1] = cpu_to_be32(CIP_EOH | CIP_FMT_AM | AMDTP_FDF_AM824 | buffer[1] = cpu_to_be32(CIP_EOH | CIP_FMT_AM | AMDTP_FDF_AM824 |
(s->sfc << CIP_FDF_SFC_SHIFT) | syt); (s->sfc << CIP_FDF_SHIFT) | syt);
buffer += 2; buffer += 2;
pcm = ACCESS_ONCE(s->pcm); pcm = ACCESS_ONCE(s->pcm);
...@@ -712,11 +716,11 @@ static int handle_in_packet(struct amdtp_stream *s, ...@@ -712,11 +716,11 @@ static int handle_in_packet(struct amdtp_stream *s,
/* Calculate data blocks */ /* Calculate data blocks */
if (payload_quadlets < 3 || if (payload_quadlets < 3 ||
((cip_header[1] & CIP_FDF_MASK) == ((cip_header[1] & CIP_FDF_MASK) ==
(AMDTP_FDF_NO_DATA << CIP_FDF_SFC_SHIFT))) { (AMDTP_FDF_NO_DATA << CIP_FDF_SHIFT))) {
data_blocks = 0; data_blocks = 0;
} else { } else {
data_block_quadlets = data_block_quadlets =
(cip_header[0] & AMDTP_DBS_MASK) >> AMDTP_DBS_SHIFT; (cip_header[0] & CIP_DBS_MASK) >> CIP_DBS_SHIFT;
/* avoid division by zero */ /* avoid division by zero */
if (data_block_quadlets == 0) { if (data_block_quadlets == 0) {
dev_info_ratelimited(&s->unit->device, dev_info_ratelimited(&s->unit->device,
...@@ -731,7 +735,7 @@ static int handle_in_packet(struct amdtp_stream *s, ...@@ -731,7 +735,7 @@ static int handle_in_packet(struct amdtp_stream *s,
} }
/* Check data block counter continuity */ /* Check data block counter continuity */
data_block_counter = cip_header[0] & AMDTP_DBC_MASK; data_block_counter = cip_header[0] & CIP_DBC_MASK;
if (data_blocks == 0 && (s->flags & CIP_EMPTY_HAS_WRONG_DBC) && if (data_blocks == 0 && (s->flags & CIP_EMPTY_HAS_WRONG_DBC) &&
s->data_block_counter != UINT_MAX) s->data_block_counter != UINT_MAX)
data_block_counter = s->data_block_counter; data_block_counter = s->data_block_counter;
...@@ -1050,8 +1054,10 @@ EXPORT_SYMBOL(amdtp_stream_pcm_pointer); ...@@ -1050,8 +1054,10 @@ EXPORT_SYMBOL(amdtp_stream_pcm_pointer);
*/ */
void amdtp_stream_update(struct amdtp_stream *s) void amdtp_stream_update(struct amdtp_stream *s)
{ {
/* Precomputing. */
ACCESS_ONCE(s->source_node_id_field) = ACCESS_ONCE(s->source_node_id_field) =
(fw_parent_device(s->unit)->card->node_id & 0x3f) << 24; (fw_parent_device(s->unit)->card->node_id << CIP_SID_SHIFT) &
CIP_SID_MASK;
} }
EXPORT_SYMBOL(amdtp_stream_update); EXPORT_SYMBOL(amdtp_stream_update);
......
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