Andre Richter
6db8b2bc72
Update toolchain
4 years ago
Andre Richter
a5884321a7
Fix rustdoc warnings
4 years ago
Andre Richter
8324b1fdac
PL011: Use BUSY bit
...
Fixes #100
4 years ago
Andre Richter
e7cb61b389
Refactoring
...
- Don't wildcard-import from arch modules. Make it explicit.
- Put translation table code into its own module.
- Put boot code in boot.rs instead of cpu.rs
- Other minor changes, most memory subsystem.
4 years ago
Andre Richter
c35a30cd0b
Bump UART to 921_600 baud + other bugfixes
...
Fixes #95
Fixes #98
Co-authored-by: Takumasa Sakao <sakataku7@gmail.com>
4 years ago
Andre Richter
f2a891236e
Remove unused feature
4 years ago
Andre Richter
ee52e8e288
Bump UART to 576000 baud
4 years ago
Andre Richter
1d2b5ad022
Memory Mapping: Improve various aspects
4 years ago
Andre Richter
44bb3f8942
Update copyright year
4 years ago
Andre Richter
18c7259c60
Default to externally powered RPis
...
Addresses issues in #86
4 years ago
Andre Richter
5c193d5803
Change to a simpler mutex API
4 years ago
Andre Richter
02f9f34af3
More sound Phantom in MMIO deref wrapper
4 years ago
Andre Richter
163e2010ab
GPIO: Fix RPi4 driver init
...
The RPi4 GPIO pull-up/pull down sequence is done differently than on the
RPi3. Switch to using the correct way.
Also, configure pull-ups for both UART pins.
Fixes #81
4 years ago
Andre Richter
b30bc518c4
Switch to GCC objdump and nm
...
The GCC versions of `objdump` and `nm` seem to have better out-of-the-box
support (for AArch64). Demangling works better, and instructions in objdump are
presented as 4 bytes instead of 4 * 1 bytes, which helps a lot.
Hence, switch to the GCC versions for now until LLVM has caught up.
4 years ago
Andre Richter
e7a13e81b8
Upgrade to cortex-a 4.x.x
4 years ago
Andre Richter
27a1d10cc3
Remove UB in linker script symbol <-> Rust handover
4 years ago
Andre Richter
64658a6ce9
Bump toolchain version
4 years ago
Andre Richter
677b274a1f
Add a panic version of the GPIO to panic!()
4 years ago
Andre Richter
6a5f3758fa
Remove/reshuffle features
4 years ago
Andre Richter
22faff5229
Various finetunings
4 years ago
Andre Richter
e7df5b2982
Use InMemoryRegister in MMU driver
4 years ago
Andre Richter
37b9d1435e
Move anything wrt linker symbols to bsp::memory
...
Also, some rewording of data types.
4 years ago
Andre Richter
af0214f0f6
State: Encapsulate state check into member function
4 years ago
Andre Richter
52807bc015
Remove artifact in readme
4 years ago
Andre Richter
b585f64e30
Shuffle constant to more fitting module
4 years ago
Andre Richter
5a793e5fcb
Wording
4 years ago
Andre Richter
dfbcd444dd
Update some readmes
4 years ago
Andre Richter
c78568bba1
Update some links
4 years ago
Andre Richter
3a0b676402
Use MMIODerefWrapper everywhere
4 years ago
Andre Richter
87d82ea559
Use MIS instead of RIS
4 years ago
Andre Richter
a362a84592
14: Improve pl011 code
4 years ago
Andre Richter
9cc0f4a5ef
Remove now obsolete const_if feature
4 years ago
Andre Richter
ee771e5ba6
Adapt image sizes where it makes sense
4 years ago
Andre Richter
cfc3bfc996
Switch to new Rust inline asm! syntax
4 years ago
Andre Richter
82f97c000b
Switch to llvm_asm! to avoid future breakage
5 years ago
Andre Richter
98d5d79acf
Don't check in binaries anymore
5 years ago
Andre Richter
bf8e6c36c7
Analyzer: Invoke cargo check through Makefile
5 years ago
Andre Richter
0a1616d8b2
Let cargo track changed files
...
This should enable incremental compilation monitored by cargo.
5 years ago
Andre Richter
a4266ba978
More Makefile fixes
5 years ago
Andre Richter
6eb9613ba2
Fix objcopy invocation
5 years ago
Andre Richter
089565762a
Makefiles: Docker USB passthrough in Linux only
...
Detect if we run on Linux. If so, dockerize Makefile targets that need access to
USB devices. If we run on anything else, attempt to execute natively.
This will enable non-Linux Unixes like macOS to run the chainboot target, given
they install the needed Ruby dependencies.
5 years ago
Andre Richter
792b208643
Missed xdoc -> doc earlier
5 years ago
Andre Richter
ed5cada47e
Remove attributes ignored by rustfmt.
5 years ago
Andre Richter
1337092a2a
Format driver includes for better readability
5 years ago
Andre Richter
c4f9432e13
Remove xbuild. Use upstream aarch64 rust-std 🎉 🦀
...
`rustup target add aarch64-unknown-none-softfloat` is now a thing.
It is no longer required to build rust-std on-demand with `xbuild`.
This reduces compile-times significantly.
5 years ago
Andre Richter
1d34a4e42e
Add tutorial 14: Peripheral Interrupts
5 years ago