1 // SPDX-License-Identifier: GPL-2.0-only
3 * ff-pcm.c - a part of driver for RME Fireface series
5 * Copyright (c) 2015-2017 Takashi Sakamoto
10 static int hw_rule_rate(struct snd_pcm_hw_params
*params
,
11 struct snd_pcm_hw_rule
*rule
)
13 const unsigned int *pcm_channels
= rule
->private;
14 struct snd_interval
*r
=
15 hw_param_interval(params
, SNDRV_PCM_HW_PARAM_RATE
);
16 const struct snd_interval
*c
=
17 hw_param_interval_c(params
, SNDRV_PCM_HW_PARAM_CHANNELS
);
18 struct snd_interval t
= {
19 .min
= UINT_MAX
, .max
= 0, .integer
= 1
23 for (i
= 0; i
< ARRAY_SIZE(amdtp_rate_table
); i
++) {
24 enum snd_ff_stream_mode mode
;
27 err
= snd_ff_stream_get_multiplier_mode(i
, &mode
);
31 if (!snd_interval_test(c
, pcm_channels
[mode
]))
34 t
.min
= min(t
.min
, amdtp_rate_table
[i
]);
35 t
.max
= max(t
.max
, amdtp_rate_table
[i
]);
38 return snd_interval_refine(r
, &t
);
41 static int hw_rule_channels(struct snd_pcm_hw_params
*params
,
42 struct snd_pcm_hw_rule
*rule
)
44 const unsigned int *pcm_channels
= rule
->private;
45 struct snd_interval
*c
=
46 hw_param_interval(params
, SNDRV_PCM_HW_PARAM_CHANNELS
);
47 const struct snd_interval
*r
=
48 hw_param_interval_c(params
, SNDRV_PCM_HW_PARAM_RATE
);
49 struct snd_interval t
= {
50 .min
= UINT_MAX
, .max
= 0, .integer
= 1
54 for (i
= 0; i
< ARRAY_SIZE(amdtp_rate_table
); i
++) {
55 enum snd_ff_stream_mode mode
;
58 err
= snd_ff_stream_get_multiplier_mode(i
, &mode
);
62 if (!snd_interval_test(r
, amdtp_rate_table
[i
]))
65 t
.min
= min(t
.min
, pcm_channels
[mode
]);
66 t
.max
= max(t
.max
, pcm_channels
[mode
]);
69 return snd_interval_refine(c
, &t
);
72 static void limit_channels_and_rates(struct snd_pcm_hardware
*hw
,
73 const unsigned int *pcm_channels
)
75 unsigned int rate
, channels
;
78 hw
->channels_min
= UINT_MAX
;
80 hw
->rate_min
= UINT_MAX
;
83 for (i
= 0; i
< ARRAY_SIZE(amdtp_rate_table
); i
++) {
84 enum snd_ff_stream_mode mode
;
87 err
= snd_ff_stream_get_multiplier_mode(i
, &mode
);
91 channels
= pcm_channels
[mode
];
92 if (pcm_channels
[mode
] == 0)
94 hw
->channels_min
= min(hw
->channels_min
, channels
);
95 hw
->channels_max
= max(hw
->channels_max
, channels
);
97 rate
= amdtp_rate_table
[i
];
98 hw
->rates
|= snd_pcm_rate_to_rate_bit(rate
);
99 hw
->rate_min
= min(hw
->rate_min
, rate
);
100 hw
->rate_max
= max(hw
->rate_max
, rate
);
104 static int pcm_init_hw_params(struct snd_ff
*ff
,
105 struct snd_pcm_substream
*substream
)
107 struct snd_pcm_runtime
*runtime
= substream
->runtime
;
108 struct amdtp_stream
*s
;
109 const unsigned int *pcm_channels
;
112 if (substream
->stream
== SNDRV_PCM_STREAM_CAPTURE
) {
113 runtime
->hw
.formats
= SNDRV_PCM_FMTBIT_S32
;
115 pcm_channels
= ff
->spec
->pcm_capture_channels
;
117 runtime
->hw
.formats
= SNDRV_PCM_FMTBIT_S32
;
119 pcm_channels
= ff
->spec
->pcm_playback_channels
;
122 limit_channels_and_rates(&runtime
->hw
, pcm_channels
);
124 err
= snd_pcm_hw_rule_add(runtime
, 0, SNDRV_PCM_HW_PARAM_CHANNELS
,
125 hw_rule_channels
, (void *)pcm_channels
,
126 SNDRV_PCM_HW_PARAM_RATE
, -1);
130 err
= snd_pcm_hw_rule_add(runtime
, 0, SNDRV_PCM_HW_PARAM_RATE
,
131 hw_rule_rate
, (void *)pcm_channels
,
132 SNDRV_PCM_HW_PARAM_CHANNELS
, -1);
136 return amdtp_ff_add_pcm_hw_constraints(s
, runtime
);
139 static int pcm_open(struct snd_pcm_substream
*substream
)
141 struct snd_ff
*ff
= substream
->private_data
;
142 struct amdtp_domain
*d
= &ff
->domain
;
144 enum snd_ff_clock_src src
;
147 err
= snd_ff_stream_lock_try(ff
);
151 err
= pcm_init_hw_params(ff
, substream
);
155 err
= ff
->spec
->protocol
->get_clock(ff
, &rate
, &src
);
159 mutex_lock(&ff
->mutex
);
161 // When source of clock is not internal or any stream is reserved for
162 // transmission of PCM frames, the available sampling rate is limited
164 if (src
!= SND_FF_CLOCK_SRC_INTERNAL
) {
165 for (i
= 0; i
< CIP_SFC_COUNT
; ++i
) {
166 if (amdtp_rate_table
[i
] == rate
)
170 // The unit is configured at sampling frequency which packet
171 // streaming engine can't support.
172 if (i
>= CIP_SFC_COUNT
) {
173 mutex_unlock(&ff
->mutex
);
178 substream
->runtime
->hw
.rate_min
= rate
;
179 substream
->runtime
->hw
.rate_max
= rate
;
181 if (ff
->substreams_counter
> 0) {
182 unsigned int frames_per_period
= d
->events_per_period
;
183 unsigned int frames_per_buffer
= d
->events_per_buffer
;
185 rate
= amdtp_rate_table
[ff
->rx_stream
.sfc
];
186 substream
->runtime
->hw
.rate_min
= rate
;
187 substream
->runtime
->hw
.rate_max
= rate
;
189 err
= snd_pcm_hw_constraint_minmax(substream
->runtime
,
190 SNDRV_PCM_HW_PARAM_PERIOD_SIZE
,
191 frames_per_period
, frames_per_period
);
193 mutex_unlock(&ff
->mutex
);
197 err
= snd_pcm_hw_constraint_minmax(substream
->runtime
,
198 SNDRV_PCM_HW_PARAM_BUFFER_SIZE
,
199 frames_per_buffer
, frames_per_buffer
);
201 mutex_unlock(&ff
->mutex
);
207 mutex_unlock(&ff
->mutex
);
209 snd_pcm_set_sync(substream
);
214 snd_ff_stream_lock_release(ff
);
218 static int pcm_close(struct snd_pcm_substream
*substream
)
220 struct snd_ff
*ff
= substream
->private_data
;
222 snd_ff_stream_lock_release(ff
);
227 static int pcm_hw_params(struct snd_pcm_substream
*substream
,
228 struct snd_pcm_hw_params
*hw_params
)
230 struct snd_ff
*ff
= substream
->private_data
;
233 err
= snd_pcm_lib_malloc_pages(substream
, params_buffer_bytes(hw_params
));
237 if (substream
->runtime
->status
->state
== SNDRV_PCM_STATE_OPEN
) {
238 unsigned int rate
= params_rate(hw_params
);
239 unsigned int frames_per_period
= params_period_size(hw_params
);
240 unsigned int frames_per_buffer
= params_buffer_size(hw_params
);
242 mutex_lock(&ff
->mutex
);
243 err
= snd_ff_stream_reserve_duplex(ff
, rate
, frames_per_period
,
246 ++ff
->substreams_counter
;
247 mutex_unlock(&ff
->mutex
);
253 static int pcm_hw_free(struct snd_pcm_substream
*substream
)
255 struct snd_ff
*ff
= substream
->private_data
;
257 mutex_lock(&ff
->mutex
);
259 if (substream
->runtime
->status
->state
!= SNDRV_PCM_STATE_OPEN
)
260 --ff
->substreams_counter
;
262 snd_ff_stream_stop_duplex(ff
);
264 mutex_unlock(&ff
->mutex
);
266 return snd_pcm_lib_free_pages(substream
);
269 static int pcm_capture_prepare(struct snd_pcm_substream
*substream
)
271 struct snd_ff
*ff
= substream
->private_data
;
272 struct snd_pcm_runtime
*runtime
= substream
->runtime
;
275 mutex_lock(&ff
->mutex
);
277 err
= snd_ff_stream_start_duplex(ff
, runtime
->rate
);
279 amdtp_stream_pcm_prepare(&ff
->tx_stream
);
281 mutex_unlock(&ff
->mutex
);
286 static int pcm_playback_prepare(struct snd_pcm_substream
*substream
)
288 struct snd_ff
*ff
= substream
->private_data
;
289 struct snd_pcm_runtime
*runtime
= substream
->runtime
;
292 mutex_lock(&ff
->mutex
);
294 err
= snd_ff_stream_start_duplex(ff
, runtime
->rate
);
296 amdtp_stream_pcm_prepare(&ff
->rx_stream
);
298 mutex_unlock(&ff
->mutex
);
303 static int pcm_capture_trigger(struct snd_pcm_substream
*substream
, int cmd
)
305 struct snd_ff
*ff
= substream
->private_data
;
308 case SNDRV_PCM_TRIGGER_START
:
309 amdtp_stream_pcm_trigger(&ff
->tx_stream
, substream
);
311 case SNDRV_PCM_TRIGGER_STOP
:
312 amdtp_stream_pcm_trigger(&ff
->tx_stream
, NULL
);
321 static int pcm_playback_trigger(struct snd_pcm_substream
*substream
, int cmd
)
323 struct snd_ff
*ff
= substream
->private_data
;
326 case SNDRV_PCM_TRIGGER_START
:
327 amdtp_stream_pcm_trigger(&ff
->rx_stream
, substream
);
329 case SNDRV_PCM_TRIGGER_STOP
:
330 amdtp_stream_pcm_trigger(&ff
->rx_stream
, NULL
);
339 static snd_pcm_uframes_t
pcm_capture_pointer(struct snd_pcm_substream
*sbstrm
)
341 struct snd_ff
*ff
= sbstrm
->private_data
;
343 return amdtp_domain_stream_pcm_pointer(&ff
->domain
, &ff
->tx_stream
);
346 static snd_pcm_uframes_t
pcm_playback_pointer(struct snd_pcm_substream
*sbstrm
)
348 struct snd_ff
*ff
= sbstrm
->private_data
;
350 return amdtp_domain_stream_pcm_pointer(&ff
->domain
, &ff
->rx_stream
);
353 static int pcm_capture_ack(struct snd_pcm_substream
*substream
)
355 struct snd_ff
*ff
= substream
->private_data
;
357 return amdtp_domain_stream_pcm_ack(&ff
->domain
, &ff
->tx_stream
);
360 static int pcm_playback_ack(struct snd_pcm_substream
*substream
)
362 struct snd_ff
*ff
= substream
->private_data
;
364 return amdtp_domain_stream_pcm_ack(&ff
->domain
, &ff
->rx_stream
);
367 int snd_ff_create_pcm_devices(struct snd_ff
*ff
)
369 static const struct snd_pcm_ops pcm_capture_ops
= {
372 .ioctl
= snd_pcm_lib_ioctl
,
373 .hw_params
= pcm_hw_params
,
374 .hw_free
= pcm_hw_free
,
375 .prepare
= pcm_capture_prepare
,
376 .trigger
= pcm_capture_trigger
,
377 .pointer
= pcm_capture_pointer
,
378 .ack
= pcm_capture_ack
,
380 static const struct snd_pcm_ops pcm_playback_ops
= {
383 .ioctl
= snd_pcm_lib_ioctl
,
384 .hw_params
= pcm_hw_params
,
385 .hw_free
= pcm_hw_free
,
386 .prepare
= pcm_playback_prepare
,
387 .trigger
= pcm_playback_trigger
,
388 .pointer
= pcm_playback_pointer
,
389 .ack
= pcm_playback_ack
,
394 err
= snd_pcm_new(ff
->card
, ff
->card
->driver
, 0, 1, 1, &pcm
);
398 pcm
->private_data
= ff
;
399 snprintf(pcm
->name
, sizeof(pcm
->name
),
400 "%s PCM", ff
->card
->shortname
);
401 snd_pcm_set_ops(pcm
, SNDRV_PCM_STREAM_PLAYBACK
, &pcm_playback_ops
);
402 snd_pcm_set_ops(pcm
, SNDRV_PCM_STREAM_CAPTURE
, &pcm_capture_ops
);
403 snd_pcm_lib_preallocate_pages_for_all(pcm
, SNDRV_DMA_TYPE_VMALLOC
,