Compare commits
6 commits
14d20e3101
...
23b5de5cd3
Author | SHA1 | Date | |
---|---|---|---|
![]() |
23b5de5cd3 | ||
![]() |
d8ca756e43 | ||
![]() |
8b6ca3accc | ||
![]() |
7836ac5f3f | ||
![]() |
d48621521a | ||
![]() |
41c1e910dd |
2
.gitignore
vendored
2
.gitignore
vendored
|
@ -15,6 +15,8 @@ verilog_RTL
|
||||||
# files generated for FPGA ULX3s implementation
|
# files generated for FPGA ULX3s implementation
|
||||||
ulx3s_fpga/mkTop.d
|
ulx3s_fpga/mkTop.d
|
||||||
ulx3s_fpga/mkTop.json
|
ulx3s_fpga/mkTop.json
|
||||||
|
ulx3s_fpga/mkTop.bit
|
||||||
|
ulx3s_fpga/mkTop.config
|
||||||
|
|
||||||
# generated experiment outputs
|
# generated experiment outputs
|
||||||
experiments/bram/*.cxx
|
experiments/bram/*.cxx
|
||||||
|
|
2
Makefile
2
Makefile
|
@ -160,7 +160,7 @@ v_sim_vcd:
|
||||||
# ----------------------------------------------------------------
|
# ----------------------------------------------------------------
|
||||||
|
|
||||||
fpga:
|
fpga:
|
||||||
make -C ulx3s_fpga
|
make -C ulx3s_fpga mkTop.bit
|
||||||
|
|
||||||
.PHONY: clean
|
.PHONY: clean
|
||||||
clean:
|
clean:
|
||||||
|
|
|
@ -49,4 +49,3 @@ mkSerialize fileHandle = do
|
||||||
ftdiState := ftdiState' ftdiState
|
ftdiState := ftdiState' ftdiState
|
||||||
when (ftdiState == IDLE)
|
when (ftdiState == IDLE)
|
||||||
bitLineOut = ftdiTxOut
|
bitLineOut = ftdiTxOut
|
||||||
|
|
61
flake.lock
Normal file
61
flake.lock
Normal file
|
@ -0,0 +1,61 @@
|
||||||
|
{
|
||||||
|
"nodes": {
|
||||||
|
"nixpkgs": {
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1743689281,
|
||||||
|
"narHash": "sha256-y7Hg5lwWhEOgflEHRfzSH96BOt26LaYfrYWzZ+VoVdg=",
|
||||||
|
"owner": "NixOS",
|
||||||
|
"repo": "nixpkgs",
|
||||||
|
"rev": "2bfc080955153be0be56724be6fa5477b4eefabb",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "NixOS",
|
||||||
|
"ref": "nixpkgs-unstable",
|
||||||
|
"repo": "nixpkgs",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"root": {
|
||||||
|
"inputs": {
|
||||||
|
"nixpkgs": "nixpkgs",
|
||||||
|
"utils": "utils"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"systems": {
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1681028828,
|
||||||
|
"narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=",
|
||||||
|
"owner": "nix-systems",
|
||||||
|
"repo": "default",
|
||||||
|
"rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "nix-systems",
|
||||||
|
"repo": "default",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"utils": {
|
||||||
|
"inputs": {
|
||||||
|
"systems": "systems"
|
||||||
|
},
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1731533236,
|
||||||
|
"narHash": "sha256-l0KFg5HjrsfsO/JpG+r7fRrqm12kzFHyUHqHCVpMMbI=",
|
||||||
|
"owner": "numtide",
|
||||||
|
"repo": "flake-utils",
|
||||||
|
"rev": "11707dc2f618dd54ca8739b309ec4fc024de578b",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "numtide",
|
||||||
|
"repo": "flake-utils",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"root": "root",
|
||||||
|
"version": 7
|
||||||
|
}
|
98
flake.nix
Normal file
98
flake.nix
Normal file
|
@ -0,0 +1,98 @@
|
||||||
|
{
|
||||||
|
inputs = {
|
||||||
|
nixpkgs = {
|
||||||
|
url = "github:NixOS/nixpkgs/nixpkgs-unstable";
|
||||||
|
};
|
||||||
|
utils.url = "github:numtide/flake-utils";
|
||||||
|
};
|
||||||
|
|
||||||
|
outputs =
|
||||||
|
inputs:
|
||||||
|
inputs.utils.lib.eachDefaultSystem (
|
||||||
|
system:
|
||||||
|
let
|
||||||
|
pkgs = import inputs.nixpkgs {
|
||||||
|
localSystem = system;
|
||||||
|
overlays = [
|
||||||
|
(final: prev: {
|
||||||
|
|
||||||
|
riscv-bluespec-classic = pkgs.callPackage (
|
||||||
|
{
|
||||||
|
stdenv,
|
||||||
|
bluespec,
|
||||||
|
nextpnr,
|
||||||
|
openfpgaloader,
|
||||||
|
trellis,
|
||||||
|
which,
|
||||||
|
yosys,
|
||||||
|
}:
|
||||||
|
stdenv.mkDerivation {
|
||||||
|
pname = "riscv-bluespec-classic";
|
||||||
|
version = "0.1.0";
|
||||||
|
src = ./.;
|
||||||
|
|
||||||
|
# Versions can be checked with
|
||||||
|
# `nix eval --json ".#riscv-bluespec-classic.nativeBuildInputs" | nix-shell -p jq --run jq`
|
||||||
|
nativeBuildInputs = [
|
||||||
|
(
|
||||||
|
(bluespec.override {
|
||||||
|
makeWrapper = prev.makeBinaryWrapper;
|
||||||
|
withDocs = false;
|
||||||
|
texliveFull = null;
|
||||||
|
asciidoctor = null;
|
||||||
|
}).overrideAttrs
|
||||||
|
{
|
||||||
|
doCheck = false;
|
||||||
|
|
||||||
|
postFixup = ''
|
||||||
|
# https://github.com/B-Lang-org/bsc/blob/65e3a87a17f6b9cf38cbb7b6ad7a4473f025c098/src/comp/bsc.hs#L1839
|
||||||
|
wrapProgram $out/bin/core/bsc \
|
||||||
|
--prefix PATH : ${
|
||||||
|
prev.lib.makeBinPath (
|
||||||
|
if stdenv.hostPlatform.isDarwin then [ prev.cctools ] else [ prev.targetPackages.stdenv.cc ]
|
||||||
|
)
|
||||||
|
}
|
||||||
|
'';
|
||||||
|
}
|
||||||
|
)
|
||||||
|
nextpnr
|
||||||
|
openfpgaloader
|
||||||
|
trellis
|
||||||
|
which
|
||||||
|
yosys
|
||||||
|
];
|
||||||
|
|
||||||
|
makeFlags = [
|
||||||
|
"fpga"
|
||||||
|
];
|
||||||
|
|
||||||
|
installPhase = ''
|
||||||
|
runHook preInstall
|
||||||
|
|
||||||
|
mkdir -p "$out"
|
||||||
|
cp "./ulx3s_fpga/mkTop.bit" "$out/"
|
||||||
|
|
||||||
|
runHook postInstall
|
||||||
|
'';
|
||||||
|
|
||||||
|
}
|
||||||
|
) { };
|
||||||
|
|
||||||
|
})
|
||||||
|
];
|
||||||
|
};
|
||||||
|
in
|
||||||
|
{
|
||||||
|
packages = {
|
||||||
|
default = inputs.self.packages."${system}".riscv-bluespec-classic;
|
||||||
|
riscv-bluespec-classic = pkgs.riscv-bluespec-classic;
|
||||||
|
};
|
||||||
|
|
||||||
|
devShells.default =
|
||||||
|
with pkgs;
|
||||||
|
mkShell {
|
||||||
|
inputsFrom = [ riscv-bluespec-classic ];
|
||||||
|
};
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
14
shell.nix
14
shell.nix
|
@ -1,14 +0,0 @@
|
||||||
{ pkgs ? import (fetchTarball "https://github.com/NixOS/nixpkgs/archive/d34a98666913267786d9ab4aa803a1fc75f81f4d.tar.gz") {} }:
|
|
||||||
|
|
||||||
pkgs.mkShell {
|
|
||||||
buildInputs = [
|
|
||||||
pkgs.yosys
|
|
||||||
pkgs.nextpnr
|
|
||||||
pkgs.bluespec
|
|
||||||
pkgs.yosys-bluespec
|
|
||||||
];
|
|
||||||
|
|
||||||
shellHook = ''
|
|
||||||
echo "Dev environment for Manna Chip."
|
|
||||||
'';
|
|
||||||
}
|
|
|
@ -5,7 +5,7 @@ IDCODE ?= 0x41113043 # 85f
|
||||||
|
|
||||||
all: prog
|
all: prog
|
||||||
|
|
||||||
../verilog_RTL/$(TOPMODULE).v: ../src/Top.bsv
|
../verilog_RTL/$(TOPMODULE).v: ../bs/Top.bs
|
||||||
V_SIM=verilator TOPMODULE=$(TOPMODULE) make -C ../ v_compile
|
V_SIM=verilator TOPMODULE=$(TOPMODULE) make -C ../ v_compile
|
||||||
|
|
||||||
$(TOPMODULE).json: ../verilog_RTL/$(TOPMODULE).v
|
$(TOPMODULE).json: ../verilog_RTL/$(TOPMODULE).v
|
||||||
|
@ -21,6 +21,7 @@ $(TOPMODULE).config: $(TOPMODULE).json
|
||||||
--textcfg $@ \
|
--textcfg $@ \
|
||||||
--lpf ulx3s_v20.lpf \
|
--lpf ulx3s_v20.lpf \
|
||||||
--85k \
|
--85k \
|
||||||
|
--lpf-allow-unconstrained \
|
||||||
--package CABGA381
|
--package CABGA381
|
||||||
|
|
||||||
$(TOPMODULE).bit: $(TOPMODULE).config
|
$(TOPMODULE).bit: $(TOPMODULE).config
|
||||||
|
|
Loading…
Reference in a new issue