From d8d303508433bf0332bf040bb9b6ac7746595b23 Mon Sep 17 00:00:00 2001 From: zhushengle Date: Fri, 11 Nov 2022 09:39:35 +0800 Subject: [PATCH] =?UTF-8?q?fixed=200b05a46=20from=20https://gitee.com/zhus?= =?UTF-8?q?hengle/kernel=5Fliteos=5Fa/pulls/1061=20task:=20time=E7=9B=B8?= =?UTF-8?q?=E5=85=B3=E7=B3=BB=E7=BB=9F=E8=B0=83=E7=94=A8=E5=86=85=E6=A0=B8?= =?UTF-8?q?=E6=A0=88=E4=BF=A1=E6=81=AF=E6=B3=84=E9=9C=B2=E6=8E=92=E6=9F=A5?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 解决方案: 在涉及从内核拷贝数据到用户态的场景时,先将内核的数据进行清零操作,再填充内核数据 Close #I60M1P Signed-off-by: zhushengle Change-Id: Ia61d4e39b9e190accea477ff5b361e41d0eed2af --- syscall/time_syscall.c | 23 ++++++++++++----------- 1 file changed, 12 insertions(+), 11 deletions(-) diff --git a/syscall/time_syscall.c b/syscall/time_syscall.c index ea87f298..4b59748f 100644 --- a/syscall/time_syscall.c +++ b/syscall/time_syscall.c @@ -109,7 +109,7 @@ int SysSetiTimer(int which, const struct itimerval *value, struct itimerval *ova { int ret; struct itimerval svalue; - struct itimerval sovalue; + struct itimerval sovalue = { 0 }; if (value == NULL) { errno = EINVAL; @@ -137,7 +137,7 @@ int SysSetiTimer(int which, const struct itimerval *value, struct itimerval *ova int SysGetiTimer(int which, struct itimerval *value) { int ret; - struct itimerval svalue; + struct itimerval svalue = { 0 }; if (value == NULL) { errno = EINVAL; @@ -189,7 +189,7 @@ int SysTimerCreate(clockid_t clockID, struct ksigevent *evp, timer_t *timerID) int SysTimerGettime(timer_t timerID, struct itimerspec *value) { int ret; - struct itimerspec svalue; + struct itimerspec svalue = { 0 }; if (value == NULL) { errno = EINVAL; @@ -213,7 +213,7 @@ int SysTimerSettime(timer_t timerID, int flags, const struct itimerspec *value, { int ret; struct itimerspec svalue; - struct itimerspec soldValue; + struct itimerspec soldValue = { 0 }; if (value == NULL) { errno = EINVAL; @@ -285,7 +285,7 @@ int SysClockSettime(clockid_t clockID, const struct timespec *tp) int SysClockGettime(clockid_t clockID, struct timespec *tp) { int ret; - struct timespec stp; + struct timespec stp = { 0 }; if (tp == NULL) { errno = EINVAL; @@ -308,7 +308,7 @@ int SysClockGettime(clockid_t clockID, struct timespec *tp) int SysClockGetres(clockid_t clockID, struct timespec *tp) { int ret; - struct timespec stp; + struct timespec stp = { 0 }; if (tp == NULL) { errno = EINVAL; @@ -356,7 +356,7 @@ int SysNanoSleep(const struct timespec *rqtp, struct timespec *rmtp) { int ret; struct timespec srqtp; - struct timespec srmtp; + struct timespec srmtp = { 0 }; if (!rqtp || LOS_ArchCopyFromUser(&srqtp, rqtp, sizeof(struct timespec))) { errno = EFAULT; @@ -384,7 +384,7 @@ int SysNanoSleep(const struct timespec *rqtp, struct timespec *rmtp) clock_t SysTimes(struct tms *buf) { clock_t ret; - struct tms sbuf; + struct tms sbuf = { 0 }; if (buf == NULL) { errno = EFAULT; @@ -436,7 +436,7 @@ int SysClockGettime64(clockid_t clockID, struct timespec64 *tp) { int ret; struct timespec t; - struct timespec64 stp; + struct timespec64 stp = { 0 }; if (tp == NULL) { errno = EINVAL; @@ -463,7 +463,7 @@ int SysClockGetres64(clockid_t clockID, struct timespec64 *tp) { int ret; struct timespec t; - struct timespec64 stp; + struct timespec64 stp = { 0 }; if (tp == NULL) { errno = EINVAL; @@ -525,7 +525,7 @@ int SysTimerGettime64(timer_t timerID, struct itimerspec64 *value) { int ret; struct itimerspec val; - struct itimerspec64 svalue; + struct itimerspec64 svalue = { 0 }; if (value == NULL) { errno = EINVAL; @@ -584,6 +584,7 @@ int SysTimerSettime64(timer_t timerID, int flags, const struct itimerspec64 *val } if (oldValue != NULL) { + (void)memset_s(&soldValue, sizeof(struct itimerspec64), 0, sizeof(struct itimerspec64)); soldValue.it_interval.tv_sec = oldVal.it_interval.tv_sec; soldValue.it_interval.tv_nsec = oldVal.it_interval.tv_nsec; soldValue.it_value.tv_sec = oldVal.it_value.tv_sec; -- GitLab