Skip to content
/ XC-SoC Public
forked from yczheng-hit/XC-SoC

A Simple SoC Based on Cortex-M0

Notifications You must be signed in to change notification settings

cmossss/XC-SoC

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

33 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

XC-SoC

A simple SoC Based on Cortex-m0.

Configuration

Install Verilator. Install arm-none-elf-gcc(if used) or

sudo apt install gcc-arm-none-eabi

You can also use keil to compile C source.

First Start

Follow these steps to build the simulation environment.

cd simulation
make sim
make image.hex # GNU gcc only
./sim_main -h

For more detail, read the source code please.

Files

Memory Map

Address Range Description
0X00000000 .. 0X0000FFFF RAMCODE
0X20000000 .. 0X2000FFFF RAMDATA
0X40000010 .. 0X4000001B UART
0X40000020 .. 0X4000002B SPI
0X40010000 .. 0X4001FFFF VGA

Files in this Repository

FPGA

This Verilog file contains the following Verilog modules:

File Description
XC-SoC.xpr Vivado Project
ebaz4205.xdc Constraints File for EBAZ4205 Board

The IP core clk_wiz is not included currently.

RTL

RTL Source, core_m0 included.

File Description
cortexm0ds_logic.v Cortex-m0 Core
XC_SoC.v Top File of The Project
…… ……

simulation

Source file for simulation. Current simulation is finished by verilator. VCS(or more) will be supported soon.

File/Folder Description
makefile Makefile for Simulation
src_verilator Folder of CPP Source for Simulation
verilator.vc Simulation Script for Verilator

software

Software source for XC-SoC.

File/Folder Description
gcc Startup File and Makefile Based on GNU GCC
keil Startup File and Keil Project
main.c main.c
XC-SoC.h Core Config for XC-SoC
include M0 Core Headfile
uart_api.h/c API for UART
spi_api.h/c API for SPI

README.md

\^_^

Troubleshooting Build Problems

src_verilator/sim_main.cpp:1:10: fatal error: verilated.h: No such file or directory

Check whether verilator is installed correctly and make clean.

TODO

  1. IIC (Waiting for board T_T)
  2. FM (Waiting for board T_T)

About

A Simple SoC Based on Cortex-M0

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Verilog 81.6%
  • C++ 8.6%
  • C 8.2%
  • Assembly 0.8%
  • Makefile 0.6%
  • Python 0.2%