~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/sound/usb/card.h

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /sound/usb/card.h (Version linux-6.12-rc7) and /sound/usb/card.h (Version linux-4.17.19)


  1 /* SPDX-License-Identifier: GPL-2.0 */              1 /* SPDX-License-Identifier: GPL-2.0 */
  2 #ifndef __USBAUDIO_CARD_H                           2 #ifndef __USBAUDIO_CARD_H
  3 #define __USBAUDIO_CARD_H                           3 #define __USBAUDIO_CARD_H
  4                                                     4 
  5 #define MAX_NR_RATES    1024                        5 #define MAX_NR_RATES    1024
  6 #define MAX_PACKS       6               /* per      6 #define MAX_PACKS       6               /* per URB */
  7 #define MAX_PACKS_HS    (MAX_PACKS * 8) /* in       7 #define MAX_PACKS_HS    (MAX_PACKS * 8) /* in high speed mode */
  8 #define MAX_URBS        12                          8 #define MAX_URBS        12
  9 #define SYNC_URBS       4       /* always four      9 #define SYNC_URBS       4       /* always four urbs for sync */
 10 #define MAX_QUEUE       18      /* try not to      10 #define MAX_QUEUE       18      /* try not to exceed this queue length, in ms */
 11                                                    11 
 12 struct audioformat {                               12 struct audioformat {
 13         struct list_head list;                     13         struct list_head list;
 14         u64 formats;                    /* ALS     14         u64 formats;                    /* ALSA format bits */
 15         unsigned int channels;          /* # c     15         unsigned int channels;          /* # channels */
 16         unsigned int fmt_type;          /* USB     16         unsigned int fmt_type;          /* USB audio format type (1-3) */
 17         unsigned int fmt_bits;          /* num << 
 18         unsigned int frame_size;        /* sam     17         unsigned int frame_size;        /* samples per frame for non-audio */
 19         unsigned char iface;            /* int !!  18         int iface;                      /* interface number */
 20         unsigned char altsetting;       /* cor     19         unsigned char altsetting;       /* corresponding alternate setting */
 21         unsigned char ep_idx;           /* end !!  20         unsigned char altset_idx;       /* array index of altenate setting */
 22         unsigned char altset_idx;       /* arr << 
 23         unsigned char attributes;       /* cor     21         unsigned char attributes;       /* corresponding attributes of cs endpoint */
 24         unsigned char endpoint;         /* end     22         unsigned char endpoint;         /* endpoint */
 25         unsigned char ep_attr;          /* end     23         unsigned char ep_attr;          /* endpoint attributes */
 26         bool implicit_fb;               /* imp << 
 27         unsigned char sync_ep;          /* syn << 
 28         unsigned char sync_iface;       /* syn << 
 29         unsigned char sync_altsetting;  /* syn << 
 30         unsigned char sync_ep_idx;      /* syn << 
 31         unsigned char datainterval;     /* log     24         unsigned char datainterval;     /* log_2 of data packet interval */
 32         unsigned char protocol;         /* UAC     25         unsigned char protocol;         /* UAC_VERSION_1/2/3 */
 33         unsigned int maxpacksize;       /* max     26         unsigned int maxpacksize;       /* max. packet size */
 34         unsigned int rates;             /* rat     27         unsigned int rates;             /* rate bitmasks */
 35         unsigned int rate_min, rate_max;           28         unsigned int rate_min, rate_max;        /* min/max rates */
 36         unsigned int nr_rates;          /* num     29         unsigned int nr_rates;          /* number of rate table entries */
 37         unsigned int *rate_table;       /* rat     30         unsigned int *rate_table;       /* rate table */
 38         unsigned char clock;            /* ass     31         unsigned char clock;            /* associated clock */
 39         struct snd_pcm_chmap_elem *chmap; /* (     32         struct snd_pcm_chmap_elem *chmap; /* (optional) channel map */
 40         bool dsd_dop;                   /* add     33         bool dsd_dop;                   /* add DOP headers in case of DSD samples */
 41         bool dsd_bitrev;                /* rev     34         bool dsd_bitrev;                /* reverse the bits of each DSD sample */
 42         bool dsd_raw;                   /* alt << 
 43 };                                                 35 };
 44                                                    36 
 45 struct snd_usb_substream;                          37 struct snd_usb_substream;
 46 struct snd_usb_iface_ref;                      << 
 47 struct snd_usb_clock_ref;                      << 
 48 struct snd_usb_endpoint;                           38 struct snd_usb_endpoint;
 49 struct snd_usb_power_domain;                   << 
 50                                                    39 
 51 struct snd_urb_ctx {                               40 struct snd_urb_ctx {
 52         struct urb *urb;                           41         struct urb *urb;
 53         unsigned int buffer_size;       /* siz     42         unsigned int buffer_size;       /* size of data buffer, if data URB */
 54         struct snd_usb_substream *subs;            43         struct snd_usb_substream *subs;
 55         struct snd_usb_endpoint *ep;               44         struct snd_usb_endpoint *ep;
 56         int index;      /* index for urb array     45         int index;      /* index for urb array */
 57         int packets;    /* number of packets p     46         int packets;    /* number of packets per urb */
 58         int queued;     /* queued data bytes b << 
 59         int packet_size[MAX_PACKS_HS]; /* size     47         int packet_size[MAX_PACKS_HS]; /* size of packets for next submission */
 60         struct list_head ready_list;               48         struct list_head ready_list;
 61 };                                                 49 };
 62                                                    50 
 63 struct snd_usb_endpoint {                          51 struct snd_usb_endpoint {
 64         struct snd_usb_audio *chip;                52         struct snd_usb_audio *chip;
 65         struct snd_usb_iface_ref *iface_ref;   << 
 66         struct snd_usb_clock_ref *clock_ref;   << 
 67                                                    53 
 68         int opened;             /* open refcou !!  54         int use_count;
 69         atomic_t running;       /* running sta << 
 70         int ep_num;             /* the referen     55         int ep_num;             /* the referenced endpoint number */
 71         int type;               /* SND_USB_END     56         int type;               /* SND_USB_ENDPOINT_TYPE_* */
                                                   >>  57         unsigned long flags;
 72                                                    58 
 73         unsigned char iface;            /* int !!  59         void (*prepare_data_urb) (struct snd_usb_substream *subs,
 74         unsigned char altsetting;       /* cor !!  60                                   struct urb *urb);
 75         unsigned char ep_idx;           /* end << 
 76                                                << 
 77         atomic_t state;         /* running sta << 
 78                                                << 
 79         int (*prepare_data_urb) (struct snd_us << 
 80                                  struct urb *u << 
 81                                  bool in_strea << 
 82         void (*retire_data_urb) (struct snd_us     61         void (*retire_data_urb) (struct snd_usb_substream *subs,
 83                                  struct urb *u     62                                  struct urb *urb);
 84                                                    63 
 85         struct snd_usb_substream *data_subs;       64         struct snd_usb_substream *data_subs;
 86         struct snd_usb_endpoint *sync_source;  !!  65         struct snd_usb_endpoint *sync_master;
 87         struct snd_usb_endpoint *sync_sink;    !!  66         struct snd_usb_endpoint *sync_slave;
 88                                                    67 
 89         struct snd_urb_ctx urb[MAX_URBS];          68         struct snd_urb_ctx urb[MAX_URBS];
 90                                                    69 
 91         struct snd_usb_packet_info {               70         struct snd_usb_packet_info {
 92                 uint32_t packet_size[MAX_PACKS     71                 uint32_t packet_size[MAX_PACKS_HS];
 93                 int packets;                       72                 int packets;
 94         } next_packet[MAX_URBS];                   73         } next_packet[MAX_URBS];
 95         unsigned int next_packet_head;  /* rin !!  74         int next_packet_read_pos, next_packet_write_pos;
 96         unsigned int next_packet_queued; /* qu !!  75         struct list_head ready_playback_urbs;
 97         struct list_head ready_playback_urbs;  << 
 98                                                    76 
 99         unsigned int nurbs;             /* # u     77         unsigned int nurbs;             /* # urbs */
100         unsigned long active_mask;      /* bit     78         unsigned long active_mask;      /* bitmask of active urbs */
101         unsigned long unlink_mask;      /* bit     79         unsigned long unlink_mask;      /* bitmask of unlinked urbs */
102         atomic_t submitted_urbs;        /* cur << 
103         char *syncbuf;                  /* syn     80         char *syncbuf;                  /* sync buffer for all sync URBs */
104         dma_addr_t sync_dma;            /* DMA     81         dma_addr_t sync_dma;            /* DMA address of syncbuf */
105                                                    82 
106         unsigned int pipe;              /* the     83         unsigned int pipe;              /* the data i/o pipe */
107         unsigned int packsize[2];       /* sma << 
108         unsigned int sample_rem;        /* rem << 
109         unsigned int sample_accum;      /* sam << 
110         unsigned int pps;               /* pac << 
111         unsigned int freqn;             /* nom     84         unsigned int freqn;             /* nominal sampling rate in fs/fps in Q16.16 format */
112         unsigned int freqm;             /* mom     85         unsigned int freqm;             /* momentary sampling rate in fs/fps in Q16.16 format */
113         int        freqshift;           /* how     86         int        freqshift;           /* how much to shift the feedback value to get Q16.16 */
114         unsigned int freqmax;           /* max     87         unsigned int freqmax;           /* maximum sampling rate, used for buffer management */
115         unsigned int phase;             /* pha     88         unsigned int phase;             /* phase accumulator */
116         unsigned int maxpacksize;       /* max     89         unsigned int maxpacksize;       /* max packet size in bytes */
117         unsigned int maxframesize;      /* max     90         unsigned int maxframesize;      /* max packet size in frames */
118         unsigned int max_urb_frames;    /* max     91         unsigned int max_urb_frames;    /* max URB size in frames */
119         unsigned int curpacksize;       /* cur     92         unsigned int curpacksize;       /* current packet size in bytes (for capture) */
120         unsigned int curframesize;      /* cur     93         unsigned int curframesize;      /* current packet size in frames (for capture) */
121         unsigned int syncmaxsize;       /* syn     94         unsigned int syncmaxsize;       /* sync endpoint packet size */
122         unsigned int fill_max:1;        /* fil     95         unsigned int fill_max:1;        /* fill max packet size always */
123         unsigned int tenor_fb_quirk:1;  /* cor     96         unsigned int tenor_fb_quirk:1;  /* corrupted feedback data */
124         unsigned int datainterval;      /* log     97         unsigned int datainterval;      /* log_2 of data packet interval */
125         unsigned int syncinterval;      /* P f     98         unsigned int syncinterval;      /* P for adaptive mode, 0 otherwise */
126         unsigned char silence_value;               99         unsigned char silence_value;
127         unsigned int stride;                      100         unsigned int stride;
                                                   >> 101         int iface, altsetting;
128         int skip_packets;               /* qui    102         int skip_packets;               /* quirks for devices to ignore the first n packets
129                                            in     103                                            in a stream */
130         bool implicit_fb_sync;          /* syn << 
131         bool lowlatency_playback;       /* low << 
132         bool need_setup;                /* (re << 
133         bool need_prepare;              /* (re << 
134         bool fixed_rate;                /* ski << 
135                                                << 
136         /* for hw constraints */               << 
137         const struct audioformat *cur_audiofmt << 
138         unsigned int cur_rate;                 << 
139         snd_pcm_format_t cur_format;           << 
140         unsigned int cur_channels;             << 
141         unsigned int cur_frame_bytes;          << 
142         unsigned int cur_period_frames;        << 
143         unsigned int cur_period_bytes;         << 
144         unsigned int cur_buffer_periods;       << 
145                                                   104 
146         spinlock_t lock;                          105         spinlock_t lock;
147         struct list_head list;                    106         struct list_head list;
148 };                                                107 };
149                                                   108 
150 struct media_ctl;                              << 
151                                                << 
152 struct snd_usb_substream {                        109 struct snd_usb_substream {
153         struct snd_usb_stream *stream;            110         struct snd_usb_stream *stream;
154         struct usb_device *dev;                   111         struct usb_device *dev;
155         struct snd_pcm_substream *pcm_substrea    112         struct snd_pcm_substream *pcm_substream;
156         int direction;  /* playback or capture    113         int direction;  /* playback or capture */
                                                   >> 114         int interface;  /* current interface */
157         int endpoint;   /* assigned endpoint *    115         int endpoint;   /* assigned endpoint */
158         const struct audioformat *cur_audiofmt !! 116         struct audioformat *cur_audiofmt;       /* current audioformat pointer (for hw_params callback) */
159         struct snd_usb_power_domain *str_pd;   !! 117         snd_pcm_format_t pcm_format;    /* current audio format (for hw_params callback) */
                                                   >> 118         unsigned int channels;          /* current number of channels (for hw_params callback) */
160         unsigned int channels_max;      /* max    119         unsigned int channels_max;      /* max channels in the all audiofmts */
                                                   >> 120         unsigned int cur_rate;          /* current rate (for hw_params callback) */
                                                   >> 121         unsigned int period_bytes;      /* current period bytes (for hw_params callback) */
                                                   >> 122         unsigned int period_frames;     /* current frames per period */
                                                   >> 123         unsigned int buffer_periods;    /* current periods per buffer */
                                                   >> 124         unsigned int altset_idx;     /* USB data format: index of alternate setting */
161         unsigned int txfr_quirk:1;      /* all    125         unsigned int txfr_quirk:1;      /* allow sub-frame alignment */
162         unsigned int tx_length_quirk:1; /* add    126         unsigned int tx_length_quirk:1; /* add length specifier to transfers */
163         unsigned int fmt_type;          /* USB    127         unsigned int fmt_type;          /* USB audio format type (1-3) */
164         unsigned int pkt_offset_adj;    /* Byt    128         unsigned int pkt_offset_adj;    /* Bytes to drop from beginning of packets (for non-compliant devices) */
165         unsigned int stream_offset_adj; /* Byt << 
166                                                   129 
167         unsigned int running: 1;        /* run    130         unsigned int running: 1;        /* running status */
168         unsigned int period_elapsed_pending;   << 
169                                                   131 
170         unsigned int buffer_bytes;      /* buf << 
171         unsigned int inflight_bytes;    /* in- << 
172         unsigned int hwptr_done;        /* pro    132         unsigned int hwptr_done;        /* processed byte position in the buffer */
173         unsigned int transfer_done;     /* pro !! 133         unsigned int transfer_done;             /* processed frames since last period update */
174         unsigned int frame_limit;       /* lim    134         unsigned int frame_limit;       /* limits number of packets in URB */
175                                                   135 
176         /* data and sync endpoints for this st    136         /* data and sync endpoints for this stream */
177         unsigned int ep_num;            /* the    137         unsigned int ep_num;            /* the endpoint number */
178         struct snd_usb_endpoint *data_endpoint    138         struct snd_usb_endpoint *data_endpoint;
179         struct snd_usb_endpoint *sync_endpoint    139         struct snd_usb_endpoint *sync_endpoint;
180         unsigned long flags;                      140         unsigned long flags;
                                                   >> 141         bool need_setup_ep;             /* (re)configure EP at prepare? */
181         unsigned int speed;             /* USB    142         unsigned int speed;             /* USB_SPEED_XXX */
182                                                   143 
183         u64 formats;                    /* for    144         u64 formats;                    /* format bitmasks (all or'ed) */
184         unsigned int num_formats;                 145         unsigned int num_formats;               /* number of supported audio formats (list) */
185         struct list_head fmt_list;      /* for    146         struct list_head fmt_list;      /* format list */
                                                   >> 147         struct snd_pcm_hw_constraint_list rate_list;    /* limited rates */
186         spinlock_t lock;                          148         spinlock_t lock;
187                                                   149 
188         unsigned int last_frame_number; /* sto !! 150         int last_frame_number;          /* stored frame number */
                                                   >> 151         int last_delay;                 /* stored delay */
189                                                   152 
190         struct {                                  153         struct {
191                 int marker;                       154                 int marker;
192                 int channel;                      155                 int channel;
193                 int byte_idx;                     156                 int byte_idx;
194         } dsd_dop;                                157         } dsd_dop;
195                                                   158 
196         bool trigger_tstamp_pending_update; /*    159         bool trigger_tstamp_pending_update; /* trigger timestamp being updated from initial estimate */
197         bool lowlatency_playback;       /* low << 
198         struct media_ctl *media_ctl;           << 
199 };                                                160 };
200                                                   161 
201 struct snd_usb_stream {                           162 struct snd_usb_stream {
202         struct snd_usb_audio *chip;               163         struct snd_usb_audio *chip;
203         struct snd_pcm *pcm;                      164         struct snd_pcm *pcm;
204         int pcm_index;                            165         int pcm_index;
205         unsigned int fmt_type;          /* USB    166         unsigned int fmt_type;          /* USB audio format type (1-3) */
206         struct snd_usb_substream substream[2];    167         struct snd_usb_substream substream[2];
207         struct list_head list;                    168         struct list_head list;
208 };                                                169 };
209                                                   170 
210 #endif /* __USBAUDIO_CARD_H */                    171 #endif /* __USBAUDIO_CARD_H */
211                                                   172 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php