Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Replace libelf/elfutils with elftoolchain #83

Open
dslm4515 opened this issue Jan 28, 2023 · 19 comments
Open

Replace libelf/elfutils with elftoolchain #83

dslm4515 opened this issue Jan 28, 2023 · 19 comments
Assignees
Labels
question Further information is requested

Comments

@dslm4515
Copy link
Owner

dslm4515 commented Jan 28, 2023

Replacing libelf/elfutils with elftoolchain will eliminate the need for musl-obstack

Binutils could be moved from /usr to /opt/gnu as secondary binutils
OR
Create a script to switch between elftoolchain and binutils

@dslm4515 dslm4515 added the enhancement New feature or request label Jan 28, 2023
@dslm4515 dslm4515 self-assigned this Jan 28, 2023
@firasuke
Copy link
Contributor

May I ask why is this an enhancement?

@dslm4515
Copy link
Owner Author

musl-obstack requires autotools to build (no configure script, just configue.ac)

But of course, elftoolchain requires libarchive ... so i guess it just trading musl-obstack for libarchive

@firasuke
Copy link
Contributor

firasuke commented Jan 28, 2023

Doesn't the kernel also require musl-obstack? Or is that another dependency on libelf?

@dslm4515
Copy link
Owner Author

I noticed that Chimera Linux does not have a musl-obstack package unlike Void and Linux. Per Alpine package repo, only libelf/elfutils [and other packages not built in MLFS] depends on musl-obstack. I lost my old notes when I first developed MLFS, as I'm sure i added musl-obstack for a reason [elfutils/libelf]

I am in the middle of building CMLFS with elftoolchain. I'll see if its an issue once I build the kernel

@firasuke
Copy link
Contributor

Okay, good luck! Please keep us updated.

@dslm4515
Copy link
Owner Author

dslm4515 commented Feb 4, 2023

I just realized compiling the Linux kernel (mainstream) might be tricky... i.e. objcopy will not be from binutils, but from elf toolchain. I will be using Chimera Linux's cports repo for guidance

@dslm4515
Copy link
Owner Author

dslm4515 commented Feb 4, 2023

When compiling, there are lots of warnings but kernel compiles:

warning: objtool: gelf_update_symshndx: Invalid argument
warning: objtool: elf_update_symbol move

@dslm4515
Copy link
Owner Author

dslm4515 commented Feb 6, 2023

And.... I built CMLFS without binutils and GCC, except when I used mussel to build stage0 clang!

@firasuke
Copy link
Contributor

firasuke commented Apr 3, 2023

So were you able to replace libelf from elfutils and musl-obstack by using elftoolchain alone?

@dslm4515
Copy link
Owner Author

dslm4515 commented Apr 3, 2023

Yes. I was able to build CMLFS without libelf (elfutils) and musl-obstack... and without binutils & GCC for the final system.

Only drawback is that elftoolchain Requires bmake and lsb-tools (or a lsb-release script). Perhaps with enough patches, elftoolchain may build with GNU's make and without lsb-tools

@firasuke
Copy link
Contributor

firasuke commented Apr 3, 2023

Interesting, so we lost some dependencies, but gained two more.

Thanks for the update!

@dslm4515
Copy link
Owner Author

dslm4515 commented May 9, 2023

I also realized nothing depends on argp-standalone, according to Alpine Linux package database. This is false: v4l-utils requires it.
I am halfway done with a 2nd CMLFS build with elftoolchain... and came across this package. I will skip it to see if anything requires it. I think it was elfutils that did. Maybe.

In my previous CMLFS build, no package requires musl-obstack ...even up to when building mesa, wayland, and a DE.

Also, @firasuke you can now add CMLFS to projects that use mussel :P ... as master branch now does.

@firasuke
Copy link
Contributor

firasuke commented May 9, 2023

I also realized nothing depends on argp-standalone, according to Alpine Linux package database. I am halfway done with a 2nd CMLFS build with elftoolchain... and came across this package. I will skip it to see if anything requires it. I think it was elfutils that did. Maybe.

I am using libuargp instead of argp-standalone, and I think only libelf from elfutils depends on it. Same goes for musl-obstack, only elfutils depends on it.

Also, @firasuke you can now add CMLFS to projects that use mussel :P ... as master branch now does.

Already did, 2 weeks ago :)

@firasuke
Copy link
Contributor

firasuke commented May 9, 2023

I think oasis uses elftoolchain as well.

@dslm4515
Copy link
Owner Author

dslm4515 commented May 9, 2023

I found an updated fork of argp-standalone.... bumping the version from 1.3 to 1.5.0... lol, i guess with the success of elftoolchain and you mentioning libuargp, its no longer needed!

I think oasis uses elftoolchain as well.

Oasis? I'll have to check that.

@dslm4515
Copy link
Owner Author

dslm4515 commented Dec 1, 2023

I just checked today: Chimera Linux no longer uses elftoolchain. It apparently switched to elfutils in the past year or so.
I couldn't find [a] definite reason[s].

This might make it harder for me to continue to use elftoolschain since I will have to develop patches when there is an issue.

Also, perhaps its time for me to re-evaluate my decision to replace elfutils with elftoolchain.

@firasuke
Copy link
Contributor

firasuke commented Dec 1, 2023

Also, perhaps its time for me to re-evaluate my decision to replace elfutils with elftoolchain.

What benefit does elftoolchain provide over elfutils?

@dslm4515
Copy link
Owner Author

dslm4515 commented Dec 3, 2023

From experience, elftoolchain can be used as a drop-in replacement for binutils (so far, I had no package fail to compile with elftoolchain). Although, it's not complete: 4 utilities & 2 libraries are not released (either planned, in-development, or in alpha-stage)... But enough to compile packages in CMLFS and BMLFS.

But in terms of compiling it, it requires bmake (and libarchive & LSB tools/script).

In my search for elftoolchain vs binutils comparisons, I realized elfutils is another alternative to binutils. I may consider trying elfutils as the system binary tools. I couldn't find any comparisons posted online...

For now, elftoolchain can be an alternative if for some reason Binutils fails to compile for whatever reason. Or for licensing issues(?).

@dslm4515 dslm4515 added question Further information is requested and removed enhancement New feature or request labels Dec 3, 2023
@q66
Copy link

q66 commented Dec 9, 2023

elftoolchain precludes having libdw (which is a part of elfutils and links against libelf), which significantly reduces usefulness of tools like perf/strace; it also makes it impossible to build specific tools (e.g. flatpak-builder)

besides that, glacial development pace, lack of DT_RELR support, lack of debuginfod support, lack of objdump, etc

chimera has switched to having llvm provide the binutils (which are significantly more featureful and less buggy) and elfutils exists primarily for libelf/libdw

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
question Further information is requested
Projects
None yet
Development

No branches or pull requests

3 participants