[PATCH 0/6] sched: Cleanup task_struct::state

From: Peter Zijlstra
Date: Wed Jun 02 2021 - 09:31:51 EST


Hi!

The task_struct::state variable is a bit odd in a number of ways:

- it's declared 'volatile' (against current practises);
- it's 'unsigned long' which is a weird size;
- it's type is inconsistent when used for function arguments.

These patches clean that up by making it consistently 'unsigned int', and
replace (almost) all accesses with READ_ONCE()/WRITE_ONCE(). In order to not
miss any, the variable is renamed, ensuring a missed conversion results in a
compile error.

The first few patches fix a number of pre-existing errors and introduce a few
helpers to make the final conversion less painful.