[RFC][PATCH 0/2] Access console drivers list under console_sem

From: Sergey Senozhatsky
Date: Tue Apr 23 2019 - 02:25:22 EST


Petr, Steven,

RFC

Normally, we grab console_sem lock before we iterate consoles
list, which is necessary if we want to be race free. The only exception
to this rule is console_flush_on_panic(). However, it seems that we are
not fully race free - register_console() iterates console drivers list
in unsafe manner in several places. E.g. the following scenarion:

CPU0 CPU1
register_console() unregister_console()
console_lock()
for_each_console() // modify console_drivers
con->foo kfree(con)

So I have two quick-n-dirty patches, which remove unsafe console list
access.

What do you think?

Sergey Senozhatsky (2):
printk: lock console_sem before we unregister boot consoles
printk: take console_sem when accessing console drivers list

kernel/printk/printk.c | 117 ++++++++++++++++++++++++-----------------
1 file changed, 69 insertions(+), 48 deletions(-)

--
2.21.0