Skip to content

Commit

Permalink
starfive/visionfive/v1: init
Browse files Browse the repository at this point in the history
  • Loading branch information
Madouura committed Oct 8, 2022
1 parent 2c14c0f commit 78ff2af
Show file tree
Hide file tree
Showing 6 changed files with 167 additions and 0 deletions.
31 changes: 31 additions & 0 deletions starfive/visionfive/v1/default.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
{ lib, pkgs, ...}:

{
hardware.deviceTree.name = lib.mkDefault "starfive/jh7100-starfive-visionfive-v1.dtb";
systemd.services."serial-getty@hvc0".enable = lib.mkDefault false;
environment.systemPackages = with pkgs; lib.mkDefault [ mtdutils ];

boot = {
# Force no ZFS (from nixos/modules/profiles/base.nix) until updated to kernel 6.0
supportedFilesystems = lib.mkForce [ "btrfs" "reiserfs" "vfat" "f2fs" "xfs" "ntfs" "cifs" ];
consoleLogLevel = lib.mkDefault 7;
kernelPackages = lib.mkDefault (pkgs.callPackage ./linux.nix { });

kernelParams = lib.mkDefault [
"console=tty0"
"console=ttyS0,115200n8"
"earlycon=sbi"
];

initrd.kernelModules = lib.mkDefault [
"dw-axi-dmac-platform"
"dw_mmc-pltfm"
"spi-dw-mmio"
];

loader = {
grub.enable = lib.mkDefault false;
generic-extlinux-compatible.enable = lib.mkDefault true;
};
};
}
35 changes: 35 additions & 0 deletions starfive/visionfive/v1/firmware.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
{ runCommand
, buildPackages
, pkgs
}:

let
uboot = pkgs.callPackage ./uboot.nix { };

opensbi = pkgs.opensbi.override {
withPayload = "${uboot}/u-boot.bin";
withFDT = "${uboot}/u-boot.dtb";
};
in runCommand "firmware-starfive-visionfive-v1" {
nativeBuildInputs = with buildPackages; [ xxd ];
} ''
function handle_file {
inFile=$1
echo inFile: $inFile
outFile=$2
inSize=`stat -c "%s" $inFile`
inSize32HexBe=`printf "%08x\n" $inSize`
inSize32HexLe=''${inSize32HexBe:6:2}''${inSize32HexBe:4:2}''${inSize32HexBe:2:2}''${inSize32HexBe:0:2}
echo "inSize: $inSize (0x$inSize32HexBe, LE:0x$inSize32HexLe)"
echo $inSize32HexLe | xxd -r -ps > $outFile
cat $inFile >> $outFile
echo outFile: $outFile
outSize=`stat -c "%s" $outFile`
outSize32HexBe=`printf "%08x\n" $outSize`
echo "outSize: $outSize (0x$outSize32HexBe)"
}
mkdir -p "$out/nix-support"
echo "file bin \"$out/opensbi_u-boot_starfive_visionfive_v1.bin\"" >> "$out/nix-support/hydra-build-products"
handle_file ${opensbi}/share/opensbi/lp64/generic/firmware/fw_payload.bin $out/opensbi_u-boot_starfive_visionfive_v1.bin
''
42 changes: 42 additions & 0 deletions starfive/visionfive/v1/linux.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
{ lib
, callPackage
, linuxPackagesFor
, ... }:

let
modDirVersion = "6.0.0";

linuxPkg = { fetchFromGitHub, buildLinux, ... } @ args:
buildLinux (args // {
inherit modDirVersion;
version = "${modDirVersion}-starfive-visionfive-v1";
extraMeta.branch = "visionfive";

src = fetchFromGitHub {
owner = "starfive-tech";
repo = "linux";
rev = "cfcb617265422c0af0ae5bc9688dceba2d10b27a";
sha256 = "sha256-EAMCOtJZ51xSLySQPaZyomfa/1Xs9kNedz04tIbELqg=";
};

kernelPatches = [{
name = "starfive-visionfive-v1-default-config";
patch = null;

defconfig = "starfive_jh7100_fedora_defconfig";

structuredExtraConfig = with lib.kernel; {
SERIAL_8250_DW = yes;
PINCTRL_STARFIVE = yes;

# Doesn't build as a module
DW_AXI_DMAC_STARFIVE = yes;

# stmmac hangs when built as a module
PTP_1588_CLOCK = yes;
STMMAC_ETH = yes;
STMMAC_PCI = yes;
};
}];
} // (args.argsOverride or { }));
in lib.recurseIntoAttrs (linuxPackagesFor (callPackage linuxPkg { }))
12 changes: 12 additions & 0 deletions starfive/visionfive/v1/sd-image-installer.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
# To build, use:
# nix-build "<nixpkgs/nixos>" -I nixos-config=starfive/visionfive/v1/sd-image-installer.nix -A config.system.build.sdImage
{
imports = [
<nixpkgs/nixos/modules/profiles/installation-device.nix>
./sd-image.nix
];

# the installation media is also the installation target,
# so we don't want to provide the installation configuration.nix.
installer.cloneConfig = false;
}
29 changes: 29 additions & 0 deletions starfive/visionfive/v1/sd-image.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
# To build, use:
# nix-build "<nixpkgs}/nixos>" -I nixos-config=starfive/visionfive/v1/sd-image.nix -A config.system.build.sdImage
{ config, pkgs, ... }:

let
firmware = pkgs.callPackage ./firmware.nix { };
in {
imports = [
<nixpkgs/nixos/modules/profiles/base.nix>
<nixpkgs/nixos/modules/installer/sd-card/sd-image.nix>
./default.nix
];

sdImage = {
imageName = "${config.sdImage.imageBaseName}-${config.system.nixos.label}-${pkgs.stdenv.hostPlatform.system}-starfive-visionfive-v1.img";

# We have to use custom boot firmware since we do not support
# StarFive's Fedora MMC partition layout. Thus, we include this in
# the image's firmware partition so the user can flash the custom firmware.
populateFirmwareCommands = ''
cp ${firmware}/opensbi_u-boot_starfive_visionfive_v1.bin firmware/opensbi_u-boot_starfive_visionfive_v1.bin
'';

populateRootCommands = ''
mkdir -p ./files/boot
${config.boot.loader.generic-extlinux-compatible.populateCmd} -c ${config.system.build.toplevel} -d ./files/boot
'';
};
}
18 changes: 18 additions & 0 deletions starfive/visionfive/v1/uboot.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
{ fetchFromGitHub
, buildUBoot
}:

buildUBoot {
version = "2022.04";

src = fetchFromGitHub {
owner = "NickCao";
repo = "u-boot-starfive";
rev = "ac75aa54020412a83b61dad46c5ea15e7f9f525c";
sha256 = "1idh5k1479znp24rrfa0ikgk6iv5h80zscqhi6yv5ah4czia3ip3";
};

defconfig = "starfive_jh7100_visionfive_smode_defconfig";
extraMeta.platforms = [ "riscv64-linux" ];
filesToInstall = [ "u-boot.bin" "u-boot.dtb" ];
}

0 comments on commit 78ff2af

Please sign in to comment.