Path: blob/master/drivers/firewire/packet-header-definitions.h
26378 views
// SPDX-License-Identifier: GPL-2.0-or-later1//2// packet-header-definitions.h - The definitions of header fields for IEEE 1394 packet.3//4// Copyright (c) 2024 Takashi Sakamoto56#ifndef _FIREWIRE_PACKET_HEADER_DEFINITIONS_H7#define _FIREWIRE_PACKET_HEADER_DEFINITIONS_H89#include <linux/types.h>1011#define ASYNC_HEADER_QUADLET_COUNT 41213#define ASYNC_HEADER_Q0_DESTINATION_SHIFT 1614#define ASYNC_HEADER_Q0_DESTINATION_MASK 0xffff000015#define ASYNC_HEADER_Q0_TLABEL_SHIFT 1016#define ASYNC_HEADER_Q0_TLABEL_MASK 0x0000fc0017#define ASYNC_HEADER_Q0_RETRY_SHIFT 818#define ASYNC_HEADER_Q0_RETRY_MASK 0x0000030019#define ASYNC_HEADER_Q0_TCODE_SHIFT 420#define ASYNC_HEADER_Q0_TCODE_MASK 0x000000f021#define ASYNC_HEADER_Q0_PRIORITY_SHIFT 022#define ASYNC_HEADER_Q0_PRIORITY_MASK 0x0000000f23#define ASYNC_HEADER_Q1_SOURCE_SHIFT 1624#define ASYNC_HEADER_Q1_SOURCE_MASK 0xffff000025#define ASYNC_HEADER_Q1_RCODE_SHIFT 1226#define ASYNC_HEADER_Q1_RCODE_MASK 0x0000f00027#define ASYNC_HEADER_Q1_RCODE_SHIFT 1228#define ASYNC_HEADER_Q1_RCODE_MASK 0x0000f00029#define ASYNC_HEADER_Q1_OFFSET_HIGH_SHIFT 030#define ASYNC_HEADER_Q1_OFFSET_HIGH_MASK 0x0000ffff31#define ASYNC_HEADER_Q3_DATA_LENGTH_SHIFT 1632#define ASYNC_HEADER_Q3_DATA_LENGTH_MASK 0xffff000033#define ASYNC_HEADER_Q3_EXTENDED_TCODE_SHIFT 034#define ASYNC_HEADER_Q3_EXTENDED_TCODE_MASK 0x0000ffff3536static inline unsigned int async_header_get_destination(const u32 header[ASYNC_HEADER_QUADLET_COUNT])37{38return (header[0] & ASYNC_HEADER_Q0_DESTINATION_MASK) >> ASYNC_HEADER_Q0_DESTINATION_SHIFT;39}4041static inline unsigned int async_header_get_tlabel(const u32 header[ASYNC_HEADER_QUADLET_COUNT])42{43return (header[0] & ASYNC_HEADER_Q0_TLABEL_MASK) >> ASYNC_HEADER_Q0_TLABEL_SHIFT;44}4546static inline unsigned int async_header_get_retry(const u32 header[ASYNC_HEADER_QUADLET_COUNT])47{48return (header[0] & ASYNC_HEADER_Q0_RETRY_MASK) >> ASYNC_HEADER_Q0_RETRY_SHIFT;49}5051static inline unsigned int async_header_get_tcode(const u32 header[ASYNC_HEADER_QUADLET_COUNT])52{53return (header[0] & ASYNC_HEADER_Q0_TCODE_MASK) >> ASYNC_HEADER_Q0_TCODE_SHIFT;54}5556static inline unsigned int async_header_get_priority(const u32 header[ASYNC_HEADER_QUADLET_COUNT])57{58return (header[0] & ASYNC_HEADER_Q0_PRIORITY_MASK) >> ASYNC_HEADER_Q0_PRIORITY_SHIFT;59}6061static inline unsigned int async_header_get_source(const u32 header[ASYNC_HEADER_QUADLET_COUNT])62{63return (header[1] & ASYNC_HEADER_Q1_SOURCE_MASK) >> ASYNC_HEADER_Q1_SOURCE_SHIFT;64}6566static inline unsigned int async_header_get_rcode(const u32 header[ASYNC_HEADER_QUADLET_COUNT])67{68return (header[1] & ASYNC_HEADER_Q1_RCODE_MASK) >> ASYNC_HEADER_Q1_RCODE_SHIFT;69}7071static inline u64 async_header_get_offset(const u32 header[ASYNC_HEADER_QUADLET_COUNT])72{73u32 hi = (header[1] & ASYNC_HEADER_Q1_OFFSET_HIGH_MASK) >> ASYNC_HEADER_Q1_OFFSET_HIGH_SHIFT;74return (((u64)hi) << 32) | ((u64)header[2]);75}7677static inline u32 async_header_get_quadlet_data(const u32 header[ASYNC_HEADER_QUADLET_COUNT])78{79return header[3];80}8182static inline unsigned int async_header_get_data_length(const u32 header[ASYNC_HEADER_QUADLET_COUNT])83{84return (header[3] & ASYNC_HEADER_Q3_DATA_LENGTH_MASK) >> ASYNC_HEADER_Q3_DATA_LENGTH_SHIFT;85}8687static inline unsigned int async_header_get_extended_tcode(const u32 header[ASYNC_HEADER_QUADLET_COUNT])88{89return (header[3] & ASYNC_HEADER_Q3_EXTENDED_TCODE_MASK) >> ASYNC_HEADER_Q3_EXTENDED_TCODE_SHIFT;90}9192static inline void async_header_set_destination(u32 header[ASYNC_HEADER_QUADLET_COUNT],93unsigned int destination)94{95header[0] &= ~ASYNC_HEADER_Q0_DESTINATION_MASK;96header[0] |= (((u32)destination) << ASYNC_HEADER_Q0_DESTINATION_SHIFT) & ASYNC_HEADER_Q0_DESTINATION_MASK;97}9899static inline void async_header_set_tlabel(u32 header[ASYNC_HEADER_QUADLET_COUNT],100unsigned int tlabel)101{102header[0] &= ~ASYNC_HEADER_Q0_TLABEL_MASK;103header[0] |= (((u32)tlabel) << ASYNC_HEADER_Q0_TLABEL_SHIFT) & ASYNC_HEADER_Q0_TLABEL_MASK;104}105106static inline void async_header_set_retry(u32 header[ASYNC_HEADER_QUADLET_COUNT],107unsigned int retry)108{109header[0] &= ~ASYNC_HEADER_Q0_RETRY_MASK;110header[0] |= (((u32)retry) << ASYNC_HEADER_Q0_RETRY_SHIFT) & ASYNC_HEADER_Q0_RETRY_MASK;111}112113static inline void async_header_set_tcode(u32 header[ASYNC_HEADER_QUADLET_COUNT],114unsigned int tcode)115{116header[0] &= ~ASYNC_HEADER_Q0_TCODE_MASK;117header[0] |= (((u32)tcode) << ASYNC_HEADER_Q0_TCODE_SHIFT) & ASYNC_HEADER_Q0_TCODE_MASK;118}119120static inline void async_header_set_priority(u32 header[ASYNC_HEADER_QUADLET_COUNT],121unsigned int priority)122{123header[0] &= ~ASYNC_HEADER_Q0_PRIORITY_MASK;124header[0] |= (((u32)priority) << ASYNC_HEADER_Q0_PRIORITY_SHIFT) & ASYNC_HEADER_Q0_PRIORITY_MASK;125}126127128static inline void async_header_set_source(u32 header[ASYNC_HEADER_QUADLET_COUNT],129unsigned int source)130{131header[1] &= ~ASYNC_HEADER_Q1_SOURCE_MASK;132header[1] |= (((u32)source) << ASYNC_HEADER_Q1_SOURCE_SHIFT) & ASYNC_HEADER_Q1_SOURCE_MASK;133}134135static inline void async_header_set_rcode(u32 header[ASYNC_HEADER_QUADLET_COUNT],136unsigned int rcode)137{138header[1] &= ~ASYNC_HEADER_Q1_RCODE_MASK;139header[1] |= (((u32)rcode) << ASYNC_HEADER_Q1_RCODE_SHIFT) & ASYNC_HEADER_Q1_RCODE_MASK;140}141142static inline void async_header_set_offset(u32 header[ASYNC_HEADER_QUADLET_COUNT], u64 offset)143{144u32 hi = (u32)(offset >> 32);145header[1] &= ~ASYNC_HEADER_Q1_OFFSET_HIGH_MASK;146header[1] |= (hi << ASYNC_HEADER_Q1_OFFSET_HIGH_SHIFT) & ASYNC_HEADER_Q1_OFFSET_HIGH_MASK;147header[2] = (u32)(offset & 0x00000000ffffffff);148}149150static inline void async_header_set_quadlet_data(u32 header[ASYNC_HEADER_QUADLET_COUNT], u32 quadlet_data)151{152header[3] = quadlet_data;153}154155static inline void async_header_set_data_length(u32 header[ASYNC_HEADER_QUADLET_COUNT],156unsigned int data_length)157{158header[3] &= ~ASYNC_HEADER_Q3_DATA_LENGTH_MASK;159header[3] |= (((u32)data_length) << ASYNC_HEADER_Q3_DATA_LENGTH_SHIFT) & ASYNC_HEADER_Q3_DATA_LENGTH_MASK;160}161162static inline void async_header_set_extended_tcode(u32 header[ASYNC_HEADER_QUADLET_COUNT],163unsigned int extended_tcode)164{165header[3] &= ~ASYNC_HEADER_Q3_EXTENDED_TCODE_MASK;166header[3] |= (((u32)extended_tcode) << ASYNC_HEADER_Q3_EXTENDED_TCODE_SHIFT) & ASYNC_HEADER_Q3_EXTENDED_TCODE_MASK;167}168169#define ISOC_HEADER_DATA_LENGTH_SHIFT 16170#define ISOC_HEADER_DATA_LENGTH_MASK 0xffff0000171#define ISOC_HEADER_TAG_SHIFT 14172#define ISOC_HEADER_TAG_MASK 0x0000c000173#define ISOC_HEADER_CHANNEL_SHIFT 8174#define ISOC_HEADER_CHANNEL_MASK 0x00003f00175#define ISOC_HEADER_TCODE_SHIFT 4176#define ISOC_HEADER_TCODE_MASK 0x000000f0177#define ISOC_HEADER_SY_SHIFT 0178#define ISOC_HEADER_SY_MASK 0x0000000f179180static inline unsigned int isoc_header_get_data_length(u32 header)181{182return (header & ISOC_HEADER_DATA_LENGTH_MASK) >> ISOC_HEADER_DATA_LENGTH_SHIFT;183}184185static inline unsigned int isoc_header_get_tag(u32 header)186{187return (header & ISOC_HEADER_TAG_MASK) >> ISOC_HEADER_TAG_SHIFT;188}189190static inline unsigned int isoc_header_get_channel(u32 header)191{192return (header & ISOC_HEADER_CHANNEL_MASK) >> ISOC_HEADER_CHANNEL_SHIFT;193}194195static inline unsigned int isoc_header_get_tcode(u32 header)196{197return (header & ISOC_HEADER_TCODE_MASK) >> ISOC_HEADER_TCODE_SHIFT;198}199200static inline unsigned int isoc_header_get_sy(u32 header)201{202return (header & ISOC_HEADER_SY_MASK) >> ISOC_HEADER_SY_SHIFT;203}204205static inline void isoc_header_set_data_length(u32 *header, unsigned int data_length)206{207*header &= ~ISOC_HEADER_DATA_LENGTH_MASK;208*header |= (((u32)data_length) << ISOC_HEADER_DATA_LENGTH_SHIFT) & ISOC_HEADER_DATA_LENGTH_MASK;209}210211static inline void isoc_header_set_tag(u32 *header, unsigned int tag)212{213*header &= ~ISOC_HEADER_TAG_MASK;214*header |= (((u32)tag) << ISOC_HEADER_TAG_SHIFT) & ISOC_HEADER_TAG_MASK;215}216217static inline void isoc_header_set_channel(u32 *header, unsigned int channel)218{219*header &= ~ISOC_HEADER_CHANNEL_MASK;220*header |= (((u32)channel) << ISOC_HEADER_CHANNEL_SHIFT) & ISOC_HEADER_CHANNEL_MASK;221}222223static inline void isoc_header_set_tcode(u32 *header, unsigned int tcode)224{225*header &= ~ISOC_HEADER_TCODE_MASK;226*header |= (((u32)tcode) << ISOC_HEADER_TCODE_SHIFT) & ISOC_HEADER_TCODE_MASK;227}228229static inline void isoc_header_set_sy(u32 *header, unsigned int sy)230{231*header &= ~ISOC_HEADER_SY_MASK;232*header |= (((u32)sy) << ISOC_HEADER_SY_SHIFT) & ISOC_HEADER_SY_MASK;233}234235#endif // _FIREWIRE_PACKET_HEADER_DEFINITIONS_H236237238