Page MenuHomeFreeBSD

RISC-V: fix global pointer assignment at boot
ClosedPublic

Authored by mhorne on Jan 11 2020, 11:52 PM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Jan 6, 1:56 AM
Unknown Object (File)
Dec 13 2024, 4:59 PM
Unknown Object (File)
Dec 13 2024, 2:51 PM
Unknown Object (File)
Nov 22 2024, 11:20 AM
Unknown Object (File)
Oct 30 2024, 12:17 PM
Unknown Object (File)
Oct 20 2024, 8:18 AM
Unknown Object (File)
Oct 3 2024, 9:57 PM
Unknown Object (File)
Oct 3 2024, 8:29 PM
Subscribers

Details

Summary

As part of the RISC-V ABI, the gp register is expected to initialized
with the address of __global_pointer$ as early as possible. This allows
loads and stores from .sdata to be relaxed based on the value of gp. In
locore.S we do this initialization twice, once each for va and mpva.
However, in both cases the initialization is preceded by an la
instruction, which in theory could be relaxed by the linker.

Move the initialization of gp to be slightly earlier (before la
cpu_exception_handler), and add an additional gp initialization at the
very beginning of _start, before virtual memory is set up.

Reported by: jrtc27

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

Yep, this is what I was thinking of (with the lla fixed). Thanks!

sys/riscv/riscv/locore.S
59 ↗(On Diff #66635)

This needs to be an lla.

sys/riscv/riscv/locore.S
330 ↗(On Diff #66635)

Maybe add the again, this time with the virtual address. comment to match the BSP case (and to make it clear that mpentry itself is inheriting the physical gp from _start)?

Use lla, not la. Use longer comment for mpva as well.

Ping. Are you happy with this?

This revision is now accepted and ready to land.Jan 16 2020, 8:34 PM
This revision was automatically updated to reflect the committed changes.