diff options
| -rw-r--r-- | include/sound/pcm.h | 1 | ||||
| -rw-r--r-- | sound/core/pcm_native.c | 4 |
2 files changed, 4 insertions, 1 deletions
diff --git a/include/sound/pcm.h b/include/sound/pcm.h index 07299b295233..c0ddb7e69c28 100644 --- a/include/sound/pcm.h +++ b/include/sound/pcm.h | |||
| @@ -285,6 +285,7 @@ struct snd_pcm_runtime { | |||
| 285 | /* -- Status -- */ | 285 | /* -- Status -- */ |
| 286 | struct snd_pcm_substream *trigger_master; | 286 | struct snd_pcm_substream *trigger_master; |
| 287 | struct timespec trigger_tstamp; /* trigger timestamp */ | 287 | struct timespec trigger_tstamp; /* trigger timestamp */ |
| 288 | bool trigger_tstamp_latched; /* trigger timestamp latched in low-level driver/hardware */ | ||
| 288 | int overrange; | 289 | int overrange; |
| 289 | snd_pcm_uframes_t avail_max; | 290 | snd_pcm_uframes_t avail_max; |
| 290 | snd_pcm_uframes_t hw_ptr_base; /* Position at buffer restart */ | 291 | snd_pcm_uframes_t hw_ptr_base; /* Position at buffer restart */ |
diff --git a/sound/core/pcm_native.c b/sound/core/pcm_native.c index 4ecd35fbfe3f..b03a638b420c 100644 --- a/sound/core/pcm_native.c +++ b/sound/core/pcm_native.c | |||
| @@ -810,7 +810,8 @@ static void snd_pcm_trigger_tstamp(struct snd_pcm_substream *substream) | |||
| 810 | if (runtime->trigger_master == NULL) | 810 | if (runtime->trigger_master == NULL) |
| 811 | return; | 811 | return; |
| 812 | if (runtime->trigger_master == substream) { | 812 | if (runtime->trigger_master == substream) { |
| 813 | snd_pcm_gettime(runtime, &runtime->trigger_tstamp); | 813 | if (!runtime->trigger_tstamp_latched) |
| 814 | snd_pcm_gettime(runtime, &runtime->trigger_tstamp); | ||
| 814 | } else { | 815 | } else { |
| 815 | snd_pcm_trigger_tstamp(runtime->trigger_master); | 816 | snd_pcm_trigger_tstamp(runtime->trigger_master); |
| 816 | runtime->trigger_tstamp = runtime->trigger_master->runtime->trigger_tstamp; | 817 | runtime->trigger_tstamp = runtime->trigger_master->runtime->trigger_tstamp; |
| @@ -979,6 +980,7 @@ static int snd_pcm_pre_start(struct snd_pcm_substream *substream, int state) | |||
| 979 | if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK && | 980 | if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK && |
| 980 | !snd_pcm_playback_data(substream)) | 981 | !snd_pcm_playback_data(substream)) |
| 981 | return -EPIPE; | 982 | return -EPIPE; |
| 983 | runtime->trigger_tstamp_latched = false; | ||
| 982 | runtime->trigger_master = substream; | 984 | runtime->trigger_master = substream; |
| 983 | return 0; | 985 | return 0; |
| 984 | } | 986 | } |
