TaiJuWu commented on code in PR #10605: URL: https://github.com/apache/nuttx/pull/10605#discussion_r1327995460
########## sched/semaphore/spinlock.c: ########## @@ -384,4 +384,176 @@ void spin_clrbit(FAR volatile cpu_set_t *set, unsigned int cpu, } #endif +/**************************************************************************** + * Name: fair_spinlock_list_init + * + * Description: + * Initialize the link linsk of fair spinlock. + * If there is any spinlock node, the node will get lock. + * + * Input Parameters: + * lock_list - A reference to the spinlock list. + * + * Returned Value: + * None + * + * Assumptions: + * None. + * + ****************************************************************************/ + +void fair_spinlock_list_init(fair_spinlock_list_t *lock_list) +{ + lock_list->lock = SP_UNLOCKED; + list_initialize(&lock_list->list); +} + +/**************************************************************************** + * Name: fair_spinlock_init + * + * Description: + * Initialize the fair spinlock. Tje lock state is set as SP_LOCK util + * some give lock to holder. + * + * Input Parameters: + * lock - A reference to the spinlock object to lock. + * + * Returned Value: + * None + * + * Assumptions: + * Not running at the interrupt level. + * + ****************************************************************************/ + +void fair_spinlock_init(fair_spinlock_t *lock) +{ + lock->lock = SP_LOCKED; + lock->holder = this_task(); + list_initialize(&lock->node); +} + +/**************************************************************************** + * Name: fair_spin_lock + * + * Description: + * Try to lock the spinlock and insert this lock to lock list. + * If list is empty, the caller can get the lock. + * If list is not empty, the lock will be inserted to this list. + * + * Input Parameters: + * lock_list - A reference to fair lock list and insert this lock to list. + * fair_lock - A reference to the spinlock object to lock. + * + * Returned Value: + * None + * + * Assumptions: + * Not running at the interrupt level. + * + ****************************************************************************/ + +void fair_spin_lock(FAR fair_spinlock_list_t *lock_list, + FAR fair_spinlock_t *fair_lock) +{ + FAR struct tcb_s *rtcb = this_task(); + fair_spinlock_t *entry; + fair_spinlock_t *temp; + +#ifdef CONFIG_SCHED_INSTRUMENTATION_SPINLOCKS + /* Notify that we have the spinlock */ + + sched_note_spinlock(this_task(), &fair_lock->lock, NOTE_SPINLOCK_LOCKED); +#endif + + /* There is no thread wait this lock */ + + spin_lock(&lock_list->lock); + + /* There is no node hold this lock */ + + if (list_is_empty(&lock_list->list)) + { + fair_lock->lock = SP_UNLOCKED; + list_add_head(&lock_list->list, &fair_lock->node); + } + + /* There is a task hold this lock */ + + else + { + /* priority based link list */ + + list_for_every_entry_safe(&lock_list->list, entry, temp, + struct fair_spinlock_s, node) + { + if (entry->holder->sched_priority > rtcb->sched_priority) + { + break; + } + } + + list_add_before(&entry->node, &fair_lock->node); + } + + spin_unlock(&lock_list->lock); + + while (up_testset(&fair_lock->lock) == SP_LOCKED) Review Comment: If thread 0 at T0 want to get the lock. thread 1 at T1 and thread 2 at T2, it will get lock by order. Because there is a queue (lock_list) maintain the order Ideally. But there is a bottleneck which is the lock_list spinlock... It effects performance a lot. -- This is an automated message from the Apache Git Service. To respond to the message, please log on to GitHub and use the URL above to go to the specific comment. To unsubscribe, e-mail: commits-unsubscr...@nuttx.apache.org For queries about this service, please contact Infrastructure at: us...@infra.apache.org