-
Notifications
You must be signed in to change notification settings - Fork 0
/
shell.nix
123 lines (107 loc) · 3.55 KB
/
shell.nix
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
# Licensed under the Apache License, Version 2.0 or the MIT License.
# SPDX-License-Identifier: Apache-2.0 OR MIT
# Copyright Tock Contributors 2022.
# Shell expression for the Nix package manager
#
# This nix expression creates an environment with necessary packages installed:
#
# * `tockloader`
# * rust
#
# To use:
#
# $ nix-shell
#
{ pkgs ? import <nixpkgs> {}, withUnfreePkgs ? false }:
with builtins;
let
inherit (pkgs) stdenv lib;
# Use builtins.fromTOML if available, otherwise use remarshal to
# generate JSON which can be read. Code taken from
# nixpkgs/pkgs/development/tools/poetry2nix/poetry2nix/lib.nix.
fromTOML = pkgs: builtins.fromTOML or (
toml: builtins.fromJSON (
builtins.readFile (
pkgs.runCommand "from-toml"
{
inherit toml;
allowSubstitutes = false;
preferLocalBuild = true;
}
''
${pkgs.remarshal}/bin/remarshal \
-if toml \
-i <(echo "$toml") \
-of json \
-o $out
''
)
)
);
# Tockloader v1.10.0
tockloader = import (pkgs.fetchFromGitHub {
owner = "tock";
repo = "tockloader";
# TODO: change to tag once there is a Tockloader release with
# `default.nix` included.
rev = "6f37412d5608d9bb48510c98a929cc3f96f8cc8f";
sha256 = "sha256-0WobupjSqJ36+nME9YO9wcEx4X6jE+edSn4PNM+aDUo=";
}) { inherit pkgs withUnfreePkgs; };
moz_overlay = import (builtins.fetchTarball https://github.com/mozilla/nixpkgs-mozilla/archive/master.tar.gz);
nixpkgs = import <nixpkgs> { overlays = [ moz_overlay ]; };
# Get a custom cross-compile capable Rust install of a specific channel and
# build. Tock expects a specific version of Rust with a selection of targets
# and components to be present.
rustBuild = (
nixpkgs.rustChannelOf (
let
# Read the ./rust-toolchain (and trim whitespace) so we can extrapolate
# the channel and date information. This makes it more convenient to
# update the Rust toolchain used.
rustToolchain = (
fromTOML pkgs (
builtins.readFile ./rust-toolchain.toml
)
).toolchain;
in
{
channel = lib.head (lib.splitString "-" rustToolchain.channel);
date = lib.concatStringsSep "-" (lib.tail (lib.splitString "-" rustToolchain.channel));
}
)
).rust.override {
targets = [
"thumbv7em-none-eabi" "thumbv7em-none-eabihf" "thumbv6m-none-eabi"
"riscv32imac-unknown-none-elf" "riscv32imc-unknown-none-elf" "riscv32i-unknown-none-elf"
];
extensions = [
"rust-src" # required to compile the core library
"llvm-tools-preview" # currently required to support recently added flags
];
};
in
pkgs.mkShell {
name = "tock-dev";
buildInputs = with pkgs; [
# --- Toolchains ---
rustBuild
openocd
# --- Convenience and support packages ---
python3Full
tockloader
# Required for tools/print_tock_memory_usage.py
python3Packages.cxxfilt
# --- CI support packages ---
qemu
];
LD_LIBRARY_PATH="${stdenv.cc.cc.lib}/lib64:$LD_LIBRARY_PATH";
# Instruct the Tock gnumake-based build system to not check for rustup and
# assume all requirend tools are installed and available in the $PATH
NO_RUSTUP = "1";
# The defaults "objcopy" and "objdump" are wrong (stem from the standard
# environment for x86), use "llvm-obj{copy,dump}" as defined in the makefile
shellHook = ''
unset OBJCOPY
unset OBJDUMP
'';
}