Added info on tests that need to be implemented.
1 file changed
tree: f18ee9fbae02a53d091d01f90e3075bab12657df
- .github/
- def/
- docs/
- gds/
- lef/
- mag/
- maglef/
- openlane/
- sdc/
- sdf/
- signoff/
- spef/
- spi/
- verilog/
- .gitignore
- LICENSE
- Makefile
- README.md
README.md
ExperiarSoC
RISC-V SoC designed for the Efabless Open MPW Program. This project
data:image/s3,"s3://crabby-images/770e4/770e487f8c5e832535585d05f765d9fe23b17f2b" alt="Block diagram of Experiar SoC Block diagram of Experiar SoC"
Features
- Dual RV32I cores
- Per core SRAM
- JTAG interface
- External flash controller
- Shared video SRAM
- Configurable VGA output
- 3x UART ports + 1 internal to caravel
- 1x SPI ports
- 4x PWM counters with 4x seperate outputs (2 are internal read only)
Memory Map
data:image/s3,"s3://crabby-images/cd5eb/cd5ebd2eb6881862a68dbabbc3c06ff4764bbf07" alt="Memory map for Experiar SoC Memory map for Experiar SoC"
Macro Layout
data:image/s3,"s3://crabby-images/ce071/ce0713a9f7810325c04a1aacc55cf8aa1c7176a6" alt="Experiar SoC Macro Layout Experiar SoC Macro Layout"
Build Status
- CaravelHost: Success
- ExperiarCore: Success
- Flash: Success
- Peripherals: Success
- Video: Success
- WishboneInterconnect: Success
- user_project_wrapper: Error at step 13
- Running Global Routing Resizer Timing Optimizations: Routing congestion too high
Tests
verify-peripheral-rtl (-gl)
Status: Success
Runs a number of tests (currently just a very basic gpio test) from the management core to ensure the peripherals work correctly.
ToDo
- Get it to build
- Flash controller
- JTAG core managment controller
- CSRs
- Write more tests
- Fix all of the errors
Reference work and inspiration
- Zero to ASIC Course: Complete course on ASIC design. Also has useful references and terminology definitions.
- Openlane Documentation: Reference for a lot of configuration. The Variables and Hardening Macros pages have been particularity useful.
- Caravel Documentation: Reference for caravel and configuration. This seems slightly out of date, but an alternate version can be found in the github repository.
- Riscduino: Used for inspiration and as a reference for using openlane. There are a number of similar aspects to this project, but all have been reimplemented rather than copied.