Linux Audio

Check our new training course

Loading...
Note: File does not exist in v4.17.
  1// SPDX-License-Identifier: GPL-2.0-or-later
  2//
  3// packet-header-definitions.h - The definitions of header fields for IEEE 1394 packet.
  4//
  5// Copyright (c) 2024 Takashi Sakamoto
  6
  7#ifndef _FIREWIRE_PACKET_HEADER_DEFINITIONS_H
  8#define _FIREWIRE_PACKET_HEADER_DEFINITIONS_H
  9
 10#include <linux/types.h>
 11
 12#define ASYNC_HEADER_QUADLET_COUNT		4
 13
 14#define ASYNC_HEADER_Q0_DESTINATION_SHIFT	16
 15#define ASYNC_HEADER_Q0_DESTINATION_MASK	0xffff0000
 16#define ASYNC_HEADER_Q0_TLABEL_SHIFT		10
 17#define ASYNC_HEADER_Q0_TLABEL_MASK		0x0000fc00
 18#define ASYNC_HEADER_Q0_RETRY_SHIFT		8
 19#define ASYNC_HEADER_Q0_RETRY_MASK		0x00000300
 20#define ASYNC_HEADER_Q0_TCODE_SHIFT		4
 21#define ASYNC_HEADER_Q0_TCODE_MASK		0x000000f0
 22#define ASYNC_HEADER_Q0_PRIORITY_SHIFT		0
 23#define ASYNC_HEADER_Q0_PRIORITY_MASK		0x0000000f
 24#define ASYNC_HEADER_Q1_SOURCE_SHIFT		16
 25#define ASYNC_HEADER_Q1_SOURCE_MASK		0xffff0000
 26#define ASYNC_HEADER_Q1_RCODE_SHIFT		12
 27#define ASYNC_HEADER_Q1_RCODE_MASK		0x0000f000
 28#define ASYNC_HEADER_Q1_RCODE_SHIFT		12
 29#define ASYNC_HEADER_Q1_RCODE_MASK		0x0000f000
 30#define ASYNC_HEADER_Q1_OFFSET_HIGH_SHIFT	0
 31#define ASYNC_HEADER_Q1_OFFSET_HIGH_MASK	0x0000ffff
 32#define ASYNC_HEADER_Q3_DATA_LENGTH_SHIFT	16
 33#define ASYNC_HEADER_Q3_DATA_LENGTH_MASK	0xffff0000
 34#define ASYNC_HEADER_Q3_EXTENDED_TCODE_SHIFT	0
 35#define ASYNC_HEADER_Q3_EXTENDED_TCODE_MASK	0x0000ffff
 36
 37static inline unsigned int async_header_get_destination(const u32 header[ASYNC_HEADER_QUADLET_COUNT])
 38{
 39	return (header[0] & ASYNC_HEADER_Q0_DESTINATION_MASK) >> ASYNC_HEADER_Q0_DESTINATION_SHIFT;
 40}
 41
 42static inline unsigned int async_header_get_tlabel(const u32 header[ASYNC_HEADER_QUADLET_COUNT])
 43{
 44	return (header[0] & ASYNC_HEADER_Q0_TLABEL_MASK) >> ASYNC_HEADER_Q0_TLABEL_SHIFT;
 45}
 46
 47static inline unsigned int async_header_get_retry(const u32 header[ASYNC_HEADER_QUADLET_COUNT])
 48{
 49	return (header[0] & ASYNC_HEADER_Q0_RETRY_MASK) >> ASYNC_HEADER_Q0_RETRY_SHIFT;
 50}
 51
 52static inline unsigned int async_header_get_tcode(const u32 header[ASYNC_HEADER_QUADLET_COUNT])
 53{
 54	return (header[0] & ASYNC_HEADER_Q0_TCODE_MASK) >> ASYNC_HEADER_Q0_TCODE_SHIFT;
 55}
 56
 57static inline unsigned int async_header_get_priority(const u32 header[ASYNC_HEADER_QUADLET_COUNT])
 58{
 59	return (header[0] & ASYNC_HEADER_Q0_PRIORITY_MASK) >> ASYNC_HEADER_Q0_PRIORITY_SHIFT;
 60}
 61
 62static inline unsigned int async_header_get_source(const u32 header[ASYNC_HEADER_QUADLET_COUNT])
 63{
 64	return (header[1] & ASYNC_HEADER_Q1_SOURCE_MASK) >> ASYNC_HEADER_Q1_SOURCE_SHIFT;
 65}
 66
 67static inline unsigned int async_header_get_rcode(const u32 header[ASYNC_HEADER_QUADLET_COUNT])
 68{
 69	return (header[1] & ASYNC_HEADER_Q1_RCODE_MASK) >> ASYNC_HEADER_Q1_RCODE_SHIFT;
 70}
 71
 72static inline u64 async_header_get_offset(const u32 header[ASYNC_HEADER_QUADLET_COUNT])
 73{
 74	u32 hi = (header[1] & ASYNC_HEADER_Q1_OFFSET_HIGH_MASK) >> ASYNC_HEADER_Q1_OFFSET_HIGH_SHIFT;
 75	return (((u64)hi) << 32) | ((u64)header[2]);
 76}
 77
 78static inline u32 async_header_get_quadlet_data(const u32 header[ASYNC_HEADER_QUADLET_COUNT])
 79{
 80	return header[3];
 81}
 82
 83static inline unsigned int async_header_get_data_length(const u32 header[ASYNC_HEADER_QUADLET_COUNT])
 84{
 85	return (header[3] & ASYNC_HEADER_Q3_DATA_LENGTH_MASK) >> ASYNC_HEADER_Q3_DATA_LENGTH_SHIFT;
 86}
 87
 88static inline unsigned int async_header_get_extended_tcode(const u32 header[ASYNC_HEADER_QUADLET_COUNT])
 89{
 90	return (header[3] & ASYNC_HEADER_Q3_EXTENDED_TCODE_MASK) >> ASYNC_HEADER_Q3_EXTENDED_TCODE_SHIFT;
 91}
 92
 93static inline void async_header_set_destination(u32 header[ASYNC_HEADER_QUADLET_COUNT],
 94						unsigned int destination)
 95{
 96	header[0] &= ~ASYNC_HEADER_Q0_DESTINATION_MASK;
 97	header[0] |= (((u32)destination) << ASYNC_HEADER_Q0_DESTINATION_SHIFT) & ASYNC_HEADER_Q0_DESTINATION_MASK;
 98}
 99
