Files
OpenLane/flake.nix
Mohamed Gaber 16319b41d9 Update OpenLane 2 Lock, Use known-good OpenSTA (#2150)
~ `openlane2` -> `2.1.3`
~ use known-good version of OpenSTA: see https://github.com/parallaxsw/OpenSTA/issues/82
   ~ version linked against OpenROAD not affected
2024-09-05 15:25:08 +03:00

74 lines
2.3 KiB
Nix

# Copyright 2024 Efabless Corporation
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
{
nixConfig = {
extra-substituters = [
"https://openlane.cachix.org"
];
extra-trusted-public-keys = [
"openlane.cachix.org-1:qqdwh+QMNGmZAuyeQJTH9ErW57OWSvdtuwfBKdS254E="
];
};
inputs = {
openlane2.url = github:efabless/openlane2;
};
outputs = {
self,
openlane2,
...
}: let
nix-eda = openlane2.inputs.nix-eda;
nixpkgs = openlane2.inputs.nixpkgs;
in {
# Outputs
packages =
nix-eda.forAllSystems {
current = self;
withInputs = [nix-eda openlane2.inputs.libparse openlane2.inputs.volare openlane2];
} (util:
with util; let
self =
{
openroad-abc = pkgs.openroad-abc.override {
# openroad-abc-rev-sha
};
opensta = pkgs.opensta.override {
# opensta-rev-sha
};
openroad = pkgs.openroad.override {
# openroad-rev-sha
# https://github.com/The-OpenROAD-Project/OpenROAD/discussions/4743
openroad-abc = self.openroad-abc;
opensta = self.opensta;
};
magic = pkgs.magic.override {
# https://github.com/RTimothyEdwards/magic/issues/317
rev = "8.3.478";
sha256 = "sha256-aFFKbSqIgpkYjFZfpW3C52N1yQc5+KiLyf5jC16K5UU=";
};
openlane1 = callPythonPackage ./default.nix {};
default = self.openlane1;
}
// (pkgs.lib.optionalAttrs (pkgs.stdenv.isLinux) {
openlane1-docker = callPackage ./docker/docker.nix {
createDockerImage = nix-eda.createDockerImage;
};
});
in
self);
};
}