71 Commits (2432c0d283883ea87b5f2e70eed36971d74d44df)

Author SHA1 Message Date
Andre Richter 2432c0d283
Revert to assembly boot code
It is too risky to rely on the compiler to not insert any operations using the
stack.

Having a stack-setting call in Rust using the cortex-a crate as the first action
in a Rust-only _start() function does not work if you're subsequently using the
stack, because the compiler often inserts the operations to make room on the
stack to prepare a function call BEFORE the call to set the stack, which crashes
the boot process.

Hence, keep on using a small piece of assembly boot code throughout.
3 years ago
Andre Richter 223989adb9
Overhaul linker script 3 years ago
Andre Richter 2f90304149
Add color and verbosity to Makefile 3 years ago
Andre Richter 6db8b2bc72
Update toolchain 3 years ago
Andre Richter a5884321a7
Fix rustdoc warnings 3 years ago
Andre Richter 8324b1fdac
PL011: Use BUSY bit
Fixes #100
3 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.
3 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 ff382c3faf
Remove comment 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 44bb3f8942
Update copyright year 4 years ago
Andre Richter 18c7259c60
Default to externally powered RPis
Addresses issues in #86
4 years ago
Andre Richter d212348931
Bump compiler version.
We have to remove the `#[naked]` attribute from `_start` for now, since it emits
a warning now when used with non-asm statements in the function body. For now,
just hope for the compiler's mercy to not emit code using the stack pointer
before we've actually set up a stack.
4 years ago
Andre Richter e8d30392d0
Add LTO 4 years ago
Andre Richter 2c3f705051
Update dependencies
register-rs 1.0.0 now uses UnsafeCell internally, which means we lost the Copy
derive on InMemoryRegister.

Therefore, a small set of changes was needed in the MMU driver to dance around
the static array init depending on a Copy type.
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 4b8f6a6980
Fix wrong phony 4 years ago
Andre Richter e1473099ff
Use miniterm instead of screen 4 years ago
Andre Richter 9e6ef76aeb
Make cortex-a platform specific dep 4 years ago
Andre Richter e7a13e81b8
Upgrade to cortex-a 4.x.x 4 years ago
Andre Richter 8fc250fc08
Streamline READMEs 4 years ago
Andre Richter 677b274a1f
Add a panic version of the GPIO to panic!() 4 years ago
Andre Richter 22faff5229
Various finetunings 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 a33f693e1c
Tutorial 6: README: Update config.txt instructions
Fixes #77
4 years ago
Andre Richter b585f64e30
Shuffle constant to more fitting module 4 years ago
Andre Richter dfbcd444dd
Update some readmes 4 years ago
Andre Richter 87e74f62cd
UART: Fix FBRD
Closes #70

Co-authored-by: Carl Fredrik Samson <cfsamson@users.noreply.github.com>
4 years ago
Andre Richter 519be514a5
Update README.md 4 years ago
Andre Richter 3a0b676402
Use MMIODerefWrapper everywhere 4 years ago
Andre Richter 681092829c
Bump to cortex-a 3.0.0 4 years ago
Andre Richter 834b226f4e
Update README 4 years ago
Andre Richter 9819b557fe
Add console symbol 4 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.
4 years ago
Andre Richter 1cba21bda1
Minor namespace adaptions 4 years ago
Andre Richter 474f58ced0
Add README diffs 4 years ago
Andre Richter 91575eaa2c
Refactor tutorial 06 4 years ago
Andre Richter 7d86a1d6ab Change note about start4.elf file naming. 4 years ago
Andreas Schmidt ef571a75a7 fix start4.elf file naming to boot on Raspi 4 4 years ago
Andre Richter 72a4d28fc1
Bump to register 0.5.x 4 years ago
Andre Richter 840c72d11b
Bump UART to 230400 Baud 4 years ago
Andre Richter e7bf7fab0e
Fix UART stats; Remove unneeded conversion. 5 years ago
Andre Richter c64dd1197a
For educational purposes, use own zero_bss(). 5 years ago
Andre Richter a41190e298
Ensure kernel panic starts on newline 5 years ago
Andre Richter e690f8e7e4
Copyright bump to 2020 🎆 5 years ago
Andre Richter 582d539212
Add console chars_read implementation 5 years ago
Andre Richter 10090900cc
Add missing source comments 5 years ago