Difference between revisions of "Extend IOP16 minimal example"

From Land Boards Wiki
Jump to navigation Jump to search
Line 105: Line 105:
 
* Add [[IOP16_UART|UART peripheral]]
 
* Add [[IOP16_UART|UART peripheral]]
 
** Will set up [[IOP16_UART|UART]] in loopback
 
** Will set up [[IOP16_UART|UART]] in loopback
 +
* Update Memory map in comments at start of TestIOP16B.vhd to add UART addresses
 +
<pre>
 +
-- IOP16 MEMORY mAP
 +
-- 0X00      - KEY1 Pushbutton (R)
 +
-- 0X00      - User LED (W)
 +
-- 0x04-0x07 - Timer Unit
 +
-- 0X08      - UART (c/S) (r/w)
 +
-- 0X09      - UART (Data) (r/w)
 +
</pre>
  
 
= Create new peripherals =
 
= Create new peripherals =

Revision as of 12:20, 11 April 2022

Overview

This is a guide to extending the minimal IOP example by adding IOP16 Peripherals to the minimal design

Baseline Design

Starts from IOP example

  • Similar to Arduino "Blink Sketch" and uses the following resources
    • Timer Unit - 1 second timer
      • The Timer unit can be removed if not needed
      • Timer makes Blink easier
    • On-board LED

Steps

  • Copy baseline design
  • Select/add peripherals
  • Create new peripherals
  • Write assembly code
  • Build/test

Clone Sources

Alternately download ZIP files

  • Alternately you can download the two ZIP files from GitHub

IOP16 PortingGuide Download-Zip-Files.PNG

  • Unzip these two folders into the same folder

IOP16 PortingGuide Unzipped-to-Folder.PNG

  • Rename the folders to remove the -main from the folder path

IOP16 PortingGuide Remove-main.PNG

  • Result

IOP16 PortingGuide BuildFolderStructure.PNG

Build Minimal Example

Start by building the minimal example in Quartus II

  • Open the Project file (TestIOP16B.qpf) in Quartus II
  • Relative path: ..\TestBuild\IOP16\Higher_Level_Examples\TestIOP16_Minimal

IOP16 PortingGuide Open-Project-File.PNG

  • Entities in Quartus should look like

IOP16 PortingGuide Entities.PNG

  • Build FPGA (click the blue "Start Compilation arrow)

Fix ROM File Path

  • Quartus does not verify the ROM file was correct
    • Could be buried in the status messages
    • Likely need to re-point to the ROM .MIF file since Quartus II sometimes "forgets"
    • Double click on the IOP_ROM file

IOP16 PortingGuide Selecting ROM 2.PNG

  • Hit finish
    • Check for error message

IOP16 PortingGuide ROM Error.PNG

  • Re-point to the ROM file
  • Make sure to select .MIF file extension

IOP16 PortingGuide ROM TestTimer.PNG

Build Again / Download

  • Build again
  • Should be no error messages
  • Result

IOP16 PortingGuide FirstBuildResults.PNG

  • Download

IOP16 PortingGuide DownloadFPGA.PNG

  • User LED should be blinking

Select Peripherals

-- IOP16 MEMORY mAP
-- 0X00      - KEY1 Pushbutton (R)
-- 0X00      - User LED (W)
-- 0x04-0x07 - Timer Unit
-- 0X08      - UART (c/S) (r/w)
-- 0X09      - UART (Data) (r/w)

Create new peripherals

Write Assembly code

Test the build