commit c4decdefb96f2511374b2b2a2fff5d92e8cf85f7 Author: Jacob Lifshay Date: Sat Oct 11 23:53:05 2025 -0700 WIP creating build script diff --git a/.forgejo/workflows/build.yml b/.forgejo/workflows/build.yml new file mode 100644 index 0000000..63b5096 --- /dev/null +++ b/.forgejo/workflows/build.yml @@ -0,0 +1,16 @@ +# SPDX-License-Identifier: LGPL-3.0-or-later +# See Notices.txt for copyright information +on: [push, pull_request] + +jobs: + build: + runs-on: debian-12 + steps: + - uses: actions/checkout@v3 + - run: | + scripts/check-copyright.sh + - run: | + apt-get update -qq + apt-get install -qq proot skopeo umoci + - run: | + ./build-container.sh \ No newline at end of file diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..e1334fe --- /dev/null +++ b/.gitignore @@ -0,0 +1,6 @@ +# SPDX-License-Identifier: LGPL-3.0-or-later +# See Notices.txt for copyright information + +/build +/build-container/ +/.cache diff --git a/LICENSE.md b/LICENSE.md new file mode 100644 index 0000000..0927556 --- /dev/null +++ b/LICENSE.md @@ -0,0 +1,157 @@ +### GNU LESSER GENERAL PUBLIC LICENSE + +Version 3, 29 June 2007 + +Copyright (C) 2007 Free Software Foundation, Inc. + + +Everyone is permitted to copy and distribute verbatim copies of this +license document, but changing it is not allowed. + +This version of the GNU Lesser General Public License incorporates the +terms and conditions of version 3 of the GNU General Public License, +supplemented by the additional permissions listed below. + +#### 0. Additional Definitions. + +As used herein, "this License" refers to version 3 of the GNU Lesser +General Public License, and the "GNU GPL" refers to version 3 of the +GNU General Public License. + +"The Library" refers to a covered work governed by this License, other +than an Application or a Combined Work as defined below. + +An "Application" is any work that makes use of an interface provided +by the Library, but which is not otherwise based on the Library. +Defining a subclass of a class defined by the Library is deemed a mode +of using an interface provided by the Library. + +A "Combined Work" is a work produced by combining or linking an +Application with the Library. The particular version of the Library +with which the Combined Work was made is also called the "Linked +Version". + +The "Minimal Corresponding Source" for a Combined Work means the +Corresponding Source for the Combined Work, excluding any source code +for portions of the Combined Work that, considered in isolation, are +based on the Application, and not on the Linked Version. + +The "Corresponding Application Code" for a Combined Work means the +object code and/or source code for the Application, including any data +and utility programs needed for reproducing the Combined Work from the +Application, but excluding the System Libraries of the Combined Work. + +#### 1. Exception to Section 3 of the GNU GPL. + +You may convey a covered work under sections 3 and 4 of this License +without being bound by section 3 of the GNU GPL. + +#### 2. Conveying Modified Versions. + +If you modify a copy of the Library, and, in your modifications, a +facility refers to a function or data to be supplied by an Application +that uses the facility (other than as an argument passed when the +facility is invoked), then you may convey a copy of the modified +version: + +- a) under this License, provided that you make a good faith effort + to ensure that, in the event an Application does not supply the + function or data, the facility still operates, and performs + whatever part of its purpose remains meaningful, or +- b) under the GNU GPL, with none of the additional permissions of + this License applicable to that copy. + +#### 3. Object Code Incorporating Material from Library Header Files. + +The object code form of an Application may incorporate material from a +header file that is part of the Library. You may convey such object +code under terms of your choice, provided that, if the incorporated +material is not limited to numerical parameters, data structure +layouts and accessors, or small macros, inline functions and templates +(ten or fewer lines in length), you do both of the following: + +- a) Give prominent notice with each copy of the object code that + the Library is used in it and that the Library and its use are + covered by this License. +- b) Accompany the object code with a copy of the GNU GPL and this + license document. + +#### 4. Combined Works. + +You may convey a Combined Work under terms of your choice that, taken +together, effectively do not restrict modification of the portions of +the Library contained in the Combined Work and reverse engineering for +debugging such modifications, if you also do each of the following: + +- a) Give prominent notice with each copy of the Combined Work that + the Library is used in it and that the Library and its use are + covered by this License. +- b) Accompany the Combined Work with a copy of the GNU GPL and this + license document. +- c) For a Combined Work that displays copyright notices during + execution, include the copyright notice for the Library among + these notices, as well as a reference directing the user to the + copies of the GNU GPL and this license document. +- d) Do one of the following: + - 0) Convey the Minimal Corresponding Source under the terms of + this License, and the Corresponding Application Code in a form + suitable for, and under terms that permit, the user to + recombine or relink the Application with a modified version of + the Linked Version to produce a modified Combined Work, in the + manner specified by section 6 of the GNU GPL for conveying + Corresponding Source. + - 1) Use a suitable shared library mechanism for linking with + the Library. A suitable mechanism is one that (a) uses at run + time a copy of the Library already present on the user's + computer system, and (b) will operate properly with a modified + version of the Library that is interface-compatible with the + Linked Version. +- e) Provide Installation Information, but only if you would + otherwise be required to provide such information under section 6 + of the GNU GPL, and only to the extent that such information is + necessary to install and execute a modified version of the + Combined Work produced by recombining or relinking the Application + with a modified version of the Linked Version. (If you use option + 4d0, the Installation Information must accompany the Minimal + Corresponding Source and Corresponding Application Code. If you + use option 4d1, you must provide the Installation Information in + the manner specified by section 6 of the GNU GPL for conveying + Corresponding Source.) + +#### 5. Combined Libraries. + +You may place library facilities that are a work based on the Library +side by side in a single library together with other library +facilities that are not Applications and are not covered by this +License, and convey such a combined library under terms of your +choice, if you do both of the following: + +- a) Accompany the combined library with a copy of the same work + based on the Library, uncombined with any other library + facilities, conveyed under the terms of this License. +- b) Give prominent notice with the combined library that part of it + is a work based on the Library, and explaining where to find the + accompanying uncombined form of the same work. + +#### 6. Revised Versions of the GNU Lesser General Public License. + +The Free Software Foundation may publish revised and/or new versions +of the GNU Lesser General Public License from time to time. Such new +versions will be similar in spirit to the present version, but may +differ in detail to address new problems or concerns. + +Each version is given a distinguishing version number. If the Library +as you received it specifies that a certain numbered version of the +GNU Lesser General Public License "or any later version" applies to +it, you have the option of following the terms and conditions either +of that published version or of any later version published by the +Free Software Foundation. If the Library as you received it does not +specify a version number of the GNU Lesser General Public License, you +may choose any version of the GNU Lesser General Public License ever +published by the Free Software Foundation. + +If the Library as you received it specifies that a proxy can decide +whether future versions of the GNU Lesser General Public License shall +apply, that proxy's public statement of acceptance of any version is +permanent authorization for you to choose that version for the +Library. diff --git a/Notices.txt b/Notices.txt new file mode 100644 index 0000000..b495805 --- /dev/null +++ b/Notices.txt @@ -0,0 +1,16 @@ +Copyright 2024 Jacob Lifshay + +This file is part of Fayalite. + +Fayalite is free software: you can redistribute it and/or modify +it under the terms of the GNU Lesser General Public License as published by +the Free Software Foundation, either version 3 of the License, or +(at your option) any later version. + +Fayalite is distributed in the hope that it will be useful, +but WITHOUT ANY WARRANTY; without even the implied warranty of +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +GNU Lesser General Public License for more details. + +You should have received a copy of the GNU Lesser General Public License +along with Fayalite. If not, see . diff --git a/build-container.sh b/build-container.sh new file mode 100755 index 0000000..e925b7d --- /dev/null +++ b/build-container.sh @@ -0,0 +1,137 @@ +#!/bin/bash +# SPDX-License-Identifier: LGPL-3.0-or-later +# See Notices.txt for copyright information +set -e + +function build_in_container() +{ + if [[ "$0" != "/build.sh" ]]; then + echo "you shouldn't run this outside of the container being built" >&2 + return 1 + fi + set -xe + mkdir -p /build + cd /build + apt update -qq + apt install -qqy \ + bison \ + build-essential \ + ccache \ + clang \ + cmake \ + cvc5 \ + default-jre-headless \ + flex \ + g++ \ + gawk \ + git \ + libantlr4-runtime-dev \ + libboost-filesystem-dev \ + libboost-iostreams-dev \ + libboost-program-options-dev \ + libboost-python-dev \ + libboost-system-dev \ + libboost-thread-dev \ + libeigen3-dev \ + libffi-dev \ + libreadline-dev \ + lld \ + openfpgaloader \ + pkg-config \ + python3 \ + python3-click \ + python3-venv \ + tcl-dev \ + uuid-dev \ + wget \ + zlib1g-dev + + update-ccache-symlinks # ccache seems to miss cc/c++ when installing, try to fix that here + + export PATH="/usr/lib/ccache:$PATH" + + python3 -m venv /opt/fayalite-deps/venv + source /opt/fayalite-deps/venv/bin/activate + + git clone https://github.com/SymbiFlow/prjxray.git /build/prjxray + cd /build/prjxray + git checkout c9f02d8576042325425824647ab5555b1bc77833 + git submodule update --init --recursive + mkdir -p build + cd build + cmake .. + make -j$(nproc) + make install + cd .. + sed -i 's/-e //' requirements.txt + pip install -r requirements.txt + + git clone https://github.com/openXC7/prjxray-db.git /opt/fayalite-deps/prjxray-db + cd /opt/fayalite-deps/prjxray-db + git checkout 381966a746cb4cf4a7f854f0e53caa3bf74fbe62 + + git clone https://github.com/chipsalliance/f4pga-xc-fasm.git /build/f4pga-xc-fasm + cd /build/f4pga-xc-fasm + git checkout 25dc605c9c0896204f0c3425b52a332034cf5e5c + pip install . + + git clone https://github.com/openXC7/nextpnr-xilinx.git /build/nextpnr-xilinx + cd /build/nextpnr-xilinx + git checkout 724db28b41e68568690a5ea1dd9ce5082362bb91 + git submodule update --init --recursive + mkdir -p build + cd build + cmake -DARCH=xilinx -DUSE_OPENMP=ON -DBUILD_GUI=OFF .. + make -j$(nproc) + make install + install bbasm /usr/local/bin/ + + cd /build + wget -O firrtl.tar.gz https://github.com/llvm/circt/releases/download/firtool-1.86.0/firrtl-bin-linux-x64.tar.gz + sha256sum -c - <<<'bf6f4ab18ae76f135c944efbd81e25391c31c1bd0617c58ab0592640abefee14 firrtl.tar.gz' + tar -xvaf firrtl.tar.gz + install firtool-1.86.0/bin/firtool /usr/local/bin/ + + # TODO: add yosys, sby, and z3 + + # get rid of caches and stuff + rm -rf \ + /build \ + /var/cache/apt/*.bin \ + /var/cache/apt/archives/*.deb \ + /var/cache/apt/archives/lock \ + /var/lib/apt/lists/*Packages* \ + /var/lib/apt/lists/*Release* \ + /var/lib/apt/lists/lock \ + /etc/apt/apt.conf.d/01autoremove-kernels \ + /var/log/apt/history.log \ + /var/log/apt/term.log \ + /var/lib/systemd/catalog/database +} + +function build_container() +{ + rm -rf build-container/ build/ + skopeo copy docker://debian:12 oci:build-container:latest + proot -0 umoci unpack --image=build-container:latest build + cp "$0" build/rootfs/build.sh + mkdir -p .cache/ccache + mkdir -p .cache/apt + proot -S build/rootfs \ + -b .cache/ccache:/root/.ccache \ + -b .cache/apt:/var/cache/apt \ + env -i -C / \ + "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin" \ + "TERM=xterm" \ + "HOME=/root" \ + "CCACHE_COMPILERCHECK=content" \ + /build.sh --build-in-container < /dev/null + rm build/rootfs/build.sh + proot -0 umoci repack --image=build-container:latest build +} + +if [[ "$*" == "--build-in-container" ]]; then + build_in_container +else + build_container +fi \ No newline at end of file diff --git a/scripts/check-copyright.sh b/scripts/check-copyright.sh new file mode 100755 index 0000000..f880a04 --- /dev/null +++ b/scripts/check-copyright.sh @@ -0,0 +1,62 @@ +#!/bin/bash +# SPDX-License-Identifier: LGPL-3.0-or-later +# See Notices.txt for copyright information +set -e + +function fail() +{ + local error="$1" + echo "error: $error" >&2 + exit 1 +} + +function fail_file() +{ + local file="$1" line="$2" error="$3" + fail "$file:$((line + 1)): $error" +} + +function check_file() +{ + local file="$1" regexes=("${@:2}") + local lines + mapfile -t lines < "$file" + local line + for line in "${!regexes[@]}"; do + eval '[[ "${lines[i]}" =~ '"${regexes[i]}"' ]]' || + fail_file "$file" "$line" "doesn't match regex: ${regexes[i]}" + done +} + +POUND_HEADER=('^"# SPDX-License-Identifier: LGPL-3.0-or-later"$' '^"# See Notices.txt for copyright information"$') +SLASH_HEADER=('^"// SPDX-License-Identifier: LGPL-3.0-or-later"$' '^"// See Notices.txt for copyright information"$') +MD_HEADER=('^"