package sipyco and use for controllers

This commit is contained in:
Sebastien Bourdeauducq 2019-11-07 19:34:36 +08:00
parent e69ddf6c4c
commit 9b0bead69b
4 changed files with 64 additions and 41 deletions

View File

@ -18,7 +18,7 @@ let
"artiq-board-${board.target}-${board.variant}" = boardBinaries; "artiq-board-${board.target}-${board.variant}" = boardBinaries;
}) {} boards; }) {} boards;
mainPackages = rec { mainPackages = rec {
inherit (pythonDeps) asyncserial levenshtein pythonparser quamash pyqtgraph-qt5 misoc migen microscope jesd204b migen-axi lit outputcheck; inherit (pythonDeps) sipyco asyncserial levenshtein pythonparser quamash pyqtgraph-qt5 misoc migen microscope jesd204b migen-axi lit outputcheck;
binutils-or1k = callPackage ./pkgs/binutils.nix { platform = "or1k"; target = "or1k-linux"; }; binutils-or1k = callPackage ./pkgs/binutils.nix { platform = "or1k"; target = "or1k-linux"; };
binutils-arm = callPackage ./pkgs/binutils.nix { platform = "arm"; target = "armv7-unknown-linux-gnueabihf"; }; binutils-arm = callPackage ./pkgs/binutils.nix { platform = "arm"; target = "armv7-unknown-linux-gnueabihf"; };
llvm-or1k = callPackage ./pkgs/llvm-or1k.nix {}; llvm-or1k = callPackage ./pkgs/llvm-or1k.nix {};
@ -32,6 +32,13 @@ let
artiq = callPackage ./pkgs/artiq.nix { inherit binutils-or1k llvm-or1k llvmlite-artiq libartiq-support lit outputcheck; }; artiq = callPackage ./pkgs/artiq.nix { inherit binutils-or1k llvm-or1k llvmlite-artiq libartiq-support lit outputcheck; };
artiq-env = (pkgs.python3.withPackages(ps: [ artiq ])).overrideAttrs (oldAttrs: { name = "${pkgs.python3.name}-artiq-env-${artiq.version}"; }); artiq-env = (pkgs.python3.withPackages(ps: [ artiq ])).overrideAttrs (oldAttrs: { name = "${pkgs.python3.name}-artiq-env-${artiq.version}"; });
openocd = callPackage ./pkgs/openocd.nix {}; openocd = callPackage ./pkgs/openocd.nix {};
conda-sipyco = import ./conda-build.nix { inherit pkgs; } {
name = "conda-sipyco";
src = import ./conda-fake-source.nix { inherit pkgs; } {
name = "sipyco";
inherit (pythonDeps.sipyco) version src;
};
};
conda-artiq = import ./conda-artiq.nix { inherit pkgs; }; conda-artiq = import ./conda-artiq.nix { inherit pkgs; };
}; };
in in

View File

