mirror of https://gitee.com/openkylin/linux.git
ALSA: pcxhr: convert timeval to ktime_t
This patch is concerned with migrating the time variables in the pcxhr module found in the sound driver. The changes are concerend with the y2038 problem where timeval will overflow in the year 2038. ktime_t was used instead of timeval to get the wall time. The difference is displayed now in nanoseconds instead of microseconds. Signed-off-by: Aya Mahfouz <mahfouz.saif.elyazal@gmail.com> Reviewed-by: Arnd Bergmann <arnd@arndb.de> Signed-off-by: Takashi Iwai <tiwai@suse.de>
This commit is contained in:
parent
66797f36fd
commit
326f0480b7
|
@ -711,8 +711,9 @@ static void pcxhr_start_linked_stream(struct pcxhr_mgr *mgr)
|
|||
int playback_mask = 0;
|
||||
|
||||
#ifdef CONFIG_SND_DEBUG_VERBOSE
|
||||
struct timeval my_tv1, my_tv2;
|
||||
do_gettimeofday(&my_tv1);
|
||||
ktime_t start_time, stop_time, diff_time;
|
||||
|
||||
start_time = ktime_get();
|
||||
#endif
|
||||
mutex_lock(&mgr->setup_mutex);
|
||||
|
||||
|
@ -823,9 +824,10 @@ static void pcxhr_start_linked_stream(struct pcxhr_mgr *mgr)
|
|||
mutex_unlock(&mgr->setup_mutex);
|
||||
|
||||
#ifdef CONFIG_SND_DEBUG_VERBOSE
|
||||
do_gettimeofday(&my_tv2);
|
||||
stop_time = ktime_get();
|
||||
diff_time = ktime_sub(stop_time, start_time);
|
||||
dev_dbg(&mgr->pci->dev, "***TRIGGER START*** TIME = %ld (err = %x)\n",
|
||||
(long)(my_tv2.tv_usec - my_tv1.tv_usec), err);
|
||||
(long)(ktime_to_ns(diff_time)), err);
|
||||
#endif
|
||||
}
|
||||
|
||||
|
|
|
@ -910,8 +910,9 @@ int pcxhr_set_pipe_state(struct pcxhr_mgr *mgr, int playback_mask,
|
|||
int audio_mask;
|
||||
|
||||
#ifdef CONFIG_SND_DEBUG_VERBOSE
|
||||
struct timeval my_tv1, my_tv2;
|
||||
do_gettimeofday(&my_tv1);
|
||||
ktime_t start_time, stop_time, diff_time;
|
||||
|
||||
start_time = ktime_get();
|
||||
#endif
|
||||
audio_mask = (playback_mask |
|
||||
(capture_mask << PCXHR_PIPE_STATE_CAPTURE_OFFSET));
|
||||
|
@ -960,9 +961,10 @@ int pcxhr_set_pipe_state(struct pcxhr_mgr *mgr, int playback_mask,
|
|||
return err;
|
||||
}
|
||||
#ifdef CONFIG_SND_DEBUG_VERBOSE
|
||||
do_gettimeofday(&my_tv2);
|
||||
stop_time = ktime_get();
|
||||
diff_time = ktime_sub(stop_time, start_time);
|
||||
dev_dbg(&mgr->pci->dev, "***SET PIPE STATE*** TIME = %ld (err = %x)\n",
|
||||
(long)(my_tv2.tv_usec - my_tv1.tv_usec), err);
|
||||
(long)(ktime_to_ns(diff_time)), err);
|
||||
#endif
|
||||
return 0;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue