Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/calint/znxcr
experimental retro 16 bit cpu written in verilog xilinx vivado intended for fpga Cmod S7 from Digilent
https://github.com/calint/znxcr
16-bit cmod-s7 cpu fpga verilog
Last synced: about 2 months ago
JSON representation
experimental retro 16 bit cpu written in verilog xilinx vivado intended for fpga Cmod S7 from Digilent
- Host: GitHub
- URL: https://github.com/calint/znxcr
- Owner: calint
- Created: 2023-04-23T09:53:08.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-05-29T01:44:58.000Z (8 months ago)
- Last Synced: 2024-05-29T15:35:58.337Z (8 months ago)
- Topics: 16-bit, cmod-s7, cpu, fpga, verilog
- Language: Verilog
- Homepage:
- Size: 5.11 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# znxcr
> :bell: development continued in project [zen-x](https://github.com/calint/zen-x)
experimental retro 16 bit cpu written in verilog xilinx vivado intended for fpga Cmod S7 from Digilent
rom and ram implemented in lut
1 cycle / instruction
first try at fpga verilog vivado
```
n
e
z n-x-c r vintage 16 bit cpu
e e t a e
r g l t 16K 16 bit instructions
o a l u 16K 16 bit data
t r 16 16 bit registers
i n 33 MHz
v
e| 0 | 1 | 2 | 3 | 4 | 5 - 7 | 8-11 | 12-15|
|---|---|---|---|---|-------|------|------|
| z | n | x | r | c | o p | rega | regb |
|---|---|---|---|---|-------|------|------|
/ . / . / . / . / 0 / 0 0 0 / .... / .... / xor
/ . / . / . / . / 0 / 0 0 1 / imm4 / .... / addi
/ . / . / . / . / 0 / 0 1 0 / src / dst / copy
/ . / . / . / . / 0 / 0 1 1 / 0000 / .... / not
/ . / . / . / . / 0 / 0 1 1 / imm4 / .... / shift
/ . / . / . / . / 0 / 1 0 0 / ... / .... / sub
/ . / . / . / . / 0 / 1 0 1 / .... / .... / add
/ . / . / . / . / 0 / 1 1 0 / addr / dst / load
/ . / . / . / . / 0 / 1 1 1 / addr / src / store
/ . / . / 0 / 0 / 1 / immediate 11 << 3 / call
/ . / . / 0 / 1 / 1 / 0 0 0 / 0000 / .... / loop
/ . / . / 0 / 1 / 1 / 1 0 0 / immediate 8 / skip
/ . / . / 0 / 1 / 1 / 0 1 0 / 0000 / .... / loadiop : :
----:-------:-----------------------------------------------------
000 : xor : reg[b]=~reg[a]
100 : addi : reg[b]+=imm4
010 : copy : reg[b]=reg[a]
110 : not : reg[b]=~reg[b]
110 : shift : reg[b]>>=imm4 (negative imm4 means 'left')
001 : sub : reg[b]-=reg[a]
101 : add : reg[b]+=reg[a]
011 : load : reg[b]=ram[a]
111 : store : ram[a]=reg[b]page cr = 11
op : :
----:-------:-----------------------------------------------------
000 : loop : start loop with counter value from reg[b]
001 : skip : pc+=imm8+1
010 : loadi : reg[b]={next instruction}
011 : :
100 : :
101 : :
110 : :
111 : :
```