-
Notifications
You must be signed in to change notification settings - Fork 220
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
ostimer.c functions not using semaphore #92
Comments
Imported from trac issue 69. Created by abrown4 on 2015-07-01T16:43:49, last modified: 2015-12-01T14:13:03 |
Trac comment by abrown4 on 2015-07-28 12:36:33: Reviewed the above commit with #103 in mind. If the functions that access the table, OS_TimerGetIdByName() and the internal OS_TimerSignalHandler(), follow the same paradigm then they don't need modification. Similarly, OS_TimerSet() modifies the table entry but the access pattern might not collide with other tasks given the expected usage patterns. Discuss. MUST CHANGE: OS_TimerSignalHandler() invokes a callback. This should not occur while the table is locked. |
Trac comment by abrown4 on 2015-07-28 14:58:16: commit: [changeset:270c2dc] Trac #92, Removed table locks in ostimer.c OS_TimerSignalHandler(). |
Trac comment by abrown4 on 2015-08-20 18:24:31: From the above commits, as of #45 [changeset:6a9db70], the white-box unit test still shows that OS_TimerSignalHandler() doesn't safely access the OS_timer_table (3 test failures from ostimer_wb test). |
The VxWorks ostimer.c has a static table and a semaphore to protect it, as in:
{{{
static OS_timer_record_t OS_timer_table[OS_MAX_TIMERS];
static uint32 os_clock_accuracy;
/*
** The Semaphore for protecting the above table
*/
static SEM_ID OS_timer_table_sem;
}}}
Unfortunately, only OS_TimerCreate(), and OS_TimerGetInfo() use that semaphore.
'''OS_TimerCreate(), OS_TimerSet(), OS_TimerDelete() do not''' and they '''modify''' the table. '''OS_TimerGetIdByName()''' and the internal '''OS_TimerSignalHandler()''' also access (read) the table without using the semaphore.
The OS_TimerAPIInit() creates the semaphore, the time conversion functions don't access the table.
Recommend fixing all the functions that access or modify the table to acquire the semaphore after passing input argument checks.
The text was updated successfully, but these errors were encountered: