-
-
Notifications
You must be signed in to change notification settings - Fork 14.8k
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
mips64-linux: declare it an n32 ABI target #237815
Conversation
configureFlags = callFile ../common/configure-flags.nix { } | ||
# On mips64-unknown-linux-gnu libsanitizer defines collide with | ||
# glibc's definitions and fail the build. It was fixed in gcc-13+. | ||
++ lib.optionals targetPlatform.isMips [ "--disable-libsanitizer" ]; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We could be more specific here (like in my PR), since it's only an issue when the ABI isn't otherwise specified. Not sure if it's worth it or not. Up to @amjoseph-nixpkgs as an actual MIPS user, I'd say.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah, narrowing it down to n32
ABI sounds reasonable. Would be nice if our isMips64n32
helper worked as is. Not sure if it's broken helper or I'm using it incorrectly:
$ nix repl . --argstr crossSystem mips64-linux
nix-repl> stdenv.targetPlatform.config
"mips64-unknown-linux-gnu"
nix-repl> stdenv.targetPlatform.isMips64n32 # (was stdenv.hostPlatform.isMips64n32 before)
false
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
And pkgs/development/compilers/gcc/common/platform-flags.nix
already contains the equivalent code:
(lib.optional targetPlatform.isMips64n32 "--disable-libsanitizer") # libsanitizer does not compile on mips64n32
That explains why pkgsCross.mips64-linux-gnuabin32
is able to compile. Maybe we should just fix the predicate here.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fixed mips64-linux
to return true
for isMips64n32
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
6cec030 looked like the right solution; I'm testing that right now...
Without the change build on mips64-unknown-linux-gnu fails as: $ nix-build -A buildPackages.gcc12 --argstr crossSystem mips64-linux In file included from ...-glibc-mips64-unknown-linux-gnu-2.37-8-dev/include/bits/stat.h:25, from ...-glibc-mips64-unknown-linux-gnu-2.37-8-dev/include/fcntl.h:78, from ../../../../gcc-12.3.0/libsanitizer/sanitizer_common/sanitizer_linux.cpp:55: ...-glibc-mips64-unknown-linux-gnu-2.37-8-dev/include/bits/struct_stat.h:190:8: error: redefinition of 'struct stat64' 190 | struct stat64 | ^~~~~~
6cec030
to
5acf9bb
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please don't do this!
The n32 ABI is great for routers or machines with less than 4gb of RAM, but -- like the other two popular ILP32 ABIs (aarch64_ilp32
and the x86
x32
ABI) probably shouldn't be the default for any architecture.
Also, in the MIPS case, right now there are two pain points:
boost-context
does not support n32 yet- it needs to know the entire processor context state, including local variables on the stack, so it can save/restore a thread. This requires hand-written assembler for every ABI, and nobody's done this for n32 yet.
- this means you can't run Nix itself on n32
- Rust doesn't support n32 yet
I'm working on both of these myself, but it's a low-priority task. My routers actually run a mixed abin32/abi64 userspace, where everything that uses Rust or boost-context is built for abi64 and the rest is abin32.
Fortunately as part of my work on #235230 I discovered a way to trick both Nix and gnu-config into letting the user specify the ABI without needing two hyphens:
mips64el-linux
(abi64)mips64el-linuxabin32
(abin32)
$ config.sub mips64el-linuxabin32
mips64el-unknown-linux-gnuabin32
$ config.sub mips64el-linux
mips64el-unknown-linux-gnu
As soon as I finish #235230 (hopefully this week) I will submit a PR to Nix so it understands that the "double" *-linuxabin32
means "I want the n32 ABI".
At the risk of stating the obvious
... AFAIU the change did not alter this fact and only exposed it to the packages so they would enable the usual |
Wow that was not obvious to me; thank you for letting me know!
I totally agree. Trying to figure out where things went wrong here. |
Description of changes
Things done
sandbox = true
set innix.conf
? (See Nix manual)nix-shell -p nixpkgs-review --run "nixpkgs-review rev HEAD"
. Note: all changes have to be committed, also see nixpkgs-review usage./result/bin/
)