mirror of
https://github.com/italicsjenga/agb.git
synced 2025-01-11 09:31:34 +11:00
split out assembly
This commit is contained in:
parent
46260c085a
commit
0be9da755c
58
agb/build.rs
58
agb/build.rs
|
@ -1,35 +1,51 @@
|
|||
use std::path;
|
||||
|
||||
fn main() {
|
||||
println!("cargo:rerun-if-changed=crt0.s");
|
||||
let asm = &["crt0.s", "interrupt_handler.s", "src/sound/mixer/mixer.s"];
|
||||
|
||||
println!("cargo:rerun-if-changed=gba.ld");
|
||||
println!("cargo:rerun-if-changed=gba_mb.ld");
|
||||
println!("cargo:rerun-if-changed=src/sound/mixer/mixer.s");
|
||||
println!("cargo:rerun-if-changed=src/asm_include.s");
|
||||
println!("cargo:rerun-if-changed=interrupt_handler.s");
|
||||
println!("cargo:rerun-if-changed=gfx/test_logo.png");
|
||||
|
||||
let out_file_name = "crt0.o";
|
||||
println!("cargo:rerun-if-changed=build.rs");
|
||||
|
||||
let out_dir = std::env::var("OUT_DIR").expect("OUT_DIR environment variable must be specified");
|
||||
let out_file_path = format!("{}/{}", out_dir, &out_file_name);
|
||||
|
||||
let out = std::process::Command::new("arm-none-eabi-as")
|
||||
.arg("-mthumb-interwork")
|
||||
.arg("-mcpu=arm7tdmi")
|
||||
.arg("-g")
|
||||
.args(&["-o", out_file_path.as_str()])
|
||||
.arg("crt0.s")
|
||||
.output()
|
||||
.expect("failed to compile crt0.s");
|
||||
for &a in asm.iter() {
|
||||
println!("cargo:rerun-if-changed={}", a);
|
||||
let filename = path::Path::new(a);
|
||||
let filename = filename.with_extension("o");
|
||||
let filename = filename
|
||||
.file_name()
|
||||
.expect("should have filename")
|
||||
.to_str()
|
||||
.expect("Please make it valid utf-8");
|
||||
|
||||
assert!(
|
||||
out.status.success(),
|
||||
"{}",
|
||||
String::from_utf8_lossy(&out.stderr)
|
||||
);
|
||||
let out_file_path = format!("{}/{}", out_dir, filename);
|
||||
|
||||
for warning_line in String::from_utf8_lossy(&out.stderr).split('\n') {
|
||||
if !warning_line.is_empty() {
|
||||
println!("cargo:warning={}", warning_line);
|
||||
let out = std::process::Command::new("arm-none-eabi-as")
|
||||
.arg("-mthumb-interwork")
|
||||
.arg("-mcpu=arm7tdmi")
|
||||
.arg("-g")
|
||||
.args(&["-o", out_file_path.as_str()])
|
||||
.arg(a)
|
||||
.output()
|
||||
.unwrap_or_else(|_| panic!("failed to compile {}", a));
|
||||
|
||||
assert!(
|
||||
out.status.success(),
|
||||
"{}",
|
||||
String::from_utf8_lossy(&out.stderr)
|
||||
);
|
||||
for warning_line in String::from_utf8_lossy(&out.stderr).split('\n') {
|
||||
if !warning_line.is_empty() {
|
||||
println!("cargo:warning={}", warning_line);
|
||||
}
|
||||
}
|
||||
println!("cargo:rustc-link-arg={}", out_file_path);
|
||||
}
|
||||
|
||||
println!("cargo:rustc-link-search={}", out_dir);
|
||||
// println!("cargo:rustc-link-arg={}/crt0.o", out_dir);
|
||||
}
|
||||
|
|
|
@ -1,7 +1,8 @@
|
|||
.include "src/asm_include.s"
|
||||
|
||||
.arm
|
||||
.global __start
|
||||
.section .crt0
|
||||
.align
|
||||
__start:
|
||||
b .Initialise
|
||||
|
||||
|
@ -73,6 +74,3 @@ b .Initialise_mb
|
|||
1:
|
||||
b 1b
|
||||
.pool
|
||||
|
||||
.include "interrupt_handler.s"
|
||||
.include "src/sound/mixer/mixer.s"
|
||||
|
|
|
@ -15,12 +15,10 @@ __text_start = ORIGIN(rom);
|
|||
SECTIONS {
|
||||
. = __text_start;
|
||||
|
||||
.crt0 : {
|
||||
KEEP (crt0.o(.text));
|
||||
. = ALIGN(4);
|
||||
} > rom
|
||||
|
||||
.text : {
|
||||
KEEP(*(.crt0));
|
||||
*(.crt0 .crt0*);
|
||||
*(.text .text*);
|
||||
. = ALIGN(4);
|
||||
} > rom
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
.macro agb_arm_func functionName:req
|
||||
.section .iwram, "ax", %progbits @ "ax" = allocatable and executable, %progbits = contains data
|
||||
.section .iwram
|
||||
.arm
|
||||
.align 2
|
||||
.global \functionName
|
||||
|
|
|
@ -1,3 +1,5 @@
|
|||
.include "src/asm_include.s"
|
||||
|
||||
.section .iwram
|
||||
.global agb_rs__buffer_size
|
||||
.balign 4
|
||||
|
|
Loading…
Reference in a new issue