diff options
author | Ard Biesheuvel <[email protected]> | 2018-07-20 10:47:18 +0900 |
---|---|---|
committer | Ingo Molnar <[email protected]> | 2018-07-22 14:13:42 +0200 |
commit | 83a0a2ea0b991927e42984be220329e776ce7137 (patch) | |
tree | fdff0c9c76bbf2e850677c7f0c4c0f1022dd5783 /tools/perf/scripts/python/net_dropmonitor.py | |
parent | 61f0d55569463a1af897117ff47d202b0ccb2e24 (diff) |
efi/x86: Prevent reentrant firmware calls in mixed mode
The UEFI spec does not permit runtime services to be called
reentrantly, and so it is up to the OS to provide proper locking
around such calls.
For the native case, this was fixed a long time ago, but for the
mixed mode case, no locking is done whatsoever. Note that the calls
are made with preemption and interrupts disabled, so only SMP
configurations are affected by this issue.
So add a spinlock and grab it when invoking a UEFI runtime service
in mixed mode. We will also need to provide non-blocking versions
of SetVariable() and QueryVariableInfo(), so add those as well.
Tested-by: Hans de Goede <[email protected]>
Signed-off-by: Ard Biesheuvel <[email protected]>
Cc: Andy Shevchenko <[email protected]>
Cc: Linus Torvalds <[email protected]>
Cc: Lukas Wunner <[email protected]>
Cc: Peter Zijlstra <[email protected]>
Cc: Thomas Gleixner <[email protected]>
Cc: [email protected]
Link: http://lkml.kernel.org/r/[email protected]
Signed-off-by: Ingo Molnar <[email protected]>
Diffstat (limited to 'tools/perf/scripts/python/net_dropmonitor.py')
0 files changed, 0 insertions, 0 deletions