commit 2a77a6976743687f0ae365aa2c939fab812f6aa7 Author: brevalferrari Date: Wed Sep 17 22:29:51 2025 +0200 Initial commit Starter, doesn't work on stable diff --git a/.cargo/config.toml b/.cargo/config.toml new file mode 100644 index 0000000..620b17c --- /dev/null +++ b/.cargo/config.toml @@ -0,0 +1,5 @@ +[build] +target = "losedows.json" + +[unstable] +build-std = ["core", "compiler_builtins"] diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..ea8c4bf --- /dev/null +++ b/.gitignore @@ -0,0 +1 @@ +/target diff --git a/Cargo.lock b/Cargo.lock new file mode 100644 index 0000000..ce98833 --- /dev/null +++ b/Cargo.lock @@ -0,0 +1,7 @@ +# This file is automatically @generated by Cargo. +# It is not intended for manual editing. +version = 4 + +[[package]] +name = "losedows" +version = "0.1.0" diff --git a/Cargo.toml b/Cargo.toml new file mode 100644 index 0000000..dd4eb08 --- /dev/null +++ b/Cargo.toml @@ -0,0 +1,17 @@ +[package] +name = "losedows" +version = "0.1.0" +edition = "2024" + +[dependencies] + +[profile.dev] +panic = "abort" + +[profile.release] +panic = "abort" + +[[bin]] +name = "losedows" +test = false +bench = false diff --git a/losedows.json b/losedows.json new file mode 100644 index 0000000..c9e27c5 --- /dev/null +++ b/losedows.json @@ -0,0 +1,16 @@ +{ + "llvm-target": "x86_64-losedowns-none", + "data-layout": "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-i128:128-f80:128-n8:16:32:64-S128", + "arch": "x86_64", + "target-endian": "little", + "target-pointer-width": "64", + "target-c-int-width": 32, + "os": "none", + "executables": true, + "linker-flavor": "ld.lld", + "linker": "rust-lld", + "panic-strategy": "abort", + "disable-redzone": true, + "features": "-mmx,-sse,+soft-float", + "rustc-abi": "x86-softfloat" +} diff --git a/src/main.rs b/src/main.rs new file mode 100644 index 0000000..be37f7e --- /dev/null +++ b/src/main.rs @@ -0,0 +1,14 @@ +#![no_std] +#![no_main] + +use core::panic::PanicInfo; + +#[unsafe(no_mangle)] +pub extern "C" fn _start() -> ! { + loop {} +} + +#[panic_handler] +fn panic(_info: &PanicInfo) -> ! { + loop {} +}