1
0
mirror of https://github.com/0xAX/linux-insides.git synced 2025-01-18 11:41:08 +00:00

Fix __down function

This commit is contained in:
Xiaoqin Hu 2016-06-01 18:29:07 -07:00
parent 8998362d50
commit f9eda4ac05

View File

@ -129,7 +129,7 @@ We may see the definition of the `flags` variable at the beginning of the `down`
As you already may guess, the main work is done between the `raw_spin_lock_irqsave` and `raw_spin_unlock_irqrestore` macros in the `down` function. We compare the value of the `semaphore` counter with zero and if it is bigger than zero, we may decrement this counter. This means that we already acquired the lock. In other way counter is zero. This means that all available resources already finished and we need to wait to acquire this lock. As we may see, the `__down` function will be called in this case.
The `__down` function is defined in the [same](https://github.com/torvalds/linux/blob/master/kernel/locking/semaphore.c)) source code file and its implementation looks:
The `__down` function is defined in the [same](https://github.com/torvalds/linux/blob/master/kernel/locking/semaphore.c) source code file and its implementation looks:
```C
static noinline void __sched __down(struct semaphore *sem)
@ -138,7 +138,7 @@ static noinline void __sched __down(struct semaphore *sem)
}
```
The just calls the `__down_common` function with three parameters:
The `__down` function just calls the `__down_common` function with three parameters:
* `semaphore`;
* `flag` - for the task;