Page MenuHomeFreeBSD

RISC-V: fix some broken relocation handling
ClosedPublic

Authored by mhorne on Sep 24 2019, 12:55 AM.
Tags
None
Referenced Files
F107351585: D21773.id62490.diff
Sun, Jan 12, 9:54 PM
Unknown Object (File)
Thu, Dec 26, 6:06 PM
Unknown Object (File)
Dec 9 2024, 12:13 PM
Unknown Object (File)
Dec 7 2024, 4:09 AM
Unknown Object (File)
Nov 25 2024, 7:02 AM
Unknown Object (File)
Oct 28 2024, 2:02 PM
Unknown Object (File)
Oct 28 2024, 2:02 PM
Unknown Object (File)
Oct 28 2024, 2:02 PM
Subscribers

Details

Summary

In a few cases, the symbol lookup is missing before attempting to
perform the relocation. While the relocation types affected are
currently unused, this results in an uninitialized variable warning,
that is escalated to an error when building with clang.

--- elf_machdep.o ---
/usr/src/head/sys/riscv/riscv/elf_machdep.c:440:25: error: variable 'val' is uninitialized when used here [-Werror,-Wuninitialized]
                imm20 = calc_hi20_imm(val);
                                      ^~~
/usr/src/head/sys/riscv/riscv/elf_machdep.c:271:14: note: initialize the variable 'val' to silence this warning
        Elf_Addr val, addr;
                    ^
                     = 0
/usr/src/head/sys/riscv/riscv/elf_machdep.c:391:9: error: variable 'addr' is uninitialized when used here [-Werror,-Wuninitialized]
                val = addr - (Elf_Addr)where;
                      ^~~~
/usr/src/head/sys/riscv/riscv/elf_machdep.c:271:20: note: initialize the variable 'addr' to silence this warning
        Elf_Addr val, addr;
                          ^
                           = 0

Diff Detail

Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 26662
Build 25036: arc lint + arc unit

Event Timeline

Note that I don't have any real way of testing this since as mentioned, none of these relocations are being emitted. I'm not entirely convinced that they are required at all, since this is the case even when compiling kmods without -fPIC. Could they be removed instead?

Note that I don't have any real way of testing this since as mentioned, none of these relocations are being emitted. I'm not entirely convinced that they are required at all, since this is the case even when compiling kmods without -fPIC. Could they be removed instead?

This is really a @br question. :)

I don't think they impose much of a maintenance burden, so I'd be slightly inclined to keep them. They at least provide a starting point should these relocation types start to appear, and in that case we'll notice pretty quickly if any bugs are still lingering. I do not have strong feelings about it though.

This revision is now accepted and ready to land.Sep 24 2019, 2:53 PM
This revision was automatically updated to reflect the committed changes.

Note that I don't have any real way of testing this since as mentioned, none of these relocations are being emitted. I'm not entirely convinced that they are required at all, since this is the case even when compiling kmods without -fPIC. Could they be removed instead?

This is really a @br question. :)

I don't think they impose much of a maintenance burden, so I'd be slightly inclined to keep them. They at least provide a starting point should these relocation types start to appear, and in that case we'll notice pretty quickly if any bugs are still lingering. I do not have strong feelings about it though.

I decided to keep them in absence of any other input. You're right that they should not be much of a burden (other than this patch) and this choice can always be re-evaluated later.

As of this commit we are able to compile the GENERIC kernel completely with clang 9, and are not far off from the full suite of kernel modules.