about summary refs log tree commit diff
path: root/lib/systems
AgeCommit message (Collapse)AuthorFilesLines
2023-08-16Merge pull request #238509 from amjoseph-nixpkgs/pr/knuth/respectJohn Ericson1-0/+2
lib/systems/parse.nix: show respect where deserved
2023-07-24Merge pull request #244330 from thillux/bluefield2-remove-cpuAdam Joseph1-1/+0
lib.systems.bluefield2: remove cpu profile
2023-07-19lib.systems.bluefield2: remove cpu profileMarkus Theil1-1/+0
Some software, e.g. systemd, failed to build with set cpu profile. Signed-off-by: Markus Theil <theil.markus@gmail.com>
2023-07-14lib.systems.bluefield2: initMarkus Theil2-0/+12
Add support for Nvidia's Bluefield 2 plattform as a compilation target. There exists a version with and without crypto support, while the crypto supported version is the most common one. Support for the non-crypto version can be easily added in the future, if needed. For a datasheet of the hardware, see: https://www.nvidia.com/content/dam/en-zz/Solutions/Data-Center/documents/datasheet-nvidia-bluefield-2-dpu.pdf Signed-off-by: Markus Theil <theil.markus@gmail.com>
2023-07-12Merge pull request #238154 from amjoseph-nixpkgs/pr/gcc/crossStageStaticAdam Joseph1-1/+20
gccCrossStageStatic: enable dynamic libraries, rename it
2023-07-05Merge pull request #240825 from r-burns/mips-embeddedRyan Burns2-1/+11
lib.platforms.mips{,64}-embedded: init
2023-07-05Merge pull request #239120 from LibreCybernetics/arch-stuffArtturi1-11/+28
2023-07-04lib.systems.extensions.sharedLibrary: do not `throw`Adam Joseph1-5/+6
Because downstream code expects to use `==` on platform attrsets, we are unfortunately not able to throw a useful error message when the `sharedLibrary` attribute is accessed. When users do a comparison like: stdenv.hostPlatform == pkgsStatic.stdenv.hostPlatform ... in a situation where `stdenv.hostPlatform.hasSharedLibraries`, they expect this to return `false`. Unfortunately Nix does a deep equality comparison here, and ends up forcing the `pkgsStatic.stdenv.hostPlatform.extensions.sharedLibrary` attribute, which throws the error. Rather than returning `null`, this commit instead simply omits the `extensions.sharedLibrary` attribute. This provides the user with a more-useful error message: instead of waiting until the `null` is used (and hoping that produces an error), the user will get an error about the `extensions.sharedLibrary` attribute being missing, at the position where it was referenced. Big thanks to @trofi for his PR to add `NIX_VALIDATE_EVAL_NONDETERMINISM` to Nix, which I am now using. It made tracking this down really easy! Fixes #244045
2023-07-01lib.systems: introduce hasSharedLibrariesAdam Joseph1-1/+20
This commit adds `hasSharedLibraries` to `lib.systems`. We need `plat.hasSharedLibraries` in order to know whether or not to expect `gcc` (and many other tools) to emit shared libraries (like `libgcc_s.so`). Many of the GNU build scripts are smart enough that if you configure them with `--enable-shared` on a platform (such as `arm-none-eabi`) that doesn't support dynamic linking, they will simply skip the shared libraries instead of aborting the `configurePhase`. Unfortunately the missing shared libraries in the final build product cause very hard-to-troubleshoot problems later on. The alternative to introducing `hasSharedLibraries` would be to set `isStatic` in these situations. However doing so causes `make-derivation.nix` to insert `-static` between the `pname` and `hostPlatform` suffix, which is undesirable. If at some point in the future we eliminate the `-static` suffix, then `hasSharedLibraries` can be made equal to `!isStatic`.
2023-06-30lib.platforms.mips{,64}-embedded: initRyan Burns2-1/+11
2023-06-29lib.systems: add gnuabin32 to isGnuAdam Joseph1-1/+1
The `isGnu` predicate was missing `gnuabin32`. This commit corrects that by adding it.
2023-06-24lib.systems.architectures: add microarchitecture levelsFabián Heredia Montiel1-11/+28
Variation on: - https://github.com/NixOS/nixpkgs/pull/208398 - https://github.com/NixOS/nixpkgs/pull/224978 Co-authored-by: Sandro Jäckel <sandro.jaeckel@gmail.com> Co-authored-by: Shawn8901 <shawn8901@googlemail.com> Co-authored-by: AveryanAlex <alex@averyan.ru>
2023-06-22lib/system: move toLosslessStringMaybe into lib/testsAdam Joseph1-15/+0
toLosslessStringMaybe is not used by anything other than lib/tests, so it can be private to that file. I don't think this function was terribly well thought-through. If people start using it, we will become permanently dependent on the ability to test platforms for equality. It also makes the elaboration process more fragile, because it encourages code outside of nixpkgs to become sensitive to the minute details of how elaboration happens.
2023-06-19Merge pull request #237167 from CHN-beta/masterSandro1-0/+3
2023-06-18lib/systems/parse.nix: show respect where deservedAdam Joseph1-0/+2
The eminent Donald E. Knuth should be recognized as having equal standing with such entities as IBM, Apple, and the Personal Computer. We should acknowledge this by including him as a "vendor". Also, `gnu-config` recognizes `mmix-knuth-*` triples (and in fact requires `vendor="knuth"` when `cpu="mmix"`) -- so we sort of have to. But we should do it anyways.
2023-06-18lib/systems: remove redundant test from selectEmulatorAdam Joseph1-2/+1
Commit eef4bbd82f4c2 changed the conditional in selectEmulator from `isCompatible` (which examines only the CPU, rather than the entire platform) to `canExecute`. This made the first conjunct redundant. Let's drop the redundant part. https://github.com/NixOS/nixpkgs/pull/238331#discussion_r1233277119
2023-06-16lib.systems: add znver4 architectureFabián Heredia Montiel1-0/+2
2023-06-13lib.systems.equals: Ignore all function attributes reflectivelyRobert Hensing1-2/+2
Co-authored-by: Artturi <Artturin@artturin.com>
2023-06-13lib.systems.{equals,toLosslessStringMaybe}: initRobert Hensing1-0/+33
2023-06-11stdenv: add alderlake supportchn1-0/+3
Signed-off-by: Haonan Chen <chn@chn.moe>
2023-06-01lib.systems.doubles: add big-endian MIPS linux doublesAlyssa Ross1-3/+3
We already have examples for these, but since we didn't actually recognise the doubles, it wasn't possible to build any packages for them without setting allowUnsupportedSystem.
2023-06-01lib.systems: remove mipsisa(32|64)r6 triplesAlyssa Ross2-20/+10
These arc the same as the normal triples apart for a difference in -march, so there's no need for them to be separate triples.
2023-05-09lib.systems: remove (accidental?) rust/rustc aliasAlyssa Ross1-1/+1
I imagine this was supposed to be rustc = args.rustc, like the other two lines. This meant that we accepted both rust and rustc attributes, with the same effect. I doubt anybody was using the undocumented, probably-accidental "rust" spelling, but we should remove it before somebody starts. In fact, we don't need to set rustc here at all, because no value platforms.select could return will ever include a rustc key (unlike the other two), so then rustc will be filled in later, when args is merged into final.
2023-05-09Merge pull request #228013 from amjoseph-nixpkgs/pr/qemuArch/mipsAdam Joseph1-0/+1
lib/systems: add mips64[el] entries to qemuArch
2023-05-04Merge master into staging-nextgithub-actions[bot]1-4/+4
2023-05-04lib/systems: move loongarch64-linux out of mips blockWeijia Wang1-4/+4
2023-04-28Merge staging-next into staginggithub-actions[bot]5-1/+10
2023-04-28Merge pull request #227560 from jackyliu16/loongnix-commitWeijia Wang5-1/+10
lib.platforms.loongarch64: init
2023-04-28lib.systems: allow specifying libc = nullAlyssa Ross1-0/+1
It makes sense to allow platform definitions to opt out of having libc at all. One use case would be targetting some obscure new Linux target that doesn't have a libc implementation yet, and another is UEFI, which is basically libc-less Windows. Not having libc is not commonly specified in (GNU) triples (even Linux's build system will just target either -gnu or -musl depending on the platform), so instead, we use a separate attribute for it.
2023-04-27lib.platforms.loongarch64: initjackyliu165-1/+10
2023-04-24lib/systems: add mips64[el] entries to qemuArchAdam Joseph1-0/+1
This commit adds `mips64el` to the `qemuArch` table.
2023-04-24Merge pull request #191995 from amjoseph-nixpkgs/lib/systems/inspect/commentAdam Joseph1-0/+8
lib/systems/inspect.nix: explanatory comment
2023-04-22lib/systems: disable docs in qemu-userArtturin1-0/+1
45M -> 31M
2023-03-10Merge master into haskell-updatesgithub-actions[bot]1-1/+2
2023-03-09lib.systems: don't try to emulate s390-linuxAlyssa Ross1-1/+2
We don't have an emulator that can do this.
2023-03-08haskell.compiler.ghcHEAD: 9.7.20221224 -> 9.7.20230217sternenseemann4-4/+7
- Christmas is over! - Upstream has changed the name of the target triplet used for the JS backend from js-unknown-ghcjs to javascript-unknown-ghcjs, since Cabal calls the architecture "javascript": https://gitlab.haskell.org/ghc/ghc/-/commit/6636b670233522f01d002c9b97827d00289dbf5c Since the triplet is made up anyways, i.e. autoconf does not support it and Rust uses different triplets for its emscripten backends, we'll just change it as well. - Upstream fixed the problem with ar(1) being invoked incorrectly by stage0: https://gitlab.haskell.org/ghc/ghc/-/commit/e987e345c807035e4637ca3eae227ae501e16c42
2023-03-07Merge pull request #211950 from Atemu/armv8-no-more-armv7Atemu1-13/+2
lib/systems/parse: stop considering armv8a able to execute armv7l
2023-02-15Merge pull request #203539 from SuperSandro2000/architectures-expand-inferiorsSandro1-6/+13
lib/systems/architectures: expand inferiors
2023-01-31Merge master into staging-nextgithub-actions[bot]1-0/+10
2023-01-30Merge pull request #212939 from amjoseph-nixpkgs/pr/isStaticFlorian Klink1-0/+10
meta: replace predicates with pattern over elaborated platform
2023-01-30lib.systems.inspect.patterns.isEfi: drop ARMv5Alyssa Ross1-2/+7
I'm not aware of any ARMv5 EFI implementation. gnu-efi doesn't support it, so the build of systemd for armv5tel-linux is broken if it's isEfi.
2023-01-29lib.systems.inspect.patterns.isEfi: remove "aarch64"Alyssa Ross1-1/+1
There is no "aarch64" CPU family — it counts as "arm", as can be seen from the definition of isAarch64 above. Checked that stdenv.hostPlatform.isEfi is still true on aarch64-linux.
2023-01-27Update lib/systems/inspect.nixAdam Joseph1-2/+2
Co-authored-by: Naïm Favier <n@monade.li>
2023-01-27Update lib/systems/inspect.nixAdam Joseph1-1/+1
Co-authored-by: Naïm Favier <n@monade.li>
2023-01-27lib/systems/inspect.nix: add platformPatterns.isStaticAdam Joseph1-0/+10
2023-01-21lib/systems/parse: stop considering armv8a able to execute armv7lAtemu1-13/+2
In the past, most (if not all) armv8 CPUs could also execute armv7. However, with the advent of Apple Silicon, aarch64 CPUs without any aarch32 capabilities are now wide-spread among users.
2023-01-19lib.platforms.s390x: initAlyssa Ross2-0/+2
2023-01-19lib.platforms.power: initAlyssa Ross1-0/+1
2023-01-19lib.platforms.armv7: initAlyssa Ross2-0/+4
2023-01-13Merge pull request #184521 from dramforever/riscv-isefiNick Cao1-1/+1
lib/systems/inspect.nix: Add riscv to isEfi