## μCore/μForth is a hardware/software co-design environment

You must have docker installed, which may either run under Linux or MacOS. Windows10 won't work because it can not connect to a COMx port.

docker pull microcore/gforth\_062 will pull a gforth\_0.6.2 system into your host (https://hub.docker.com/r/microcore/gforth\_062). It is the basis of  $\mu$ Forth, the assembler/cross compiler, OS, and debugger for  $\mu$ Core. Please note that the docker image requires an RS232 serial interface.

 $\mu$ Core is written in VHDL and the code is available on github.com. During development, ModelSim has been used for simulation and Synplify for synthesis.

git clone https://github.com/microCore-VHDL/microCore will initially pull the basic  $\mu$ Core kernel without application specific additions. Documentation on  $\mu$ Core is available in the **documents** directory.

git clone https://github.com/microCore-VHDL/LFXP2\_8\_protoboard will initially pull a customized version for a simple prototyping board around the LFXP2-8E FPGA from Lattice. This is meant as a model on how to use  $\mu$ Core in applications. Documentation on the prototyping board is available in the **documents** directory.

Both projects have the same subdirectory structure:

## 

Documentation documents <technology> 'lattice', only present for lfxp2 8 protoboard. Simulator config file and wave display scripts for various tests modelsim ' work' library for the simulator's compiled μCore code work μForth cross compiler and basic sim/load files software Additional load/sim files. Copy the ones to use into 'software'. test Synthesizer onfiguration files for synplify synplify vhdl VHDL files of µCore a collection of architecture\_pkg and uDatacache files for architectures various data widths. Suffix 'b' means with byte addressing.

Please note that this structure is different from what the FPGA vendor specific design environments would like to see. Unfortunately, they all expect something different. Therefore, I try to abandon the use of the environments, just using the simulator, the synthesizer, and the FPGA-specific P&R suite as stand alone software. If this is not possible, the vendor's design suite is installed under <technology>.

In the following discussion, a Linux system is assumed as host OS.

To get started,  $\mu$ Core's instruction set test ./software/coretest.fs will be executed assuming ModelSim on Linux and the /dev/ttyUSB0 serial port. When using a different OS or serial interface, both ./software/umbilical.fs and the bin/bash file ./gforth\_062.sh have to be modified accordingly.

1. At first, ./software/sim\_core.fs must be cross compiled. To this end, open a terminal in the microCore directory. Start the docker image with ./gforth\_062.sh. This should display gforth's signon message if all goes well. If not, make sure that you did specify a valid serial port in the .sh-script.

- 2. **include sim\_core.fs<cr>** will produce an object code file for initializing μCore's program memory at the start of simulation. A couple of information lines will be displayed and the last line should read **sim\_core.fs** written to **program.mem** ok.
- 3. cd into ./modelSim and start modelSim by double-clicking microCore.mpf. This will open the project display. Don't forget to "Suppress Warnings: [] From IEEE Numeric Std Packages"(Pulldown 'Simulate' -> 'Runtime Options...') or else your Transcript screen will be flooded with irrelevant warning messages during simulation.
- 4. Create a **work** library by clicking 'File' -> 'New' -> 'Library'. Select "a new library and a logical mapping to it" and enter **work** for both 'Library Name:' and 'Library Physical Name:'.
- 5. 'Compile' -> 'Compile All' will compile the μCore design. It should produce one warning and no errors. (Perhaps your ModelSim version needs different initialization files in the simulator/work directory.)
- 6. Double click 'simulation' in the project tab. This will, amongst others, open the wave window.
- 7. In the wave window, click on the 'file' pull down menue and select 'load', which will open the **modelSim** directory. Double click **core.do**. This will select a set of basic μCore signals for the wave window.
- 8. Simulate for 130 usec and take a look at the right end of the wave display. If all went well, signal **bitout** will be high and signal **r.tos** will toggle between \$FFFFFFE and 0. In ModelSim's transcript window you should read:

```
# initializing ../software/program.mem
# starting core test ...
# ** Note: core test ok
# Time: <nnnnnn> ns Iteration: 4 Instance: /bench
```

If the last two message lines will not show, you either did not simulate long enough (> 130 us), or there was an error. Then **bitout** will be low and a number different from 0 in **r.tos** indicates the error, which you can search for in **coretest.fs**.