Fix compilation of locore.S with clang
The branch from _start to mpentry has to cross a large section of data; an offset larger than can be specified with a 12-bit branch immediate. Fix this by converting the branch to an unconditional jump. The gcc assembler does this conversion silently but it is not done automatically by clang. Reported by: Jeremy Bennett <jeremy.bennett@embecosm.com> Reviewed by: markj Approved by: markj (mentor) MFC after: 1 week Differential Revision: https://reviews.freebsd.org/D21437
This commit is contained in:
parent
09e90944bc
commit
199d0f1085
@ -69,12 +69,18 @@ _start:
|
||||
la t0, hart_lottery
|
||||
li t1, 1
|
||||
amoadd.w t0, t1, 0(t0)
|
||||
bnez t0, mpentry
|
||||
|
||||
/*
|
||||
* We must jump to mpentry in the non-BSP case because the offset is
|
||||
* too large to fit in a 12-bit branch immediate.
|
||||
*/
|
||||
beqz t0, 1f
|
||||
j mpentry
|
||||
|
||||
/*
|
||||
* Page tables
|
||||
*/
|
||||
|
||||
1:
|
||||
/* Add L1 entry for kernel */
|
||||
la s1, pagetable_l1
|
||||
la s2, pagetable_l2 /* Link to next level PN */
|
||||
|
Loading…
x
Reference in New Issue
Block a user