aboutsummaryrefslogtreecommitdiffstats
path: root/sound/core/pcm_compat.c
diff options
context:
space:
mode:
Diffstat (limited to 'sound/core/pcm_compat.c')
-rw-r--r--sound/core/pcm_compat.c19
1 files changed, 11 insertions, 8 deletions
diff --git a/sound/core/pcm_compat.c b/sound/core/pcm_compat.c
index 91cdf9435fec..af2a3fdb8828 100644
--- a/sound/core/pcm_compat.c
+++ b/sound/core/pcm_compat.c
@@ -190,7 +190,8 @@ struct snd_pcm_status32 {
190 u32 avail_max; 190 u32 avail_max;
191 u32 overrange; 191 u32 overrange;
192 s32 suspended_state; 192 s32 suspended_state;
193 unsigned char reserved[60]; 193 struct compat_timespec audio_tstamp;
194 unsigned char reserved[60-sizeof(struct compat_timespec)];
194} __attribute__((packed)); 195} __attribute__((packed));
195 196
196 197
@@ -205,17 +206,16 @@ static int snd_pcm_status_user_compat(struct snd_pcm_substream *substream,
205 return err; 206 return err;
206 207
207 if (put_user(status.state, &src->state) || 208 if (put_user(status.state, &src->state) ||
208 put_user(status.trigger_tstamp.tv_sec, &src->trigger_tstamp.tv_sec) || 209 compat_put_timespec(&status.trigger_tstamp, &src->trigger_tstamp) ||
209 put_user(status.trigger_tstamp.tv_nsec, &src->trigger_tstamp.tv_nsec) || 210 compat_put_timespec(&status.tstamp, &src->tstamp) ||
210 put_user(status.tstamp.tv_sec, &src->tstamp.tv_sec) ||
211 put_user(status.tstamp.tv_nsec, &src->tstamp.tv_nsec) ||
212 put_user(status.appl_ptr, &src->appl_ptr) || 211 put_user(status.appl_ptr, &src->appl_ptr) ||
213 put_user(status.hw_ptr, &src->hw_ptr) || 212 put_user(status.hw_ptr, &src->hw_ptr) ||
214 put_user(status.delay, &src->delay) || 213 put_user(status.delay, &src->delay) ||
215 put_user(status.avail, &src->avail) || 214 put_user(status.avail, &src->avail) ||
216 put_user(status.avail_max, &src->avail_max) || 215 put_user(status.avail_max, &src->avail_max) ||
217 put_user(status.overrange, &src->overrange) || 216 put_user(status.overrange, &src->overrange) ||
218 put_user(status.suspended_state, &src->suspended_state)) 217 put_user(status.suspended_state, &src->suspended_state) ||
218 compat_put_timespec(&status.audio_tstamp, &src->audio_tstamp))
219 return -EFAULT; 219 return -EFAULT;
220 220
221 return err; 221 return err;
@@ -364,6 +364,7 @@ struct snd_pcm_mmap_status32 {
364 u32 hw_ptr; 364 u32 hw_ptr;
365 struct compat_timespec tstamp; 365 struct compat_timespec tstamp;
366 s32 suspended_state; 366 s32 suspended_state;
367 struct compat_timespec audio_tstamp;
367} __attribute__((packed)); 368} __attribute__((packed));
368 369
369struct snd_pcm_mmap_control32 { 370struct snd_pcm_mmap_control32 {
@@ -426,12 +427,14 @@ static int snd_pcm_ioctl_sync_ptr_compat(struct snd_pcm_substream *substream,
426 sstatus.hw_ptr = status->hw_ptr % boundary; 427 sstatus.hw_ptr = status->hw_ptr % boundary;
427 sstatus.tstamp = status->tstamp; 428 sstatus.tstamp = status->tstamp;
428 sstatus.suspended_state = status->suspended_state; 429 sstatus.suspended_state = status->suspended_state;
430 sstatus.audio_tstamp = status->audio_tstamp;
429 snd_pcm_stream_unlock_irq(substream); 431 snd_pcm_stream_unlock_irq(substream);
430 if (put_user(sstatus.state, &src->s.status.state) || 432 if (put_user(sstatus.state, &src->s.status.state) ||
431 put_user(sstatus.hw_ptr, &src->s.status.hw_ptr) || 433 put_user(sstatus.hw_ptr, &src->s.status.hw_ptr) ||
432 put_user(sstatus.tstamp.tv_sec, &src->s.status.tstamp.tv_sec) || 434 compat_put_timespec(&sstatus.tstamp, &src->s.status.tstamp) ||
433 put_user(sstatus.tstamp.tv_nsec, &src->s.status.tstamp.tv_nsec) ||
434 put_user(sstatus.suspended_state, &src->s.status.suspended_state) || 435 put_user(sstatus.suspended_state, &src->s.status.suspended_state) ||
436 compat_put_timespec(&sstatus.audio_tstamp,
437 &src->s.status.audio_tstamp) ||
435 put_user(scontrol.appl_ptr, &src->c.control.appl_ptr) || 438 put_user(scontrol.appl_ptr, &src->c.control.appl_ptr) ||
436 put_user(scontrol.avail_min, &src->c.control.avail_min)) 439 put_user(scontrol.avail_min, &src->c.control.avail_min))
437 return -EFAULT; 440 return -EFAULT;