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

TOMOYO Linux Cross Reference
Linux/sound/firewire/digi00x/digi00x.h

Version: ~ [ linux-6.11-rc3 ] ~ [ linux-6.10.4 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.45 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.104 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.164 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.223 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.281 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.319 ] ~ [ 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.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /sound/firewire/digi00x/digi00x.h (Version linux-6.11-rc3) and /sound/firewire/digi00x/digi00x.h (Version linux-4.17.19)


  1 /* SPDX-License-Identifier: GPL-2.0-only */    << 
  2 /*                                                  1 /*
  3  * digi00x.h - a part of driver for Digidesign      2  * digi00x.h - a part of driver for Digidesign Digi 002/003 family
  4  *                                                  3  *
  5  * Copyright (c) 2014-2015 Takashi Sakamoto         4  * Copyright (c) 2014-2015 Takashi Sakamoto
                                                   >>   5  *
                                                   >>   6  * Licensed under the terms of the GNU General Public License, version 2.
  6  */                                                 7  */
  7                                                     8 
  8 #ifndef SOUND_DIGI00X_H_INCLUDED                    9 #ifndef SOUND_DIGI00X_H_INCLUDED
  9 #define SOUND_DIGI00X_H_INCLUDED                   10 #define SOUND_DIGI00X_H_INCLUDED
 10                                                    11 
 11 #include <linux/compat.h>                          12 #include <linux/compat.h>
 12 #include <linux/device.h>                          13 #include <linux/device.h>
 13 #include <linux/firewire.h>                        14 #include <linux/firewire.h>
 14 #include <linux/module.h>                          15 #include <linux/module.h>
 15 #include <linux/mod_devicetable.h>                 16 #include <linux/mod_devicetable.h>
 16 #include <linux/delay.h>                           17 #include <linux/delay.h>
 17 #include <linux/slab.h>                            18 #include <linux/slab.h>
 18 #include <linux/sched/signal.h>                    19 #include <linux/sched/signal.h>
 19                                                    20 
 20 #include <sound/core.h>                            21 #include <sound/core.h>
 21 #include <sound/initval.h>                         22 #include <sound/initval.h>
 22 #include <sound/info.h>                            23 #include <sound/info.h>
 23 #include <sound/pcm.h>                             24 #include <sound/pcm.h>
 24 #include <sound/pcm_params.h>                      25 #include <sound/pcm_params.h>
 25 #include <sound/firewire.h>                        26 #include <sound/firewire.h>
 26 #include <sound/hwdep.h>                           27 #include <sound/hwdep.h>
 27 #include <sound/rawmidi.h>                         28 #include <sound/rawmidi.h>
 28                                                    29 
 29 #include "../lib.h"                                30 #include "../lib.h"
 30 #include "../iso-resources.h"                      31 #include "../iso-resources.h"
 31 #include "../amdtp-stream.h"                       32 #include "../amdtp-stream.h"
 32                                                    33 
 33 struct snd_dg00x {                                 34 struct snd_dg00x {
 34         struct snd_card *card;                     35         struct snd_card *card;
 35         struct fw_unit *unit;                      36         struct fw_unit *unit;
 36                                                    37 
 37         struct mutex mutex;                        38         struct mutex mutex;
 38         spinlock_t lock;                           39         spinlock_t lock;
 39                                                    40 
                                                   >>  41         bool registered;
                                                   >>  42         struct delayed_work dwork;
                                                   >>  43 
 40         struct amdtp_stream tx_stream;             44         struct amdtp_stream tx_stream;
 41         struct fw_iso_resources tx_resources;      45         struct fw_iso_resources tx_resources;
 42                                                    46 
 43         struct amdtp_stream rx_stream;             47         struct amdtp_stream rx_stream;
 44         struct fw_iso_resources rx_resources;      48         struct fw_iso_resources rx_resources;
 45                                                    49 
 46         unsigned int substreams_counter;           50         unsigned int substreams_counter;
 47                                                    51 
 48         /* for uapi */                             52         /* for uapi */
 49         int dev_lock_count;                        53         int dev_lock_count;
 50         bool dev_lock_changed;                     54         bool dev_lock_changed;
 51         wait_queue_head_t hwdep_wait;              55         wait_queue_head_t hwdep_wait;
 52                                                    56 
 53         /* For asynchronous messages. */           57         /* For asynchronous messages. */
 54         struct fw_address_handler async_handle     58         struct fw_address_handler async_handler;
 55         u32 msg;                                   59         u32 msg;
 56                                                    60 
 57         /* Console models have additional MIDI     61         /* Console models have additional MIDI ports for control surface. */
 58         bool is_console;                           62         bool is_console;
 59                                                << 
 60         struct amdtp_domain domain;            << 
 61 };                                                 63 };
 62                                                    64 
 63 #define DG00X_ADDR_BASE         0xffffe0000000     65 #define DG00X_ADDR_BASE         0xffffe0000000ull
 64                                                    66 
 65 #define DG00X_OFFSET_STREAMING_STATE    0x0000     67 #define DG00X_OFFSET_STREAMING_STATE    0x0000
 66 #define DG00X_OFFSET_STREAMING_SET      0x0004     68 #define DG00X_OFFSET_STREAMING_SET      0x0004
 67 /* unknown but address in host space    0x0008     69 /* unknown but address in host space    0x0008 */
 68 /* For LSB of the address               0x000c     70 /* For LSB of the address               0x000c */
 69 /* unknown                              0x0010     71 /* unknown                              0x0010 */
 70 #define DG00X_OFFSET_MESSAGE_ADDR       0x0014     72 #define DG00X_OFFSET_MESSAGE_ADDR       0x0014
 71 /* For LSB of the address               0x0018     73 /* For LSB of the address               0x0018 */
 72 /* unknown                              0x001c     74 /* unknown                              0x001c */
 73 /* unknown                              0x0020     75 /* unknown                              0x0020 */
 74 /* not used                     0x0024--0x00ff     76 /* not used                     0x0024--0x00ff */
 75 #define DG00X_OFFSET_ISOC_CHANNELS      0x0100     77 #define DG00X_OFFSET_ISOC_CHANNELS      0x0100
 76 /* unknown                              0x0104     78 /* unknown                              0x0104 */
 77 /* unknown                              0x0108     79 /* unknown                              0x0108 */
 78 /* unknown                              0x010c     80 /* unknown                              0x010c */
 79 #define DG00X_OFFSET_LOCAL_RATE         0x0110     81 #define DG00X_OFFSET_LOCAL_RATE         0x0110
 80 #define DG00X_OFFSET_EXTERNAL_RATE      0x0114     82 #define DG00X_OFFSET_EXTERNAL_RATE      0x0114
 81 #define DG00X_OFFSET_CLOCK_SOURCE       0x0118     83 #define DG00X_OFFSET_CLOCK_SOURCE       0x0118
 82 #define DG00X_OFFSET_OPT_IFACE_MODE     0x011c     84 #define DG00X_OFFSET_OPT_IFACE_MODE     0x011c
 83 /* unknown                              0x0120     85 /* unknown                              0x0120 */
 84 /* Mixer control on/off                 0x0124     86 /* Mixer control on/off                 0x0124 */
 85 /* unknown                              0x0128     87 /* unknown                              0x0128 */
 86 #define DG00X_OFFSET_DETECT_EXTERNAL    0x012c     88 #define DG00X_OFFSET_DETECT_EXTERNAL    0x012c
 87 /* unknown                              0x0138     89 /* unknown                              0x0138 */
 88 #define DG00X_OFFSET_MMC                0x0400     90 #define DG00X_OFFSET_MMC                0x0400
 89                                                    91 
 90 enum snd_dg00x_rate {                              92 enum snd_dg00x_rate {
 91         SND_DG00X_RATE_44100 = 0,                  93         SND_DG00X_RATE_44100 = 0,
 92         SND_DG00X_RATE_48000,                      94         SND_DG00X_RATE_48000,
 93         SND_DG00X_RATE_88200,                      95         SND_DG00X_RATE_88200,
 94         SND_DG00X_RATE_96000,                      96         SND_DG00X_RATE_96000,
 95         SND_DG00X_RATE_COUNT,                      97         SND_DG00X_RATE_COUNT,
 96 };                                                 98 };
 97                                                    99 
 98 enum snd_dg00x_clock {                            100 enum snd_dg00x_clock {
 99         SND_DG00X_CLOCK_INTERNAL = 0,             101         SND_DG00X_CLOCK_INTERNAL = 0,
100         SND_DG00X_CLOCK_SPDIF,                    102         SND_DG00X_CLOCK_SPDIF,
101         SND_DG00X_CLOCK_ADAT,                     103         SND_DG00X_CLOCK_ADAT,
102         SND_DG00X_CLOCK_WORD,                     104         SND_DG00X_CLOCK_WORD,
103         SND_DG00X_CLOCK_COUNT,                    105         SND_DG00X_CLOCK_COUNT,
104 };                                                106 };
105                                                   107 
106 enum snd_dg00x_optical_mode {                     108 enum snd_dg00x_optical_mode {
107         SND_DG00X_OPT_IFACE_MODE_ADAT = 0,        109         SND_DG00X_OPT_IFACE_MODE_ADAT = 0,
108         SND_DG00X_OPT_IFACE_MODE_SPDIF,           110         SND_DG00X_OPT_IFACE_MODE_SPDIF,
109         SND_DG00X_OPT_IFACE_MODE_COUNT,           111         SND_DG00X_OPT_IFACE_MODE_COUNT,
110 };                                                112 };
111                                                   113 
112 #define DOT_MIDI_IN_PORTS       1                 114 #define DOT_MIDI_IN_PORTS       1
113 #define DOT_MIDI_OUT_PORTS      2                 115 #define DOT_MIDI_OUT_PORTS      2
114                                                   116 
115 int amdtp_dot_init(struct amdtp_stream *s, str    117 int amdtp_dot_init(struct amdtp_stream *s, struct fw_unit *unit,
116                    enum amdtp_stream_direction    118                    enum amdtp_stream_direction dir);
117 int amdtp_dot_set_parameters(struct amdtp_stre    119 int amdtp_dot_set_parameters(struct amdtp_stream *s, unsigned int rate,
118                              unsigned int pcm_    120                              unsigned int pcm_channels);
119 void amdtp_dot_reset(struct amdtp_stream *s);     121 void amdtp_dot_reset(struct amdtp_stream *s);
120 int amdtp_dot_add_pcm_hw_constraints(struct am    122 int amdtp_dot_add_pcm_hw_constraints(struct amdtp_stream *s,
121                                      struct sn    123                                      struct snd_pcm_runtime *runtime);
122 void amdtp_dot_midi_trigger(struct amdtp_strea    124 void amdtp_dot_midi_trigger(struct amdtp_stream *s, unsigned int port,
123                           struct snd_rawmidi_s    125                           struct snd_rawmidi_substream *midi);
124                                                   126 
125 int snd_dg00x_transaction_register(struct snd_    127 int snd_dg00x_transaction_register(struct snd_dg00x *dg00x);
126 int snd_dg00x_transaction_reregister(struct sn    128 int snd_dg00x_transaction_reregister(struct snd_dg00x *dg00x);
127 void snd_dg00x_transaction_unregister(struct s    129 void snd_dg00x_transaction_unregister(struct snd_dg00x *dg00x);
128                                                   130 
129 extern const unsigned int snd_dg00x_stream_rat    131 extern const unsigned int snd_dg00x_stream_rates[SND_DG00X_RATE_COUNT];
130 extern const unsigned int snd_dg00x_stream_pcm    132 extern const unsigned int snd_dg00x_stream_pcm_channels[SND_DG00X_RATE_COUNT];
131 int snd_dg00x_stream_get_external_rate(struct     133 int snd_dg00x_stream_get_external_rate(struct snd_dg00x *dg00x,
132                                        unsigne    134                                        unsigned int *rate);
133 int snd_dg00x_stream_get_local_rate(struct snd    135 int snd_dg00x_stream_get_local_rate(struct snd_dg00x *dg00x,
134                                     unsigned i    136                                     unsigned int *rate);
135 int snd_dg00x_stream_set_local_rate(struct snd    137 int snd_dg00x_stream_set_local_rate(struct snd_dg00x *dg00x, unsigned int rate);
136 int snd_dg00x_stream_get_clock(struct snd_dg00    138 int snd_dg00x_stream_get_clock(struct snd_dg00x *dg00x,
137                                enum snd_dg00x_    139                                enum snd_dg00x_clock *clock);
138 int snd_dg00x_stream_check_external_clock(stru    140 int snd_dg00x_stream_check_external_clock(struct snd_dg00x *dg00x,
139                                           bool    141                                           bool *detect);
140 int snd_dg00x_stream_init_duplex(struct snd_dg    142 int snd_dg00x_stream_init_duplex(struct snd_dg00x *dg00x);
141 int snd_dg00x_stream_reserve_duplex(struct snd !! 143 int snd_dg00x_stream_start_duplex(struct snd_dg00x *dg00x, unsigned int rate);
142                                     unsigned i << 
143                                     unsigned i << 
144 int snd_dg00x_stream_start_duplex(struct snd_d << 
145 void snd_dg00x_stream_stop_duplex(struct snd_d    144 void snd_dg00x_stream_stop_duplex(struct snd_dg00x *dg00x);
146 void snd_dg00x_stream_update_duplex(struct snd    145 void snd_dg00x_stream_update_duplex(struct snd_dg00x *dg00x);
147 void snd_dg00x_stream_destroy_duplex(struct sn    146 void snd_dg00x_stream_destroy_duplex(struct snd_dg00x *dg00x);
148                                                   147 
149 void snd_dg00x_stream_lock_changed(struct snd_    148 void snd_dg00x_stream_lock_changed(struct snd_dg00x *dg00x);
150 int snd_dg00x_stream_lock_try(struct snd_dg00x    149 int snd_dg00x_stream_lock_try(struct snd_dg00x *dg00x);
151 void snd_dg00x_stream_lock_release(struct snd_    150 void snd_dg00x_stream_lock_release(struct snd_dg00x *dg00x);
152                                                   151 
153 void snd_dg00x_proc_init(struct snd_dg00x *dg0    152 void snd_dg00x_proc_init(struct snd_dg00x *dg00x);
154                                                   153 
155 int snd_dg00x_create_pcm_devices(struct snd_dg    154 int snd_dg00x_create_pcm_devices(struct snd_dg00x *dg00x);
156                                                   155 
157 int snd_dg00x_create_midi_devices(struct snd_d    156 int snd_dg00x_create_midi_devices(struct snd_dg00x *dg00x);
158                                                   157 
159 int snd_dg00x_create_hwdep_device(struct snd_d    158 int snd_dg00x_create_hwdep_device(struct snd_dg00x *dg00x);
160 #endif                                            159 #endif
161                                                   160 

~ [ 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