Commit Graph

863 Commits (4a7844404e8e1440652e5ac914d20e0489bdc0c4)
 

Author SHA1 Message Date
Anton Blanchard 4a7844404e Forgot to add DFFRAM
Anton Blanchard 6f697e4f5f Update PVR
Set a unique PVR for the caravel version of microwatt
Anton Blanchard 9910d99320 Not sure we need this
Anton Blanchard 9ccf9a7f80 Add a script to post process the microwatt verilog for caravel
Jordan Niethe a45c503aea Connect to the caravel logic analyzer
This connects 32 read and 32 write bits to the caravel logic analyzer.

Thanks to Jordan for the original patch
Anton Blanchard ce27cd3e28 Disable debug log
Anton Blanchard 5326455c02 No need to set HAS_FPU and LOG_LENGTH in Makefile
Anton Blanchard bf0c08dd87 tie off wb_ext_io_out
Anton Blanchard 120e1ce6ec SPI fixes, and remove reset controller and PLL
We need to expose all the input, output and output enable SPI lines
in order to use QSPI.

Remove the reset controller and PLL, since we are driving these
directly from caravel.
Michael Neuling 0664747146 Set alt reset vector to the start of flash at 0xf0000000 and make it
programmable externally (using carvel LA)
Michael Neuling 4685ff6bbb Add mc*.vhdl from:
git@github.com:openpowerwtf/uw_fab.git
Anton Blanchard 185bcba6bb Add a simple test case
We use 2 32bit RAMs, so we need to split the test case into
two files.
Anton Blanchard 83faae4a86 Add RAM_512x64
Anton Blanchard d1f0ac2e0b Disable second uart since we aren't using it
Anton Blanchard 17d93d504a Add a toplevel file for caravel
Anton Blanchard 9877db9b97 Disable BOOT_CLOCKS in flash controller
Anton Blanchard d852dedfe4 Reduce the core size
- 256B 2 way icache and dcache
- 2 entry 2 way dTLB
- 4 entry direct mapped iTLB
- 8 entry debug log
- disable FPU
Anton Blanchard 7fdbb7c850 Cut down hello_world to fit in 4kB
Michael Neuling 1ee4995cd8 Cleanup some 'U' state issues
Signed-off-by: Michael Neuling <mikey@neuling.org>
Anton Blanchard 55b6f8be52 Work around ghdl/yosys issue with direct mapped TLB
Workaround from Tristan.

Signed-off-by: Anton Blanchard <anton@linux.ibm.com>
Anton Blanchard 0be86c3a32 Update JTAG TAP controller for Microwatt
Make a few changes to match what mw_debug expects:

- 6 byte instructions
- IDCODE at 001001
- microwatt debug at 000011

Also change IDCODE to be an IBM ID.

Signed-off-by: Anton Blanchard <anton@linux.ibm.com>
Anton Blanchard 5e8ba5acb0 First pass at an external JTAG port
The verilator simulation interface uses the remote_bitbang
protocol from openocd. I have a simple implementation for
urjtag too.

Signed-off-by: Anton Blanchard <anton@linux.ibm.com>
Anton Blanchard a3b70ab01e Reset cmd_ready_o in spi_txrx
Initialize bit_count so that cmd_ready_o isn't X state immediately
after reset.

Signed-off-by: Anton Blanchard <anton@linux.ibm.com>
Anton Blanchard a0eb4eec17 Fix another reset issue in spi_rxtx
counter was X state after reset, initialize it.

Signed-off-by: Anton Blanchard <anton@linux.ibm.com>
Anton Blanchard 39c826aa46
Merge pull request from antonblanchard/wishbone_layout
Make wishbone_master_out and wb_io_master_out match
Anton Blanchard ebe696affc
Merge pull request from paulusmack/misc
soc: Drive uart1_irq to 0 when we don't have UART1
Anton Blanchard c6dfc19d89 Make wishbone_master_out and wb_io_master_out match
This makes it easier to parse the records in verilog because they
are getting flattened into an array of bits by ghdl/yosys.

Signed-off-by: Anton Blanchard <anton@linux.ibm.com>
Paul Mackerras e41cb01bca fetch1: Fix debug stop
The ability to stop the core using the debug interface has been broken
since commit bb4332b7e6b5 ("Remove fetch2 pipeline stage"), which
removed a statement that cleared the valid bit on instructions when
their stop_mark was 1.

Fix this by clearing r.req coming out of fetch1 when r.stop_mark = 1.
This has the effect of making i_out.valid be 0 from the icache.  We
also fix a bug in icache.vhdl where it was not honouring i_in.req when
use_previous = 1.

It turns out that the logic in fetch1.vhdl to handle stopping and
restarting was not correct, with the effect that stopping the core
would leave NIA pointing to the last instruction executed, not the
next instruction to be executed.  In fact the state machine is
unnecessary and the whole thing can be simplified enormously - we
need to increment NIA whenever stop_in = 0 in the previous cycle.

