aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/uapi/sound/asound.h6
-rw-r--r--sound/core/pcm_native.c3
2 files changed, 7 insertions, 2 deletions
diff --git a/include/uapi/sound/asound.h b/include/uapi/sound/asound.h
index cbf7dc850a46..a7e062f91f39 100644
--- a/include/uapi/sound/asound.h
+++ b/include/uapi/sound/asound.h
@@ -139,7 +139,7 @@ struct snd_hwdep_dsp_image {
139 * * 139 * *
140 *****************************************************************************/ 140 *****************************************************************************/
141 141
142#define SNDRV_PCM_VERSION SNDRV_PROTOCOL_VERSION(2, 0, 11) 142#define SNDRV_PCM_VERSION SNDRV_PROTOCOL_VERSION(2, 0, 12)
143 143
144typedef unsigned long snd_pcm_uframes_t; 144typedef unsigned long snd_pcm_uframes_t;
145typedef signed long snd_pcm_sframes_t; 145typedef signed long snd_pcm_sframes_t;
@@ -391,7 +391,9 @@ struct snd_pcm_sw_params {
391 snd_pcm_uframes_t silence_threshold; /* min distance from noise for silence filling */ 391 snd_pcm_uframes_t silence_threshold; /* min distance from noise for silence filling */
392 snd_pcm_uframes_t silence_size; /* silence block size */ 392 snd_pcm_uframes_t silence_size; /* silence block size */
393 snd_pcm_uframes_t boundary; /* pointers wrap point */ 393 snd_pcm_uframes_t boundary; /* pointers wrap point */
394 unsigned char reserved[64]; /* reserved for future */ 394 unsigned int tstamp_type; /* timestamp type */
395 int pads; /* alignment, reserved */
396 unsigned char reserved[56]; /* reserved for future */
395}; 397};
396 398
397struct snd_pcm_channel_info { 399struct snd_pcm_channel_info {
diff --git a/sound/core/pcm_native.c b/sound/core/pcm_native.c
index 2372c49a8e84..81dedc381efd 100644
--- a/sound/core/pcm_native.c
+++ b/sound/core/pcm_native.c
@@ -543,6 +543,8 @@ static int snd_pcm_sw_params(struct snd_pcm_substream *substream,
543 543
544 if (params->tstamp_mode > SNDRV_PCM_TSTAMP_LAST) 544 if (params->tstamp_mode > SNDRV_PCM_TSTAMP_LAST)
545 return -EINVAL; 545 return -EINVAL;
546 if (params->tstamp_type > SNDRV_PCM_TSTAMP_TYPE_LAST)
547 return -EINVAL;
546 if (params->avail_min == 0) 548 if (params->avail_min == 0)
547 return -EINVAL; 549 return -EINVAL;
548 if (params->silence_size >= runtime->boundary) { 550 if (params->silence_size >= runtime->boundary) {
@@ -557,6 +559,7 @@ static int snd_pcm_sw_params(struct snd_pcm_substream *substream,
557 err = 0; 559 err = 0;
558 snd_pcm_stream_lock_irq(substream); 560 snd_pcm_stream_lock_irq(substream);
559 runtime->tstamp_mode = params->tstamp_mode; 561 runtime->tstamp_mode = params->tstamp_mode;
562 runtime->tstamp_type = params->tstamp_type;
560 runtime->period_step = params->period_step; 563 runtime->period_step = params->period_step;
561 runtime->control->avail_min = params->avail_min; 564 runtime->control->avail_min = params->avail_min;
562 runtime->start_threshold = params->start_threshold; 565 runtime->start_threshold = params->start_threshold;