sched/timer: Simplify setitimer implementation.

This commit simplified setitmer implementation by eliminating a redundant conditional branch.

Signed-off-by: ouyangxiangzhen <ouyangxiangzhen@xiaomi.com>
This commit is contained in:
ouyangxiangzhen 2024-10-18 16:10:28 +08:00 committed by Xiang Xiao
parent 541f30878a
commit 8ecca52b27

View file

@ -89,7 +89,7 @@
int setitimer(int which, FAR const struct itimerval *value, int setitimer(int which, FAR const struct itimerval *value,
FAR struct itimerval *ovalue) FAR struct itimerval *ovalue)
{ {
FAR struct tcb_s *rtcb = this_task(); FAR struct tcb_s *rtcb;
struct itimerspec spec; struct itimerspec spec;
struct itimerspec ospec; struct itimerspec ospec;
irqstate_t flags; irqstate_t flags;
@ -101,20 +101,20 @@ int setitimer(int which, FAR const struct itimerval *value,
return ERROR; return ERROR;
} }
rtcb = this_task();
flags = enter_critical_section();
if (!rtcb->group->itimer) if (!rtcb->group->itimer)
{ {
flags = enter_critical_section(); ret = timer_create(CLOCK_REALTIME, NULL, &rtcb->group->itimer);
if (!rtcb->group->itimer) }
{
ret = timer_create(CLOCK_REALTIME, NULL, &rtcb->group->itimer);
}
leave_critical_section(flags); leave_critical_section(flags);
if (ret != OK) if (ret != OK)
{ {
return ret; return ret;
}
} }
TIMEVAL_TO_TIMESPEC(&value->it_value, &spec.it_value); TIMEVAL_TO_TIMESPEC(&value->it_value, &spec.it_value);