mirror of
https://github.com/0xAX/linux-insides.git
synced 2024-12-22 06:38:07 +00:00
Merge pull request #765 from Mutated1994/patch-9
Update linux-timers-2.md
This commit is contained in:
commit
ff53caa2da
@ -304,14 +304,20 @@ Note that before the first will be called, we lock the `clocksource_mutex` [mute
|
||||
The first `clocksource_enqueue` function and other two defined in the same source code [file](https://github.com/torvalds/linux/tree/master/kernel/time/clocksource.c). We go through all already registered `clocksources` or in other words we go through all elements of the `clocksource_list` and tries to find best place for a given `clocksource`:
|
||||
|
||||
```C
|
||||
/*
|
||||
* Enqueue the clocksource sorted by rating
|
||||
*/
|
||||
static void clocksource_enqueue(struct clocksource *cs)
|
||||
{
|
||||
struct list_head *entry = &clocksource_list;
|
||||
struct clocksource *tmp;
|
||||
|
||||
list_for_each_entry(tmp, &clocksource_list, list)
|
||||
if (tmp->rating >= cs->rating)
|
||||
entry = &tmp->list;
|
||||
list_for_each_entry(tmp, &clocksource_list, list) {
|
||||
/* Keep track of the place, where to insert */
|
||||
if (tmp->rating < cs->rating)
|
||||
break;
|
||||
entry = &tmp->list;
|
||||
}
|
||||
list_add(&cs->list, entry);
|
||||
}
|
||||
```
|
||||
|
Loading…
Reference in New Issue
Block a user