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:
parent
541f30878a
commit
8ecca52b27
1 changed files with 11 additions and 11 deletions
|
@ -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);
|
||||||
|
|
Loading…
Reference in a new issue