rust-raspberrypi-OS-tutorials/.07_delays
2018-03-31 20:06:27 +02:00
..
delays.c Hide tuts not implemented in Rust yet 2018-03-31 20:06:27 +02:00
delays.h Hide tuts not implemented in Rust yet 2018-03-31 20:06:27 +02:00
gpio.h Hide tuts not implemented in Rust yet 2018-03-31 20:06:27 +02:00
kernel8.img Hide tuts not implemented in Rust yet 2018-03-31 20:06:27 +02:00
link.ld Hide tuts not implemented in Rust yet 2018-03-31 20:06:27 +02:00
main.c Hide tuts not implemented in Rust yet 2018-03-31 20:06:27 +02:00
Makefile Hide tuts not implemented in Rust yet 2018-03-31 20:06:27 +02:00
mbox.c Hide tuts not implemented in Rust yet 2018-03-31 20:06:27 +02:00
mbox.h Hide tuts not implemented in Rust yet 2018-03-31 20:06:27 +02:00
OLVASSEL.md Hide tuts not implemented in Rust yet 2018-03-31 20:06:27 +02:00
README.md Hide tuts not implemented in Rust yet 2018-03-31 20:06:27 +02:00
start.S Hide tuts not implemented in Rust yet 2018-03-31 20:06:27 +02:00
uart.c Hide tuts not implemented in Rust yet 2018-03-31 20:06:27 +02:00
uart.h Hide tuts not implemented in Rust yet 2018-03-31 20:06:27 +02:00

Tutorial 07 - Delays

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

Delays.h, delays.c

wait_cycles(n) this is a very straightforward thing, we execute the 'nop' instruction n times.

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

wait_msec_st(n) is a BCM specific implementation, which uses the System Timer peripheral (not available on qemu).

Main

We use different wait implementations between printing strings on serial console.