Commit Graph

74 Commits

Author SHA1 Message Date
Andre Richter
5c193d5803
Change to a simpler mutex API 2020-11-20 22:05:14 +01:00
Andre Richter
02f9f34af3
More sound Phantom in MMIO deref wrapper 2020-11-19 22:53:43 +01:00
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
2020-11-14 10:18:29 +01:00
Andre Richter
098e19ecc4
Fix zero-sized bss handling 2020-11-01 21:32:53 +01:00
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.
2020-11-01 15:58:05 +01:00
Andre Richter
9e6ef76aeb
Make cortex-a platform specific dep 2020-10-28 11:45:28 +01:00
Andre Richter
e7a13e81b8
Upgrade to cortex-a 4.x.x 2020-10-28 11:27:43 +01:00
Andre Richter
690716e4af
add toml extension to .cargo/config file 2020-10-11 22:06:14 +02:00
Andre Richter
208f547f29
Remove needless extern C 2020-10-06 00:01:50 +02:00
Andre Richter
27a1d10cc3
Remove UB in linker script symbol <-> Rust handover 2020-10-05 23:47:18 +02:00
Andre Richter
64658a6ce9
Bump toolchain version 2020-10-04 18:15:37 +02:00
Andre Richter
677b274a1f
Add a panic version of the GPIO to panic!() 2020-09-30 21:51:31 +02:00
Andre Richter
95c67afda2
update deps 2020-09-29 22:49:12 +02:00
Andre Richter
6a5f3758fa
Remove/reshuffle features 2020-09-29 22:48:04 +02:00
Andre Richter
7b0ae693c7
Switch to qemu-exit 1.0.x 2020-09-29 22:17:53 +02:00
Andre Richter
22faff5229
Various finetunings 2020-09-29 21:43:31 +02:00
Andre Richter
e7df5b2982
Use InMemoryRegister in MMU driver 2020-09-28 22:31:42 +02:00
Andre Richter
37b9d1435e
Move anything wrt linker symbols to bsp::memory
Also, some rewording of data types.
2020-09-28 21:45:38 +02:00
Andre Richter
1d46dd40b6
Run of prettier over whole repo 2020-09-25 21:24:56 +02:00
Andre Richter
b8f7764bbb
Align to new rubocop rules 2020-09-24 22:46:51 +02:00
Andre Richter
b585f64e30
Shuffle constant to more fitting module 2020-07-30 22:59:24 +02:00
Andre Richter
5a793e5fcb
Wording 2020-07-29 08:15:29 +02:00
Andre Richter
c1696d6b02
Whitespace 2020-07-24 23:25:26 +02:00
Andre Richter
7e14b246d7
Explicitly set exception vectors in link.ld 2020-07-21 17:53:19 +02:00
Andre Richter
224ac8d944
Use --headers for readelf 2020-07-21 17:47:43 +02:00
Carl Fredrik Samson
0afffdeac7 Added short explanation of the BRD calculations for setting up UART re #70 2020-07-15 23:21:03 +02:00
Andre Richter
87e74f62cd
UART: Fix FBRD
Closes #70

Co-authored-by: Carl Fredrik Samson <cfsamson@users.noreply.github.com>
2020-07-13 21:55:37 +02:00
Andre Richter
c78568bba1
Update some links 2020-07-12 15:06:46 +02:00
Andre Richter
325599c8b7
Fix arch and target for VS Code 2020-07-12 13:48:14 +02:00
Andre Richter
3a0b676402
Use MMIODerefWrapper everywhere 2020-07-12 12:44:03 +02:00
Andre Richter
b6d480d548
kernels: Update dependencies 2020-06-28 13:36:34 +02:00
Andre Richter
16a903ad29
kernels: Update dependencies 2020-05-31 13:20:19 +02:00
Andre Richter
1ba7330f9f
Bump qemu-exit to 0.1.1 2020-05-11 08:35:48 +02:00
Andre Richter
ef919b0842
kernels: Update dependencies 2020-05-05 21:51:17 +02:00
Andre Richter
681092829c
Bump to cortex-a 3.0.0 2020-04-16 22:54:08 +02:00
Andre Richter
98d5d79acf
Don't check in binaries anymore 2020-04-16 22:47:19 +02:00
Andre Richter
5a0d8de96b
Demangle in objdump 2020-04-15 23:38:44 +02:00
Andre Richter
bf8e6c36c7
Analyzer: Invoke cargo check through Makefile 2020-04-15 23:00:21 +02:00
Andre Richter
0a1616d8b2
Let cargo track changed files
This should enable incremental compilation monitored by cargo.
2020-04-14 23:16:35 +02:00
Andre Richter
a4266ba978
More Makefile fixes 2020-04-12 22:22:29 +02:00
Andre Richter
6eb9613ba2
Fix objcopy invocation 2020-04-12 11:54:13 +02:00
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.
2020-04-11 12:22:52 +02:00
Andre Richter
792b208643
Missed xdoc -> doc earlier 2020-04-09 21:27:14 +02:00
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.
2020-04-07 23:17:48 +02:00
Andre Richter
890442e8f1
Fix typo 2020-04-06 22:13:29 +02:00
Andre Richter
1cba21bda1
Minor namespace adaptions 2020-03-31 23:45:17 +02:00
Andre Richter
646a51d69f
13: remove now obsolte extern crate statement 2020-03-28 21:52:07 +01:00
Andre Richter
2a7ebe15eb
13: Change tests to new module structure 2020-03-28 21:16:56 +01:00
Andre Richter
f0513a6b0c
Upgrade to Rust nightly-2020-03-19 2020-03-28 16:19:10 +01:00
Andre Richter
474f58ced0
Add README diffs 2020-03-28 15:42:42 +01:00