aboutsummaryrefslogtreecommitdiffstats
path: root/fpga/.ci/templates
diff options
context:
space:
mode:
Diffstat (limited to 'fpga/.ci/templates')
-rw-r--r--fpga/.ci/templates/check_clean_repo_steps.yml58
-rw-r--r--fpga/.ci/templates/fpga_build.yml82
-rw-r--r--fpga/.ci/templates/mb_cpld_build.yml67
-rw-r--r--fpga/.ci/templates/regmap.yml60
-rw-r--r--fpga/.ci/templates/zbx_cpld_build.yml67
5 files changed, 334 insertions, 0 deletions
diff --git a/fpga/.ci/templates/check_clean_repo_steps.yml b/fpga/.ci/templates/check_clean_repo_steps.yml
new file mode 100644
index 000000000..7ac034dd8
--- /dev/null
+++ b/fpga/.ci/templates/check_clean_repo_steps.yml
@@ -0,0 +1,58 @@
+#
+# Copyright 2021 Ettus Research, a National Instruments Brand
+#
+# SPDX-License-Identifier: LGPL-3.0-or-later
+#
+# Description:
+#
+# Checks for a clean repository (no untracked or modified files).
+#
+
+parameters:
+ # Directory to execute the commands in
+ - name: directory
+ type: string
+ default: $(Agent.BuildDirectory)/s
+
+steps:
+# Windows based calls
+- powershell: |
+ # Using git status as a way to check for a clean repo can produce
+ # misleading results when the line endings have been modified (XmlParse has
+ # a tendency to modify line endings). "git diff" seems to produce more
+ # reliable results, and the --exit-code is useful for detecting a change/no
+ # change summary.
+
+ # Check for modified files
+ git diff --exit-code; if (-not $?) {throw "git diff should be empty"}
+
+ # Check for modified files that are staged
+ git diff --cached --exit-code; if (-not $?) {throw "git diff of staged changes should be empty"}
+
+ # Check for untracked files
+ git add . # add all untracked files
+ git diff --cached --exit-code; if (-not $?) {throw "There should be no untracked files"}
+ displayName: 'Check clean repository (Windows)'
+ condition: eq( variables['Agent.OS'], 'Windows_NT' )
+ workingDirectory: ${{ parameters.directory }}
+
+# Linux based calls
+- bash: |
+ # Using git status as a way to check for a clean repo can produce
+ # misleading results when the line endings have been modified (XmlParse has
+ # a tendency to modify line endings). "git diff" seems to produce more
+ # reliable results, and the --exit-code is useful for detecting a change/no
+ # change summary.
+
+ # Check for modified files
+ git diff --exit-code || exit 1
+
+ # Checked for modified files that are staged
+ git diff --cached --exit-code || exit 1
+
+ # Check for untracked files
+ git add . # add all untracked files
+ git diff --cached --exit-code || exit 1
+ displayName: 'Check clean repository (Linux)'
+ condition: eq( variables['Agent.OS'], 'Linux' )
+ workingDirectory: ${{ parameters.directory }}
diff --git a/fpga/.ci/templates/fpga_build.yml b/fpga/.ci/templates/fpga_build.yml
new file mode 100644
index 000000000..dbc41b790
--- /dev/null
+++ b/fpga/.ci/templates/fpga_build.yml
@@ -0,0 +1,82 @@
+#
+# Copyright 2021 Ettus Research, a National Instruments Brand
+#
+# SPDX-License-Identifier: LGPL-3.0-or-later
+#
+# Description:
+#
+# This template should be used for all FPGA builds within the uhddev
+# repository. Exports the FPGA build results (bitfile, device tree and timing
+# report from build directory) as artifacts 'FPGA image <target>'.
+#
+# See description for the parameters below.
+#
+
+parameters:
+ ### Required parameters
+ # FPGA target to be built e.g. X410_XG
+ - name: target
+ type: string
+
+ ### Optional parameters
+ # Set to true if the intermediate files from build-<target> directory should
+ # be exported for debugging as artifact 'FPGA build <target> (<attempt>)'
+ - name: debug
+ type: boolean
+ default: false
+ # Checkout repository in a clean state as described in
+ # https://docs.microsoft.com/en-us/azure/devops/pipelines/yaml-schema?view=azure-devops&tabs=schema%2Cparameter-schema#checkout
+ - name: clean
+ type: boolean
+ default: true
+ # Default timeout of 4h
+ - name: timeout
+ type: number
+ default: 240
+
+jobs:
+- job: FPGA_${{ parameters.target }}
+ displayName: 'Build FPGA ${{ parameters.target }}'
+ pool:
+ name: de-dre-lab
+ demands:
+ - ettus_fpga_build
+ - vivado2019.1
+ timeoutInMinutes: ${{ parameters.timeout }}
+ steps:
+ # Currently limited to be executed in same repo.
+ # Removes all unversioned files if necessary.
+ # Checkout path defined by single repository case in
+ # https://docs.microsoft.com/en-us/azure/devops/pipelines/repos/multi-repo-checkout?view=azure-devops#checkout-path
+ - checkout: self
+ clean: ${{ parameters.clean }}
+
+ # Remove incomplete IP builds due to aborted previous runs.
+ - bash: |
+ python3 cleanup_incomplete_ip_builds.py -d fpga/usrp3/top/x400
+ workingDirectory: $(Agent.BuildDirectory)/s/fpga/.ci/scripts/
+ displayName: 'Incomplete IP Cleanup'
+
+ # Clean export directories and run FPGA build.
+ - bash: |
+ rm -rf build
+ rm -rf build-${{ parameters.target }}
+ source setupenv.sh
+ make ${{ parameters.target }}
+ workingDirectory: $(Agent.BuildDirectory)/s/fpga/usrp3/top/x400
+ displayName: 'Build Target'
+
+ # Publish the final result only if all previous steps passed
+ - publish: $(Agent.BuildDirectory)/s/fpga/usrp3/top/x400/build
+ artifact: 'FPGA image ${{ parameters.target }}'
+ displayName: 'Publish FPGA'
+
+ # Publish intermediate files.
+ - publish: $(Agent.BuildDirectory)/s/fpga/usrp3/top/x400/build-${{ parameters.target }}
+ artifact: 'FPGA build ${{ parameters.target }} ($(System.JobAttempt))'
+ condition: and(always(), eq('${{ parameters.debug }}', true))
+ displayName: 'Publish Build Directory'
+
+ # Check if FPGA build left any untracked files.
+ - ${{ if eq(parameters.debug, true) }}:
+ - template: check_clean_repo_steps.yml
diff --git a/fpga/.ci/templates/mb_cpld_build.yml b/fpga/.ci/templates/mb_cpld_build.yml
new file mode 100644
index 000000000..53aa0736f
--- /dev/null
+++ b/fpga/.ci/templates/mb_cpld_build.yml
@@ -0,0 +1,67 @@
+#
+# Copyright 2021 Ettus Research, a National Instruments Brand
+#
+# SPDX-License-Identifier: LGPL-3.0-or-later
+#
+# Description:
+#
+# This template is used to build the MB CPLD within the uhddev repository.
+# Exports the CPLD build results (from build directory) as artifacts 'MB CPLD
+# image'.
+#
+# See description for the parameters below.
+#
+
+parameters:
+ ### Optional parameters
+ # Set to true if the intermediate files from build-<target> directory should
+ # be exported for debugging as artifact 'MB CPLD build (<attempt>)'
+ - name: debug
+ type: boolean
+ default: false
+ # Checkout repository in a clean state as described in
+ # https://docs.microsoft.com/en-us/azure/devops/pipelines/yaml-schema?view=azure-devops&tabs=schema%2Cparameter-schema#checkout
+ - name: clean
+ type: boolean
+ default: true
+
+jobs:
+- job: MB_CPLD
+ displayName: 'Build MB CPLD'
+ pool:
+ name: de-dre-lab
+ demands:
+ - ettus_fpga_build
+ - quartus18.1_lite
+ timeoutInMinutes: 30
+ steps:
+ # Currently limited to be executed in same repo.
+ # Removes all unversioned files if necessary.
+ # Checkout path defined by single repository case in
+ # https://docs.microsoft.com/en-us/azure/devops/pipelines/repos/multi-repo-checkout?view=azure-devops#checkout-path
+ - checkout: self
+ clean: ${{ parameters.clean }}
+
+ # Run CPLD build
+ # Increase license server timeout as there might appear timeouts during
+ # static timing analysis which end up setting the build to fail.
+ - script: |
+ call set FLEXLM_TIMEOUT=20000000
+ call make
+ workingDirectory: $(Agent.BuildDirectory)/s/fpga/usrp3/top/x400/cpld
+ displayName: 'Build CPLD'
+
+ # Publish the final result only if all previous steps passed
+ - publish: $(Agent.BuildDirectory)/s/fpga/usrp3/top/x400/cpld/build
+ artifact: 'MB CPLD image'
+ displayName: 'Publish CPLD'
+
+ # always publish intermediate files
+ - publish: $(Agent.BuildDirectory)/s/fpga/usrp3/top/x400/cpld/output_files
+ artifact: 'MB CPLD build ($(System.JobAttempt))'
+ condition: and(always(), eq('${{ parameters.debug }}', true))
+ displayName: 'Publish Build Directory'
+
+ # Check if FPGA build left any untracked files.
+ - ${{ if eq(parameters.debug, true) }}:
+ - template: check_clean_repo_steps.yml
diff --git a/fpga/.ci/templates/regmap.yml b/fpga/.ci/templates/regmap.yml
new file mode 100644
index 000000000..b477ddc06
--- /dev/null
+++ b/fpga/.ci/templates/regmap.yml
@@ -0,0 +1,60 @@
+#
+# Copyright 2021 Ettus Research, a National Instruments Brand
+#
+# SPDX-License-Identifier: LGPL-3.0-or-later
+#
+# Description:
+#
+# This template is used to build the FPGA register map within the uhddev
+# repository. Exports the regmap as artifact 'Regmap'.
+#
+# See description for the parameters below.
+#
+
+parameters:
+ ### Optional parameters
+ # Set to true to check existence of temporary files after job completion
+ - name: debug
+ type: boolean
+ default: false
+ # Checkout repository in a clean state as described in
+ # https://docs.microsoft.com/en-us/azure/devops/pipelines/yaml-schema?view=azure-devops&tabs=schema%2Cparameter-schema#checkout
+ - name: clean
+ type: boolean
+ default: true
+
+jobs:
+- job: Regmap
+ displayName: 'Generate Register Map'
+ pool:
+ name: de-dre-lab
+ demands:
+ - hwSetup
+ timeoutInMinutes: 30
+ steps:
+ # Currently limited to be executed in same repo.
+ # Removes all unversioned files if necessary.
+ # Checkout path defined by single repository case in
+ # https://docs.microsoft.com/en-us/azure/devops/pipelines/repos/multi-repo-checkout?view=azure-devops#checkout-path
+ - checkout: self
+ clean: ${{ parameters.clean }}
+
+ - script: |
+ call hwSetup
+ call make regmap
+ workingDirectory: $(Agent.BuildDirectory)/s/fpga/nitools/x400/fpga
+ displayName: 'XmlParse'
+
+ # Publish the final result only if all previous steps passed
+ - publish: $(Agent.BuildDirectory)/s/fpga/usrp3/top/x400/doc
+ artifact: 'FPGA regmap'
+ displayName: 'Publish Regmap'
+
+ # Check if FPGA build left any untracked files.
+ - ${{ if eq(parameters.debug, true) }}:
+ # Generated regmap has issue with line endings.
+ # Staging the files resolves these changes and still report any
+ # modifications for the check below.
+ - script: git add -A
+ displayName: 'Stage all files'
+ - template: check_clean_repo_steps.yml
diff --git a/fpga/.ci/templates/zbx_cpld_build.yml b/fpga/.ci/templates/zbx_cpld_build.yml
new file mode 100644
index 000000000..b1fb598f2
--- /dev/null
+++ b/fpga/.ci/templates/zbx_cpld_build.yml
@@ -0,0 +1,67 @@
+#
+# Copyright 2021 Ettus Research, a National Instruments Brand
+#
+# SPDX-License-Identifier: LGPL-3.0-or-later
+#
+# Description:
+#
+# This template is used to build the ZBX daughterboard CPLD within the uhddev
+# repository. Exports the CPLD build results (from build directory) as
+# artifacts 'ZBX CPLD image'.
+#
+# See description for the parameters below.
+#
+
+parameters:
+ ### Optional parameters
+ # Set to true if the intermediate files from build-<target> directory should
+ # be exported for debugging as artifact 'ZBX CPLD build (<attempt>)'
+ - name: debug
+ type: boolean
+ default: false
+ # Checkout repository in a clean state as described in
+ # https://docs.microsoft.com/en-us/azure/devops/pipelines/yaml-schema?view=azure-devops&tabs=schema%2Cparameter-schema#checkout
+ - name: clean
+ type: boolean
+ default: true
+
+jobs:
+- job: ZBX_CPLD
+ displayName: 'Build ZBX CPLD'
+ pool:
+ name: de-dre-lab
+ demands:
+ - ettus_fpga_build
+ - quartus18.1_lite
+ timeoutInMinutes: 30
+ steps:
+ # Currently limited to be executed in same repo.
+ # Removes all unversioned files if necessary.
+ # Checkout path defined by single repository case in
+ # https://docs.microsoft.com/en-us/azure/devops/pipelines/repos/multi-repo-checkout?view=azure-devops#checkout-path
+ - checkout: self
+ clean: ${{ parameters.clean }}
+
+ # Run CPLD build
+ # Increase license server timeout as there might appear timeouts during
+ # static timing analysis which end up setting the build to fail.
+ - script: |
+ call set FLEXLM_TIMEOUT=20000000
+ call make
+ workingDirectory: $(Agent.BuildDirectory)/s/fpga/usrp3/top/x400/dboards/zbx/cpld
+ displayName: 'Build CPLD'
+
+ # Publish the final result only if all previous steps passed
+ - publish: $(Agent.BuildDirectory)/s/fpga/usrp3/top/x400/dboards/zbx/cpld/build
+ artifact: 'ZBX CPLD image'
+ displayName: 'Publish CPLD'
+
+ # Always publish intermediate files
+ - publish: $(Agent.BuildDirectory)/s/fpga/usrp3/top/x400/dboards/zbx/cpld/output_files
+ artifact: 'ZBX CPLD build ($(System.JobAttempt))'
+ condition: and(always(), eq('${{ parameters.debug }}', true))
+ displayName: 'Publish Build Directory'
+
+ # Check if FPGA build left any untracked files.
+ - ${{ if eq(parameters.debug, true) }}:
+ - template: check_clean_repo_steps.yml