rust-raspberrypi-OS-tutorials/09_delays
Andre Richter 1ca70bcd56
Check-in kernel8
Useful for assembly inspection via objdump
2018-08-26 20:34:37 +02:00
..
.cargo Use aarch64-unknown-none target in nightly 🎉 2018-08-19 23:42:24 +02:00
raspi3_boot rust-fmt all 2018-08-26 14:02:07 +02:00
src rust-fmt all 2018-08-26 14:02:07 +02:00
Cargo.lock Bump cortex-a to v1.1.0 2018-08-24 00:13:53 +02:00
Cargo.toml Bump cortex-a to v1.1.0 2018-08-24 00:13:53 +02:00
kernel8 Check-in kernel8 2018-08-26 20:34:37 +02:00
kernel8.img Fix wrong Stack address 2018-08-26 13:58:12 +02:00
link.ld Correct linker issues 2018-08-20 17:07:18 +02:00
Makefile Use cargo-xbuild 2018-08-21 21:22:50 +02:00
README.md Add tutorial 0A_power 2018-04-23 22:05:22 +02:00

Tutorial 09 - Delays

It is very important to wait precise amounts of time while you are interfacing with low level hardware. In this tutorial, we'll cover thee ways. One is CPU frequency dependent (and useful if wait time is given in CPU clock cycles), the other two are µs based.

delays.rs

delays::wait_cycles(cyc: u32) this is very straightforward, we execute the nop instruction n times.

delays::wait_msec(n: u32) this implementation uses ARM system registers (available on all AArch64 CPUs).

delays::SysTmr::wait_msec_st(&self, n: u64) is a BCM specific implementation, which uses the System Timer peripheral (not available on qemu).

uart.rs

We can now conveniently use delays::wait_cycles() in Uart::init().

main.rs

We test our different wait implementations.