@ -2,6 +2,18 @@
rec { rec {
# User dependencies # User dependencies
sipyco = python3Packages.buildPythonPackage rec {
name = "sipyco";
version = "1.0";
src = fetchFromGitHub {
owner = "m-labs";
repo = "sipyco";
rev = "ec6602c086054520f7617bb1fbee2e0897409978";
sha256 = "0jm8b533qa9ny1p3dyvpk8aa7vb50qp59937lp0k8zs73sv32grz";
};
propagatedBuildInputs = with python3Packages; [ numpy ];
};
asyncserial = python3Packages.buildPythonPackage rec { asyncserial = python3Packages.buildPythonPackage rec {
name = "asyncserial"; name = "asyncserial";
src = fetchFromGitHub { src = fetchFromGitHub {

View File

@ -153,7 +153,7 @@ let
echo file device_db_template \$out/device_db.py >> \$out/nix-support/hydra-build-products echo file device_db_template \$out/device_db.py >> \$out/nix-support/hydra-build-products
"; ";
})) drtio-systems; })) drtio-systems;
extras = import ./extras.nix { inherit pkgs; inherit (artiq-fast) asyncserial artiq; }; extras = import ./extras.nix { inherit pkgs; inherit (artiq-fast) sipyco asyncserial artiq; };
in in
artiq-fast // generic-kasli // drtio-ddbs // extras // rec { artiq-fast // generic-kasli // drtio-ddbs // extras // rec {
artiq-board-sayma-rtm = artiq-board { artiq-board-sayma-rtm = artiq-board {

View File

@ -1,4 +1,4 @@
{ pkgs, asyncserial, artiq }: { pkgs, sipyco, asyncserial, artiq }:
let let
dualPackage = ( dualPackage = (
{ name, version, src, pythonOptions ? {}, condaOptions ? {}}: { name, version, src, pythonOptions ? {}, condaOptions ? {}}:
@ -49,82 +49,85 @@ let
in in
(dualPackage { (dualPackage {
name = "korad_ka3005p"; name = "korad_ka3005p";
version = "1.0"; version = "1.1";
src = pkgs.fetchFromGitHub { src = pkgs.fetchFromGitHub {
owner = "m-labs"; owner = "m-labs";
repo = "korad_ka3005p"; repo = "korad_ka3005p";
rev = "e8c02ade175b842972f76a27919a4aaf8190de90"; rev = "a0cfaa5792a211e166d224314c4d0be4881b9b8d";
sha256 = "1svgnx52amvy9xl0b2wkz0ii4ycjvjv96ac0g07zkxabdqm5ff65"; sha256 = "1bxzyjyvdhsbm9hj7ypf0vgkd1lvc340bb6lx3wchvh30n7bv9gv";
}; };
pythonOptions = { propagatedBuildInputs = [ asyncserial artiq ]; }; pythonOptions = { propagatedBuildInputs = [ sipyco asyncserial ]; };
condaOptions = { dependencies = [ "asyncserial" ]; }; condaOptions = { dependencies = [ "sipyco" "asyncserial" ]; };
}) // (dualPackage { }) // (dualPackage {
name = "novatech409b"; name = "novatech409b";
version = "1.0"; version = "1.1";
src = pkgs.fetchFromGitHub { src = pkgs.fetchFromGitHub {
owner = "m-labs"; owner = "m-labs";
repo = "novatech409b"; repo = "novatech409b";
rev = "442e82e2234c0bf951da2084a77861f8977755c8"; rev = "8740b3e7b254e03395135e6bc128bbaca70d4fbb";
sha256 = "032qgg48dy2k31vj0q8bfni0iy2kcyscd32bq60h701wvass6jv7"; sha256 = "0mwm434y83y8jb30fpz69z6z3b6sxbc8dv3nw0hq4wc7iginx89d";
}; };
pythonOptions = { propagatedBuildInputs = [ asyncserial artiq ]; }; pythonOptions = { propagatedBuildInputs = [ sipyco asyncserial ]; };
condaOptions = { dependencies = [ "asyncserial" ]; }; condaOptions = { dependencies = [ "sipyco" "asyncserial" ]; };
}) // (dualPackage { }) // (dualPackage {
name = "lda"; name = "lda";
version = "1.0"; version = "1.1";
src = pkgs.fetchFromGitHub { src = pkgs.fetchFromGitHub {
owner = "m-labs"; owner = "m-labs";
repo = "lda"; repo = "lda";
rev = "4329da1497f496839ce20beebce0d79ed453941f"; rev = "6138a94a1116c8f7b40b8bd8bb161f847065aab6";
sha256 = "00c15a03xy9vbca0j2zfy89l3ghbdmmv5wqfksm6pdwy4z036cwa"; sha256 = "1009k9pq8wx5zxrljkxr1g95g8q979i7mq3csksdkd3d0v2jvqif";
}; };
pythonOptions = { pythonOptions = {
propagatedBuildInputs = [ artiq ]; propagatedBuildInputs = [ sipyco ];
postPatch = '' postPatch = ''
substituteInPlace lda/hidapi.py \ substituteInPlace lda/hidapi.py \
--replace "hidapi_lib_path = None"\ --replace "hidapi_lib_path = None"\
"hidapi_lib_path = '${hidapi}/lib/libhidapi-libusb.so.0'" "hidapi_lib_path = '${hidapi}/lib/libhidapi-libusb.so.0'"
''; '';
}; };
condaOptions = { dependencies = [ "sipyco" ]; };
}) // (dualPackage { }) // (dualPackage {
name = "thorlabs_tcube"; name = "thorlabs_tcube";
version = "1.0"; version = "1.1";
src = pkgs.fetchFromGitHub { src = pkgs.fetchFromGitHub {
owner = "m-labs"; owner = "m-labs";
repo = "thorlabs_tcube"; repo = "thorlabs_tcube";
rev = "b72e7ba7de8355bd93dd20d53b6f15386dff229d"; rev = "8b85292d76a69ae72ba8da32b894c87c794574ba";
sha256 = "1lqwqflwbfdykmhf6g0pwgiq7i2vf67ybj4l8n3jn16vny21b41s"; sha256 = "09cy9nhydcwdib21wb0qg1cinvibfbszwgphrmf2ajw5kqpr1d6a";
}; };
pythonOptions = { propagatedBuildInputs = [ asyncserial artiq ]; }; pythonOptions = { propagatedBuildInputs = [ sipyco asyncserial ]; };
condaOptions = { dependencies = [ "asyncserial" ]; }; condaOptions = { dependencies = [ "sipyco" "asyncserial" ]; };
}) // (dualPackage { }) // (dualPackage {
name = "newfocus8742"; name = "newfocus8742";
version = "0.1"; version = "0.2";
src = pkgs.fetchFromGitHub { src = pkgs.fetchFromGitHub {
owner = "quartiq"; owner = "quartiq";
repo = "newfocus8742"; repo = "newfocus8742";
rev = "31a92595d1cb77d9256b891ec17eed0fbeceb1bc"; rev = "9f6092b724b33b934aa4d3a1d6a20c295cd1d02d";
sha256 = "1dww0y83d4i6nma1q5hnaagih94c32bxlla5p6a5a8zkc4x2pky9"; sha256 = "0qf05ghylnqf3l5vjx5dc748wi84xn6p6lb6f9r8p6f1z7z67fb8";
}; };
pythonOptions = { pythonOptions = {
propagatedBuildInputs = [ pkgs.python3Packages.pyusb artiq ]; propagatedBuildInputs = [ sipyco pkgs.python3Packages.pyusb ];
# no unit tests so do a simple smoke test # no unit tests so do a simple smoke test
checkPhase = "python -m newfocus8742.aqctl_newfocus8742 --version"; checkPhase = "python -m newfocus8742.aqctl_newfocus8742 -h";
}; };
condaOptions = { dependencies = [ "sipyco" ]; };
}) // (dualPackage { }) // (dualPackage {
name = "hut2"; name = "hut2";
version = "0.1"; version = "0.2";
src = pkgs.fetchFromGitHub { src = pkgs.fetchFromGitHub {
owner = "quartiq"; owner = "quartiq";
repo = "hut2"; repo = "hut2";
rev = "acfd62dcd60d37250e2d1b691344c6e65b6e83eb"; rev = "26aaa8edd57d44dc00a41c3082536ac58dcbc9d6";
sha256 = "0dpx3c5aclj7gki6iaybjbx9rqrxnwccpxcvjwp594ccbcswvclr"; sha256 = "0p8iwapsx3g5k2sazian4s97cwcixkh3gnn7y44mhyydn8k7i3g0";
}; };
pythonOptions = { pythonOptions = {
propagatedBuildInputs = [ artiq ]; propagatedBuildInputs = [ sipyco ];
# no unit tests without hardware so do a simple smoke test # no unit tests without hardware so do a simple smoke test
checkPhase = "python -m hut2.aqctl_hut2 --version"; checkPhase = "python -m hut2.aqctl_hut2 -h";
}; };
condaOptions = { dependencies = [ "sipyco" ]; };
}) // rec { }) // rec {
toptica-lasersdk = pkgs.python3Packages.buildPythonPackage rec { toptica-lasersdk = pkgs.python3Packages.buildPythonPackage rec {
version = "2.0.0"; version = "2.0.0";
@ -137,13 +140,13 @@ in
propagatedBuildInputs = [ pkgs.python3Packages.pyserial ]; propagatedBuildInputs = [ pkgs.python3Packages.pyserial ];
}; };
toptica-lasersdk-artiq = pkgs.python3Packages.buildPythonPackage rec { toptica-lasersdk-artiq = pkgs.python3Packages.buildPythonPackage rec {
version = "0.1"; version = "0.2";
name = "toptica-lasersdk-artiq-${version}"; name = "toptica-lasersdk-artiq-${version}";
src = pkgs.fetchFromGitHub { src = pkgs.fetchFromGitHub {
owner = "quartiq"; owner = "quartiq";
repo = "lasersdk-artiq"; repo = "lasersdk-artiq";
rev = "d38bb985e7ddffc9ac9d94fe136cac10947bfd72"; rev = "f96d0e81aa47beb468fa4d73d92dad0872d8a960";
sha256 = "03a09lc81l2l787yjm0xjpnjvs5x77ndmks3xxh25yyxdhsdf1fl"; sha256 = "1z6yc4h7fjw5b3f50asdk1kp65sj4hhxmdzsh1ay8g3n1c9g3hh5";
}; };
postPatch = '' postPatch = ''
substituteInPlace lasersdk_artiq/aqctl_laser.py \ substituteInPlace lasersdk_artiq/aqctl_laser.py \
@ -153,20 +156,21 @@ in
--replace "toptica.lasersdk.async.client" \ --replace "toptica.lasersdk.async.client" \
"toptica.lasersdk.asyncio.client" "toptica.lasersdk.asyncio.client"
''; '';
propagatedBuildInputs = [ toptica-lasersdk artiq ]; propagatedBuildInputs = [ sipyco toptica-lasersdk ];
}; };
} // (dualPackage { } // (dualPackage {
name = "highfinesse-net"; name = "highfinesse-net";
version = "0.1"; version = "0.2";
src = pkgs.fetchFromGitHub { src = pkgs.fetchFromGitHub {
owner = "quartiq"; owner = "quartiq";
repo = "highfinesse-net"; repo = "highfinesse-net";
rev = "6864ae5da5cbc67953b968010115db951e52a272"; rev = "595daeb036592cf0254989e9b2cf8fac4844b6bc";
sha256 = "1k8xacgam5xghxvljvdzpsdhhq86fra13hkvdy7y301s9nyp30s4"; sha256 = "1nq7mnirprlac453rxfarf0wpdw77jmji2m22ks4nwjlb43ahmaz";
}; };
pythonOptions = { pythonOptions = {
propagatedBuildInputs = [ artiq ]; propagatedBuildInputs = [ sipyco ];
# no unit tests without hardware so do a simple smoke test # no unit tests without hardware so do a simple smoke test
checkPhase = "python -m highfinesse_net.aqctl_highfinesse_net --version"; checkPhase = "python -m highfinesse_net.aqctl_highfinesse_net -h";
}; };
condaOptions = { dependencies = [ "sipyco" ]; };
}) })