nand2/07_Operating_System/01_GPIO_Test/Readme.md.backup

49 lines
1.2 KiB
Plaintext
Raw Normal View History

2023-01-11 10:13:09 +00:00
## GPIO.jack
This library provides access to `BUT` and `LED`.
### function void init(int addr)
Initialize LED (addr) and BUT (addr+1).
### function int readLed()
Returns the value of LED.
### function void writeLed(int c)
Write c to LED.
### function int readBut()
Returns the state of BUT.
***
## Project
In the Testfolder `01_GPIO_Test` you find a minimal version of `Sys.jack` containing the init function `Sys.init()`, which is called after starting JACK-OS. `Sys.init()` is the JACK-OS version of `leds.asm`, which reads the BUT and writes the values to LED in an endless loop:
```
class Sys {
function void init() {
do GPIO.init(4096);
while (true){
do GPIO.writeLed(GPIO.readBut());
}
return;
}
}
```
* Implement `GPIO.jack`
* Test in simulation:
```
$ cd 01_GPIO_Test
$ make
$ cd ../00_HACK
$ apio clean
$ apio sim
```
The test bench will simulate the pushing of BUT1/2. Check if the LED change accordingly.
![](gpio.png)
* run in real hardware with HACK build at `06_IO_Devices/05_GO` (together with the bootloader). Build and upload GPIO_Test to iCE40HX1K-EVB with:
```
$ cd 01_GPIO_Test
$ make
$ make upload
```
* push buttons BUT on iCE40HX1K-EVB and check the LED.