Skip to content

Commit 9ab4059

Browse files
luyahanV8 LUCI CQ
authored and
V8 LUCI CQ
committed
[riscv] Flush icache in both local and remote harts
Fix the I-Cache flush flag according to the implementation of flush_icache_mm in Linux kernel. Change-Id: I6e6b1f56c377c2c0a629e170737bfac6c357ce8d Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/6080611 Commit-Queue: Yahan Lu (LuYahan) <[email protected]> Reviewed-by: Ji Qiu <[email protected]> Cr-Commit-Position: refs/heads/main@{#97673}
1 parent 3fc356b commit 9ab4059

File tree

1 file changed

+2
-6
lines changed

1 file changed

+2
-6
lines changed

src/codegen/riscv/cpu-riscv.cc

+2-6
Original file line numberDiff line numberDiff line change
@@ -15,16 +15,12 @@ namespace internal {
1515
void CpuFeatures::FlushICache(void* start, size_t size) {
1616
#if !defined(USE_SIMULATOR)
1717
char* end = reinterpret_cast<char*>(start) + size;
18-
// The definition of this syscall is equal to
19-
// SYSCALL_DEFINE3(riscv_flush_icache, uintptr_t, start,
20-
// uintptr_t, end, uintptr_t, flags)
21-
// The flag here is set to be SYS_RISCV_FLUSH_ICACHE_LOCAL, which is
22-
// defined as 1 in the Linux kernel.
2318
// SYS_riscv_flush_icache is a symbolic constant used in user-space code to
2419
// identify the flush_icache system call, while __NR_riscv_flush_icache is the
2520
// corresponding system call number used in the kernel to dispatch the system
2621
// call.
27-
syscall(__NR_riscv_flush_icache, start, end, 1);
22+
// The flag set to zero will flush all cpu cores.
23+
syscall(__NR_riscv_flush_icache, start, end, 0);
2824
#endif // !USE_SIMULATOR.
2925
}
3026

0 commit comments

Comments
 (0)