mirror of
https://github.com/cirosantilli/linux-kernel-module-cheat.git
synced 2026-01-23 02:05:57 +01:00
userland/arch/aarch64/inline_asm/futex_sev.cpp
This commit is contained in:
@@ -18804,6 +18804,10 @@ so we conclude that:
|
||||
|
||||
Therefore, a WFE in userland is treated much like a busy loop by the Linux kernel: the kernel does not seem to try and explicitly make up room for other processes as would happen on a futex.
|
||||
|
||||
The following test checks that SEV events don't wake up a futexes, running forever in case of success. In <<gem5-syscall-emulation-multithreading>>, this is crucial to prevent deadlocks:
|
||||
|
||||
* link:userland/arch/aarch64/inline_asm/futex_sev.cpp[]
|
||||
|
||||
====== ARMv8 spinlock pattern
|
||||
|
||||
http://infocenter.arm.com/help/index.jsp?topic=/com.arm.doc.faqs/ka16277.html
|
||||
|
||||
@@ -525,6 +525,7 @@ path_properties_tuples = (
|
||||
},
|
||||
{
|
||||
'freestanding': freestanding_properties,
|
||||
'futex_sev.cpp': {'more_than_1s': True},
|
||||
'sve_addvl.c': {'arm_sve': True},
|
||||
'wfe_sev.c': {
|
||||
# gem5 bug, WFE not waking up on syscall emulation,
|
||||
|
||||
35
userland/arch/aarch64/inline_asm/futex_sev.cpp
Normal file
35
userland/arch/aarch64/inline_asm/futex_sev.cpp
Normal file
@@ -0,0 +1,35 @@
|
||||
// https://cirosantilli.com/linux-kernel-module-cheat#wfe-from-userland
|
||||
|
||||
#ifndef _GNU_SOURCE
|
||||
#define _GNU_SOURCE
|
||||
#endif
|
||||
#include <atomic>
|
||||
#include <iostream>
|
||||
#include <mutex>
|
||||
#include <thread>
|
||||
|
||||
#include <lkmc/futex.h>
|
||||
|
||||
std::atomic_ulong done;
|
||||
int futex = 1;
|
||||
|
||||
void myfunc() {
|
||||
lkmc_futex(&futex, FUTEX_WAIT, futex, NULL, NULL, 0);
|
||||
done.store(futex);
|
||||
}
|
||||
|
||||
int main(int argc, char **argv) {
|
||||
bool do_sev = true;
|
||||
if (argc > 1) {
|
||||
do_sev = (argv[1][0] != '0');
|
||||
}
|
||||
done.store(0);
|
||||
std::thread thread;
|
||||
thread = std::thread(myfunc);
|
||||
while (!done.load()) {
|
||||
if (do_sev) {
|
||||
__asm__ __volatile__ ("sev");
|
||||
}
|
||||
}
|
||||
thread.join();
|
||||
}
|
||||
Reference in New Issue
Block a user