Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add SoC config #681

Closed
wants to merge 631 commits into from
Closed

Add SoC config #681

wants to merge 631 commits into from

Conversation

infinitymdm
Copy link
Contributor

@infinitymdm infinitymdm commented Mar 19, 2024

Changes in this PR apply only to the soc branch, not main or dev

This PR adds a new configuration file for the Wally RV64GC SoC using BSG's memory controller, as well as a number of changes relevant to our SoC tapeout effort.

Summary of changes:

  • Bring the soc branch (relatively) up-to-date with main
  • Integrate debug spec from Debug Support seed #823
  • Clean up previous SoC-related changes:
    • Delete testbench/testbench-soc.sv and merge its contents into `testbench/testbench.sv
    • Delete soc-specific dofiles
    • Use a few new config parameters to selectively enable PLL and BSG DMC support
    • Add a new config file config/soc/config.vh
  • Get BSG's memory controller talking to Wally over AHB
    • Rewrite ahbxuiconverter.sv with FSM-based control and waaay simpler datapath
    • Add memory-mapped registers for configuring the memory controller
    • Add memory-mapped registers for configuring TCI 28nm PLL IP
    • Add "First stage bootloader" assembly procedures (under soc/fsbl) that set up the aforementioned configuration registers with valid test parameters
  • Test Wally in SoC configuration
    • Configure testbench to use the Micron LPDDR model provided by BSG
    • Add self-checking procedure to tests/custom/lpddrtest
    • You can run tests against the SoC config using regression-wally --soc

@davidharrishmc
Copy link
Contributor

I agree that I'd rather keep the ton of bsg stuff out of the wally-batch.do.

There's also a lot of unrelated files being committed here, such as copies of the crypto unit. Can you clean up the PR to only add the stuff you need?

@infinitymdm
Copy link
Contributor Author

There's also a lot of unrelated files being committed here, such as copies of the crypto unit. Can you clean up the PR to only add the stuff you need?

Most of that is just to catch the soc branch up to main. If you prefer, I can open a separate PR to pull main into soc.

@davidharrishmc
Copy link
Contributor

Ah, I understand. Disregard my comment.

@infinitymdm infinitymdm force-pushed the pll branch 2 times, most recently from c686795 to 77b15cb Compare March 27, 2024 15:54
@infinitymdm infinitymdm marked this pull request as ready for review March 28, 2024 03:01
@infinitymdm infinitymdm force-pushed the pll branch 3 times, most recently from 7604ebb to 7d74c70 Compare April 16, 2024 19:27
@infinitymdm infinitymdm marked this pull request as draft May 30, 2024 21:17
rosethompson and others added 27 commits June 19, 2024 14:00
Removes *** from all system verilog
Partial fix for verilator +args. At least compiles.
Modified makefile riscv-dv to not simulation only generate tests.
Covergen doesn't produce stores and riscv-dv only generates tests
lint cleanup and divider optimization
@infinitymdm
Copy link
Contributor Author

Closing for now pending #921. I'll open a new PR with just the memory controller changes rebased on top of main.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants