Berkus Decker
79f859b576
wip: nucleus builds!
2023-12-10 04:44:36 +02:00
Berkus Decker
7c76dbded1
sq: refactor build system
2023-11-20 02:40:17 +02:00
Berkus Decker
c6e466e914
wip: refactor build system
...
Reduce redundancy, make naming more clear.
Add ttt target.
2023-11-18 14:29:39 +02:00
Berkus Decker
028866fdbb
test: 🚨 Don't spam QEMU console when testing
2023-08-12 03:29:02 +03:00
Berkus Decker
2cf5e1dea8
refactor: 📦 Update PL011 UART
2023-08-01 16:59:42 +03:00
Berkus Decker
7de1af043e
fix: 🐛 Add RUST_STD to clippy invocation
...
Combine both parts of RUST_STD and RUST_STD_FEATURES into a single
option, easier to control, harder to miss.
2023-07-29 04:08:18 +03:00
Berkus Decker
ce3b94e86e
fix: 🐛 Fix 2/2 for objcopy unaligned sections bug
...
This one restores rust-objcopy but explicitly aligns
the beginning of each section. This avoids incorrect
binary output (.rodata section was offset 10-12 bytes
because of unaligned section start).
2023-07-29 04:08:18 +03:00
Berkus Decker
d2ed7c21ac
fix: 🐛 Fix 1/2 for objcopy unaligned sections bug
...
Due to a bug in llvm-objcopy sections
must be explicitly aligned, see
https://github.com/llvm/llvm-project/issues/58407
and
https://github.com/rust-lang/rust/issues/102983
This fix just replaces rust-objcopy with a GNU
binutils counterpart from `brew install
aarch64-elf-binutils`. Next commit will do a
less intrusive fix.
2023-07-29 04:08:18 +03:00
Berkus Decker
13d6b2a037
chore: ♻️ Add QEMU tracing options for aarch64
...
Disabled for now, need to try them out.
2023-07-29 04:08:18 +03:00
Berkus Decker
0e1c6669ac
refactor: 📦 Use better code structure
...
As inspired by andre-richter's tutorials.
2023-07-29 04:08:18 +03:00
Berkus Decker
5356de7cbb
fix: 🐛 Disable some make tasks
...
Allows running gdb and hopper tasks.
Enable QEMU task.
2023-07-29 04:08:18 +03:00
Berkus Decker
dfbd424bde
chore: ♻️ Add sparkly magic
2023-07-29 04:08:18 +03:00
Berkus Decker
d6887bccee
refactor(build): 📦 Use single gdb-config command
2023-07-29 04:08:18 +03:00
Berkus Decker
2313b0cf97
fix: 🐛 Make sdeject command more useful
2023-07-29 04:08:18 +03:00
Berkus Decker
12f51399df
feat: ✨ Do a Rust-only chainloader!
2023-07-29 04:08:18 +03:00
Berkus Decker
61762ccbf6
feat(qemu): ✨ Print QEMU run options
2023-07-29 04:08:18 +03:00
Berkus Decker
97fc7f6b3d
feat(qemu): ✨ Generate QEMU logs
2023-07-29 04:08:18 +03:00
Berkus Decker
b52c63796c
fix: 🐛 Set GDB breakpoints by physical address
2022-06-11 00:25:21 +03:00
Berkus Decker
7ab44c7d15
build: 🛠 allow deprecated code in clippy
2022-03-01 01:12:34 +02:00
Berkus Decker
f4418c3164
feat: ✨ Add `just boot` command
...
Due to just or cargo-make taking over the
controlling PTY we cannot launch an interactive
command from a cargo-make file, so just print
the command line to launch.
2022-02-10 02:16:28 +02:00
Berkus Decker
162592beaa
feat: ✨ Add chainofcommand
...
Works fine with a caveat that you need
to press ENTER after Ctrl+C, investigate.
Multiplex QEMU output for serial access.
2022-02-10 02:16:28 +02:00
Berkus Decker
cfe4a230de
feat: ✨ Add chainboot boot loader
2022-02-10 02:15:57 +02:00
Berkus Decker
8f26c6fa44
refactor: 📦 Clean up code
...
Debugging with jtag.
Explicitly default to no features.
Allow unused allocator code.
Add board selection.
Add RPi4 datasheet.
Add explanation on bss alignment type.
2022-02-10 02:15:18 +02:00
Berkus Decker
f76fab3fff
chore: ♻️ Use different DTB files for rpi3 and rpi4
2022-02-10 02:14:07 +02:00
Berkus Decker
9cbc6ce80f
build: 🛠 Extract QEMU_DISASM_OPTS
2022-02-10 02:14:07 +02:00
Berkus Decker
8b6a585250
build: 🛠 Set machine ID for QEMU versions after 6.2.0
...
Work around ancient QEMU versions on CI boxes.
2022-02-10 02:14:07 +02:00
Berkus Decker
721af870bf
build: 🛠 Make image prepare steps more verbose
2022-02-10 02:14:07 +02:00
Berkus Decker
40782ea7cc
chore(debug): ♻️ Upgrade gdb version and update run scripts
2022-02-10 02:14:07 +02:00
Berkus Decker
4cdeeb8556
refactor: 📦 Split kernel into machine and nucleus
...
Move openocd task to upper level and remove kernel
build dependency - the qemu runner doesn't really
depend on it.
2022-02-10 02:14:07 +02:00
Berkus Decker
b26d61cb67
build: 🛠 Improve Justfile help output
...
Enter `just` to see a list of available commands
with explanations.
Added `just ci` step.
Added `just fmt-check`.
Removed unnecessary kernel file removals.
Moved sdeject task and added `just device-eject`.
2022-01-23 16:03:03 +02:00
Berkus Decker
503f43d983
build(tools): Enable target board selection
2021-12-20 17:52:14 +02:00
Berkus Decker
f6da27062f
build(tools): Update OpenOCD version
...
RTT patch has been merged, so use the latest 0.11.0-rc2+dev-01576-g0d9e8bd52-dirty
2021-12-20 17:51:08 +02:00
Berkus Decker
bfba78118f
Move build-std flags to cargo config
2020-11-14 17:33:43 +02:00
Berkus Decker
6da44a69ac
Improve gdb runner
2020-11-04 22:24:34 +02:00
Berkus Decker
d38661b63f
Add openocd/gdb targets to makefile
...
Refactor build system scripts a bit.
2020-11-03 19:29:43 +02:00
Berkus Decker
504dcd1f65
Update copyrights
2020-10-15 23:04:01 +03:00
Berkus Decker
50b0613f5c
Use rust-objcopy tool
...
Since cargo-binutils 0.3.1 the `cargo objcopy` causes a build before
copying files, this doesn't work for test-runner.
We only need the actual objcopy tool, not the cargo infra here.
2020-10-06 19:27:50 +03:00
Berkus Decker
af1cc83530
Add testing framework
...
Based on os.phil-opp.com ideas it includes running test framework in
qemu semihosting mode so that tests can indicate pass or fail to calling
process.
GitHub Actions are configured to run these tests and validate acceptance.
Add test-runner target to perform tests in qemu.
Add -nographic for qemu running tests.
Drop serial for qemu tests as well.
2020-10-06 19:27:50 +03:00
Berkus Decker
34115db6f6
Bump minimum required cargo-make version
...
We use some features that work ok only since 0.32
2020-09-21 04:01:19 +03:00
Berkus Decker
be3131f666
Improve cargo makefile
2020-09-21 04:01:16 +03:00
Berkus Decker
a4a3289712
Add GH Actions build workflow
2020-08-10 00:34:49 +03:00
Berkus Decker
57fc6e5aa5
Add QEMU configuration
2020-08-09 19:40:57 +03:00
Berkus Decker
cb814b353b
Add Raspberry Pi target configuration
...
* Use rlibc for memset/memcpy
* Create linker script for raspberry pi 3
* Add aarch64 target file inspired by Robigalia
* Force bitcode embedding for LTO
2020-08-09 19:35:09 +03:00