diff options
| author | Andrea Parri <parri.andrea@gmail.com> | 2023-08-03 06:27:38 +0200 | 
|---|---|---|
| committer | Palmer Dabbelt <palmer@rivosinc.com> | 2023-08-08 15:28:37 -0700 | 
| commit | 4eb2eb1b4c0eb07793c240744843498564a67b83 (patch) | |
| tree | 5f1555b7754f49cdf99cc4c39c56778af191fd1f /tools/testing/selftests/bpf/prog_tests/autoload.c | |
| parent | 6514f81e1bd55cbe419a5001a4ce910acc276211 (diff) | |
riscv,mmio: Fix readX()-to-delay() ordering
Section 2.1 of the Platform Specification [1] states:
  Unless otherwise specified by a given I/O device, I/O devices are on
  ordering channel 0 (i.e., they are point-to-point strongly ordered).
which is not sufficient to guarantee that a readX() by a hart completes
before a subsequent delay() on the same hart (cf. memory-barriers.txt,
"Kernel I/O barrier effects").
Set the I(nput) bit in __io_ar() to restore the ordering, align inline
comments.
[1] https://github.com/riscv/riscv-platform-specs
Signed-off-by: Andrea Parri <parri.andrea@gmail.com>
Link: https://lore.kernel.org/r/20230803042738.5937-1-parri.andrea@gmail.com
Fixes: fab957c11efe ("RISC-V: Atomic and Locking Code")
Cc: stable@vger.kernel.org
Signed-off-by: Palmer Dabbelt <palmer@rivosinc.com>
Diffstat (limited to 'tools/testing/selftests/bpf/prog_tests/autoload.c')
0 files changed, 0 insertions, 0 deletions
