Page 1 of 1

Rust UEFI

Posted: Sun Sep 18, 2016 10:15 am
by vlad9486
Here http://wiki.osdev.org/Rust_Bare_Bones suggested to disable function sections in rustc. What does it mean and how can I do this?

Re: Rust UEFI

Posted: Sun Sep 18, 2016 11:17 am
by Rusky
Linkers work at the level of sections when deciding what to include in their output. "Function sections" (-ffunction-sections) is an option that Rust enables in LLVM to put each function in its own section, enabling the linker (with another option, --gc-sections) to leave out unused functions in the final binary.

This is mostly helpful in userspace applications that link large libraries they only need part of, and is only supported by some linkers (e.g. not MSVC's link.exe, if you happen to be using that for UEFI). You can disable it by passing this to rustc: -C llvm-args=-fno-function-sections

Re: Rust UEFI

Posted: Sun Sep 18, 2016 1:58 pm
by vlad9486
Thanks for the answer. I don't use link.exe, I link with x86_64-efi-pe-ld from binutils. So, I should not care about this issue.

Re: Rust UEFI

Posted: Sun Sep 18, 2016 3:31 pm
by Rusky
Well, you will be able to use --gc-sections with that linker, but you're still using the PE format so you may still run into the limit depending on how much you try to do in your bootloader. I would just keep that in mind for the future and leave -ffunction-sections on for now.

Re: Rust UEFI

Posted: Sun Sep 18, 2016 11:25 pm
by Boris
UEFI apps are executables in PE format, which can contain up to 64k sections. If you plan to have more functions than that, you have to enable that option.