100static inline void async_header_set_tlabel(u32 header[ASYNC_HEADER_QUADLET_COUNT],
101					   unsigned int tlabel)
102{
103	header[0] &= ~ASYNC_HEADER_Q0_TLABEL_MASK;
104	header[0] |= (((u32)tlabel) << ASYNC_HEADER_Q0_TLABEL_SHIFT) & ASYNC_HEADER_Q0_TLABEL_MASK;
105}
106
107static inline void async_header_set_retry(u32 header[ASYNC_HEADER_QUADLET_COUNT],
108					  unsigned int retry)
109{
110	header[0] &= ~ASYNC_HEADER_Q0_RETRY_MASK;
111	header[0] |= (((u32)retry) << ASYNC_HEADER_Q0_RETRY_SHIFT) & ASYNC_HEADER_Q0_RETRY_MASK;
112}
113
114static inline void async_header_set_tcode(u32 header[ASYNC_HEADER_QUADLET_COUNT],
115					  unsigned int tcode)
116{
117	header[0] &= ~ASYNC_HEADER_Q0_TCODE_MASK;
118	header[0] |= (((u32)tcode) << ASYNC_HEADER_Q0_TCODE_SHIFT) & ASYNC_HEADER_Q0_TCODE_MASK;
119}
120
121static inline void async_header_set_priority(u32 header[ASYNC_HEADER_QUADLET_COUNT],
122					     unsigned int priority)
123{
124	header[0] &= ~ASYNC_HEADER_Q0_PRIORITY_MASK;
125	header[0] |= (((u32)priority) << ASYNC_HEADER_Q0_PRIORITY_SHIFT) & ASYNC_HEADER_Q0_PRIORITY_MASK;
126}
127
128
129static inline void async_header_set_source(u32 header[ASYNC_HEADER_QUADLET_COUNT],
130					   unsigned int source)
131{
132	header[1] &= ~ASYNC_HEADER_Q1_SOURCE_MASK;
133	header[1] |= (((u32)source) << ASYNC_HEADER_Q1_SOURCE_SHIFT) & ASYNC_HEADER_Q1_SOURCE_MASK;
134}
135
136static inline void async_header_set_rcode(u32 header[ASYNC_HEADER_QUADLET_COUNT],
137					  unsigned int rcode)
138{
139	header[1] &= ~ASYNC_HEADER_Q1_RCODE_MASK;
140	header[1] |= (((u32)rcode) << ASYNC_HEADER_Q1_RCODE_SHIFT) & ASYNC_HEADER_Q1_RCODE_MASK;
141}
142
143static inline void async_header_set_offset(u32 header[ASYNC_HEADER_QUADLET_COUNT], u64 offset)
144{
145	u32 hi = (u32)(offset >> 32);
146	header[1] &= ~ASYNC_HEADER_Q1_OFFSET_HIGH_MASK;
147	header[1] |= (hi << ASYNC_HEADER_Q1_OFFSET_HIGH_SHIFT) & ASYNC_HEADER_Q1_OFFSET_HIGH_MASK;
148	header[2] = (u32)(offset & 0x00000000ffffffff);
149}
150
151static inline void async_header_set_quadlet_data(u32 header[ASYNC_HEADER_QUADLET_COUNT], u32 quadlet_data)
152{
153	header[3] = quadlet_data;
154}
155
156static inline void async_header_set_data_length(u32 header[ASYNC_HEADER_QUADLET_COUNT],
157						unsigned int data_length)
158{
159	header[3] &= ~ASYNC_HEADER_Q3_DATA_LENGTH_MASK;
160	header[3] |= (((u32)data_length) << ASYNC_HEADER_Q3_DATA_LENGTH_SHIFT) & ASYNC_HEADER_Q3_DATA_LENGTH_MASK;
161}
162
163static inline void async_header_set_extended_tcode(u32 header[ASYNC_HEADER_QUADLET_COUNT],
164						   unsigned int extended_tcode)
165{
166	header[3] &= ~ASYNC_HEADER_Q3_EXTENDED_TCODE_MASK;
167	header[3] |= (((u32)extended_tcode) << ASYNC_HEADER_Q3_EXTENDED_TCODE_SHIFT) & ASYNC_HEADER_Q3_EXTENDED_TCODE_MASK;
168}
169
170#define ISOC_HEADER_DATA_LENGTH_SHIFT		16
171#define ISOC_HEADER_DATA_LENGTH_MASK		0xffff0000
172#define ISOC_HEADER_TAG_SHIFT			14
173#define ISOC_HEADER_TAG_MASK			0x0000c000
174#define ISOC_HEADER_CHANNEL_SHIFT		8
175#define ISOC_HEADER_CHANNEL_MASK		0x00003f00
176#define ISOC_HEADER_TCODE_SHIFT			4
177#define ISOC_HEADER_TCODE_MASK			0x000000f0
178#define ISOC_HEADER_SY_SHIFT			0
179#define ISOC_HEADER_SY_MASK			0x0000000f
180
181static inline unsigned int isoc_header_get_data_length(u32 header)
182{
183	return (header & ISOC_HEADER_DATA_LENGTH_MASK) >> ISOC_HEADER_DATA_LENGTH_SHIFT;
184}
185
186static inline unsigned int isoc_header_get_tag(u32 header)
187{
188	return (header & ISOC_HEADER_TAG_MASK) >> ISOC_HEADER_TAG_SHIFT;
189}
190
191static inline unsigned int isoc_header_get_channel(u32 header)
192{
193	return (header & ISOC_HEADER_CHANNEL_MASK) >> ISOC_HEADER_CHANNEL_SHIFT;
194}
195
196static inline unsigned int isoc_header_get_tcode(u32 header)
197{
198	return (header & ISOC_HEADER_TCODE_MASK) >> ISOC_HEADER_TCODE_SHIFT;
199}
200
201static inline unsigned int isoc_header_get_sy(u32 header)
202{
203	return (header & ISOC_HEADER_SY_MASK) >> ISOC_HEADER_SY_SHIFT;
204}
205
206static inline void isoc_header_set_data_length(u32 *header, unsigned int data_length)
207{
208	*header &= ~ISOC_HEADER_DATA_LENGTH_MASK;
209	*header |= (((u32)data_length) << ISOC_HEADER_DATA_LENGTH_SHIFT) & ISOC_HEADER_DATA_LENGTH_MASK;
210}
211
212static inline void isoc_header_set_tag(u32 *header, unsigned int tag)
213{
214	*header &= ~ISOC_HEADER_TAG_MASK;
215	*header |= (((u32)tag) << ISOC_HEADER_TAG_SHIFT) & ISOC_HEADER_TAG_MASK;
216}
217
218static inline void isoc_header_set_channel(u32 *header, unsigned int channel)
219{
220	*header &= ~ISOC_HEADER_CHANNEL_MASK;
221	*header |= (((u32)channel) << ISOC_HEADER_CHANNEL_SHIFT) & ISOC_HEADER_CHANNEL_MASK;
222}
223
224static inline void isoc_header_set_tcode(u32 *header, unsigned int tcode)
225{
226	*header &= ~ISOC_HEADER_TCODE_MASK;
227	*header |= (((u32)tcode) << ISOC_HEADER_TCODE_SHIFT) & ISOC_HEADER_TCODE_MASK;
228}
229
230static inline void isoc_header_set_sy(u32 *header, unsigned int sy)
231{
232	*header &= ~ISOC_HEADER_SY_MASK;
233	*header |= (((u32)sy) << ISOC_HEADER_SY_SHIFT) & ISOC_HEADER_SY_MASK;
234}
235
236#endif // _FIREWIRE_PACKET_HEADER_DEFINITIONS_H