[PATCH 2/2] riscv: Eagerly flush in flush_icache_deferred()
Andrea Parri
parri.andrea at gmail.com
Fri Aug 16 02:27:47 PDT 2024
> I should have added some memory barriers. I want to have the stores to
> task->mm->context.force_icache_flush and
> task->mm->context.icache_stale_mask in riscv_set_icache_flush_ctx() from
> one hart to be visible by another hart that is observing the values in
> flush_icache_deferred() and switch_to_should_flush_icache(). Then also
> for the changes to those variables in flush_icache_deferred() and
> switch_to_should_flush_icache() to be visible in future invocations of
> those functions.
[...]
> Oh okay so we will need to do a memory barrier before the fence.i in the
> userspace program. I don't believe a memory barrier will be necessary in
> the kernel though while this prctl is active, will the kernel ensure
> memory coherence upon migration?
Yes, the kernel enforces coherence upon migration:(*) in the example
at stake, this means that T1 will have a coherent view of memory when
migrating from CPU1 to CPU3.
To leverage this property, we (or the user application) would need to
provide some synchronization between T2 (that modifies the code) and
T1. This typically involves some form of barrier pairing.
Feel free to reach out, here on the list or in private chats, for any
related memory-barrier doubts I might be able to clarify.
Andrea
(*) A malicious/buggy hypervisor could migrate (virtual)CPU X, and all
its threads, at any time and way allowed by Murphy's law. :-) I take
it as that goes beyond the scope of this series...
More information about the linux-riscv
mailing list