Page MenuHomeFreeBSD

Unify metadata load files for arm, mips, powerpc, sparc64
ClosedPublic

Authored by jhibbits on Jan 19 2018, 1:45 AM.
Tags
None
Referenced Files
F108157101: D13978.diff
Tue, Jan 21, 11:59 PM
Unknown Object (File)
Thu, Jan 2, 9:51 AM
Unknown Object (File)
Dec 2 2024, 9:41 AM
Unknown Object (File)
Dec 2 2024, 9:41 AM
Unknown Object (File)
Dec 2 2024, 9:41 AM
Unknown Object (File)
Dec 2 2024, 9:41 AM
Unknown Object (File)
Dec 2 2024, 9:40 AM
Unknown Object (File)
Nov 23 2024, 2:01 PM
Subscribers

Details

Summary

All metadata.c files are very similar, with only trivial changes. Unify them
into a single common file, with minor special-casing where needed.

This has been compile-tested only so far, with tinderbox.

Test Plan

Build and run where able

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 14964
Build 15076: arc lint + arc unit

Event Timeline

I think this is a great idea. Don't see any obvious problems with the implementation.

andrew added inline comments.
stand/loader.mk
20

Shouldn't this only be built for ubldr on arm?

stand/common/metadata.c
111–147

This needs to be centralized. We have too many copies of it. While this is a good start, more needs to be done. Not a change request, per se, just an observation. This does help a lot, however.

157–165

Why not md_setbootargs? And require that the md code provide one, or a common one that does the else? We need to do something similar with EFI and parsing ConnIn / ConnOut and ConnErr...

276–284

So vm_offset_t can be different between 32-bit and 64-bit builds. Do we need to worry about that?

stand/loader.mk
20

We really need to start just building everything and putting it into a library. This twisty maze of ifdefs is insane.

stand/common/metadata.c
111–147

A lot more work needs to be done as a whole. Let's save that for the next step of cleanup.

157–165

That can be done. I wasn't too excited about the \#ifdef here anyway, but figured if we dump sparc64 soonish, this will go away anyway. Then we don't even need to bother with a md_setbootargs().

276–284

Yes, but it's only significant on powerpc, where vm_offset_t is 32-bit, but this can load 64-bit kernels. MIPS has this code as well, but the 32-bit case is never used.

If we \#ifdef out the 'unused' md_load*() function, this should be compiled down to virtually the same code as before on all platforms, unless the compiler isn't smart enough to elide the unused kern64 argument.

stand/loader.mk
20

I agree. Step 42 in cleanup?

20

I could move this, until said library is created, into arm/uboot/Makefile. Going into the efiloader it's just unused code (does our linker prune executables? It'd be nice if it did).

stand/loader.mk
20

I just took a look.

The problem isn't that it isn't used for EFI.

The problem EFI has it's own copy of these routines that are similar yet different in efi/loader/bootinfo.c (and bizarrely in efi/loader/arch/i386/bootinfo.c, but that one looks to be a bit-rotted version of the former). Perhaps you could look into the differences to see if they are real or not?

stand/loader.mk
20

A quick look at the file indicates the only differences are bi_load_efi_data(), and one small bit in bi_load(), adding MODINFOMD_FW_HANDLE. Beyond that, it looks identical to md_load(). Kill it with fire.

stand/loader.mk
20

Fire in this commit, or a future one?

stand/loader.mk
20

Future commit. I don't want to risk the vast majority of users just yet. I'd rather an x86 user do it, too.

Update per feedback. Passes make universe.

One thing left to do, but will be done after this change, will be to add the
swizzling from r328536. As that was contentious, I won't add it immediately,
but will make it a separate change.

The BERI stuff looks good to me.

This revision is now accepted and ready to land.Feb 12 2018, 11:02 PM
This revision was automatically updated to reflect the committed changes.