|  | 3 years ago | |
|---|---|---|
| blink | 3 years ago | |
| cryptocores@302ad79ced | 3 years ago | |
| lib | 3 years ago | |
| neorv32@3bd0835ac5 | 3 years ago | |
| neorv32_aes | 3 years ago | |
| uart_aes | 3 years ago | |
| uart_loop | 3 years ago | |
| uart_reg | 3 years ago | |
| uart_trng | 3 years ago | |
| .gitmodules | 3 years ago | |
| LICENSE.md | 3 years ago | |
| README.md | 3 years ago | |
Ongoing experiments with the Cologne Chip's GateMate FPGA architecture. All experiments are done with teh GateMate FPGA Starter (Eval) Kit.
Simple design which should display a blinking LED waving from LED1-LED8 of the GateMate FPGA Starter Kit. It uses CC_PLL & CC_CFG_END primitives of the GateMate FPGA.
Simple UART loop with UART RX & TX units and FIFO buffer between. It uses CC_PLL & CC_CFG_END primitives of the GateMate FPGA. With fifo depth >= 18 Yosys is infering CC_BRAM_20K instead of registers.
Beware: The simulation model of CC_BRAM_20K seems to be incorrect, so better set fifo depth < 18 or use yosys option -nobram when synthesizing the model for post-synthesis & post-implementation simulation.
Register file which can be accessed through UART. It uses CC_PLL & CC_CFG_END primitives of the GateMate FPGA. It contains 8 registers storing values of one byte each. The first received byte on the axis in port contains command & address:
7   reserved6:4 register address3:0 command (0x0 read, 0x1 write)In case of a write command, the payload has to follow with the next byte. In case of a read command, the value of the addressed register is returned on the axis out port. Register at address 0 is special. It contains the version and is read-only. Writes to that register are ignored.
An implementation of a TRNG which allows to read random data from the FPGA via UART. Inclusive a software tool for easy access. Random generation is based on a fibonacci ring oscillator (FiRo) with toggle flip-flop and von Neumann post-processing.