Fixes: bb4332b7e6b5 ("Remove fetch2 pipeline stage")
Signed-off-by: Paul Mackerras <paulus@ozlabs.org>
Paul Mackerras 97586e7e99 soc: Drive uart1_irq to 0 when we don't have UART1
The tools complain about uart1_irq not being driven and not having a
default when HAS_UART1 is false.  This sets it to 0 in that case.

Fixes: 7575b1e0c2 ("uart: Import and hook up opencore 16550 compatible UART")
Signed-off-by: Paul Mackerras <paulus@ozlabs.org>
Michael Neuling d96ee21c39
Merge pull request from antonblanchard/flash-reset
Fix a few reset issues in flash controller
Paul Mackerras f4831507b3
Merge pull request from antonblanchard/nofpu-fix
Fully initialize FPU buses when FPU is disabled
Anton Blanchard c870040a20 Fix an issue in flash controller when BOOT_CLOCKS is false
If BOOT_CLOCKS is false we currently get stuck in the flash
state machine. This patch from Ben fixes it.

Also fix an x state issue I see in icarus verilog where we need
to reset auto_state.

Signed-off-by: Anton Blanchard <anton@linux.ibm.com>
Anton Blanchard 659be2780f Fully initialize FPU buses when FPU is disabled
Some of the bits in the FPU buses end up as z state. Yosys
flags them, so we may as well clean it up.

Signed-off-by: Anton Blanchard <anton@linux.ibm.com>
Anton Blanchard 7c8bc85e44 Fix a few reset issues in flash controller
Our flash controller fails when simulating with iverilog. Looking
closer, both wb_stash and auto_last_addr are X state, and things
fall apart after they get used.

Initialise them both fixes the iverilog issue.

Signed-off-by: Anton Blanchard <anton@linux.ibm.com>
Anton Blanchard 081dc64d39
Merge pull request from antonblanchard/log-length
Add LOG_LENGTH to top-generic.vhdl
Anton Blanchard 86bdfe6fd4
Merge pull request from antonblanchard/fix-verilator
Add verilator FPGA target
Anton Blanchard 80cf489e96 Add LOG_LENGTH to top-generic.vhdl
The other top level files allow LOG_LENGTH to be configured.

Signed-off-by: Anton Blanchard <anton@linux.ibm.com>
Anton Blanchard df8e1ca2a7 Add verilator FPGA target
Our Makefiles need some work, but for now create an FPGA target:

make FPGA_TARGET=verilator microwatt-verilator

ghdl and yosys can use containers using PODMAN=1 or DOCKER=1
options.

Signed-off-by: Anton Blanchard <anton@linux.ibm.com>
Anton Blanchard 62d5b16c66
Merge pull request from antonblanchard/fix-verilator
Fix verilator build
Anton Blanchard 4bc5169f78 Fix verilator build
yosys and verilator did not like us passing in the verilog and
exporting it again. Pass the source directly to verilator instead.

Signed-off-by: Anton Blanchard <anton@linux.ibm.com>
Michael Neuling 77c03e5d42
Merge pull request from antonblanchard/hello-world-in-8k
Reduce hello_world footprint to fit in 8kB
Anton Blanchard 605010e33d Fix ghdl warning due to variable shadowing in icache
Fix a couple of ghdl warnings:

icache.vhdl:387:21⚠️ declaration of "i" hides constant "i" [-Whide]
icache.vhdl:400:17⚠️ declaration of "i" hides constant "i" [-Whide]

Signed-off-by: Anton Blanchard <anton@linux.ibm.com>
Anton Blanchard bc4e6b7efe Reduce hello_world footprint to fit in 8kB
When building with yosys we assume hello_world fits in 8kB. There's
enough free space that we can adjust the linker script to make it fit.

Signed-off-by: Anton Blanchard <anton@linux.ibm.com>
Michael Neuling 16da9b5ba7
Merge pull request from paulusmack/master
Sundry bug fixes, plus implement mtmsr
Michael Neuling b60026e7c1
Merge pull request from umarcor/containers
makefile: update synthesis containers
Michael Neuling d839037f0b
Merge pull request from umarcor/ci/containers
ci: use job.container
umarcor 93b2987b19 ci: use job.container
Signed-off-by: umarcor <unai.martinezcorral@ehu.eus>
umarcor de808d7a6a makefile: update synthesis containers
Signed-off-by: umarcor <unai.martinezcorral@ehu.eus>
umarcor d05737833e makefile: whitespace cleanup
Signed-off-by: umarcor <unai.martinezcorral@ehu.eus>
Paul Mackerras 29fabeb12e tests/misc: Add a test for correct CTR and LR updating by branches
This adds a test with a bdnzl followed immediately by a bdnz, to check
that CTR and LR both get evaluated and written back correctly in this
situation.

Signed-off-by: Paul Mackerras <paulus@ozlabs.org>