diff --git a/lib/std/mem.zig b/lib/std/mem.zig index 984f1198acd6..1fd8af950a94 100644 --- a/lib/std/mem.zig +++ b/lib/std/mem.zig @@ -17,6 +17,14 @@ pub const page_size = switch (builtin.cpu.arch) { else => 4 * 1024, }, .sparc64 => 8 * 1024, + .loongarch32, .loongarch64 => switch (builtin.os.tag) { + // Linux default KConfig value is 16KiB + .linux => 16 * 1024, + // FIXME: + // There is no other OS supported yet. Use the same value + // as Linux for now. + else => 16 * 1024, + }, else => 4 * 1024, }; diff --git a/lib/std/os/linux.zig b/lib/std/os/linux.zig index 198481c373b9..797b9dd16c6a 100644 --- a/lib/std/os/linux.zig +++ b/lib/std/os/linux.zig @@ -113,6 +113,7 @@ pub const SYS = switch (@import("builtin").cpu.arch) { .riscv64 => syscalls.RiscV64, .sparc => syscalls.Sparc, .sparc64 => syscalls.Sparc64, + .loongarch64 => syscalls.LoongArch64, .m68k => syscalls.M68k, .mips, .mipsel => syscalls.MipsO32, .mips64, .mips64el => if (builtin.abi == .gnuabin32) diff --git a/src/glibc.zig b/src/glibc.zig index 85f1828ad432..bfef0d892bb4 100644 --- a/src/glibc.zig +++ b/src/glibc.zig @@ -1175,6 +1175,7 @@ fn buildSharedLib( pub fn needsCrtiCrtn(target: std.Target) bool { return switch (target.cpu.arch) { .riscv32, .riscv64 => false, + .loongarch64 => false, else => true, }; } diff --git a/src/musl.zig b/src/musl.zig index b75009c44758..ac40e2677927 100644 --- a/src/musl.zig +++ b/src/musl.zig @@ -303,7 +303,8 @@ pub fn needsCrtiCrtn(target: std.Target) bool { return switch (target.cpu.arch) { .riscv32, .riscv64, - .wasm32, .wasm64 => return false, + .wasm32, .wasm64 => false, + .loongarch64 => false, else => true, }; // zig fmt: on