Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Pre-release v3.0.5 #207

Merged
merged 63 commits into from
Nov 3, 2023
Merged
Show file tree
Hide file tree
Changes from 24 commits
Commits
Show all changes
63 commits
Select commit Hold shift + click to select a range
90a172b
remove redundant pytest from check_wifi, try new check_usb.sh based o…
GitJRS Jun 22, 2023
afe2f14
Merge pull request #197 from xmos/release/v3.0.4
shuchitak Jun 23, 2023
27de2fc
Use SOF timestamps for rate calculation
Sep 11, 2023
8fc36e4
Update copyright
Sep 18, 2023
6e32624
Changed variable name
Sep 19, 2023
881d26f
Merge pull request #202 from shuchitak/feature/use_sof_timestamps_for…
shuchitak Sep 19, 2023
2b9fa5b
fixes for xmosdoc v4
BrennanGit Sep 22, 2023
7b23dcf
move docs build to jenkins
BrennanGit Sep 22, 2023
db522c6
update xjsl for PR labels
BrennanGit Sep 22, 2023
83332aa
check if test fails when a nullptr is sent
Sep 28, 2023
e3cab13
Fix for num_bytes_sent=NULL in i2c_master_remote_write
Sep 28, 2023
7fefdee
Add test for NULL
Sep 28, 2023
3a3b9c3
fix test
Sep 28, 2023
662947e
added comments to the test
Sep 28, 2023
9a35ef0
Hardcoded sent to 1
Sep 28, 2023
6655c03
Merge pull request #204 from shuchitak/bugfix/i2c_master_null_ptr
shuchitak Sep 28, 2023
3373be1
doc_Builder -> xmosdoc
BrennanGit Oct 3, 2023
26e5bd3
Update doc README.rst
BrennanGit Oct 3, 2023
abf837a
set xmosdoc version to v4
BrennanGit Oct 10, 2023
cb9c336
Merge pull request #203 from BrennanGit/feature/doc_builder_v4
BrennanGit Oct 20, 2023
edd7dd6
Add dummy definitions
xluciano Oct 24, 2023
83dab9f
Fix typo
xluciano Oct 24, 2023
84cdc6c
Update setting file
xluciano Oct 24, 2023
9d735eb
Merge pull request #206 from lucianomartin/bugfix/warnings
xluciano Oct 25, 2023
635fdc3
Review comments
xluciano Oct 25, 2023
540ad02
add disclaimer to legal.rst
BrennanGit Oct 25, 2023
0a75668
only include dsiclaimer in html
BrennanGit Oct 25, 2023
279a1c9
missed a space
BrennanGit Oct 25, 2023
694b1e8
Merge pull request #208 from lucianomartin/feature/review
xluciano Oct 26, 2023
68fc428
Bump fwk_core and fwk_io in CI run
ed-xmos Oct 26, 2023
8c36762
Use tagged releases
ed-xmos Oct 26, 2023
d222040
Reword changelog about fetched modules
ed-xmos Oct 26, 2023
a858cbc
Merge pull request #210 from xmos/feature/update_fetch_deps_to_latest…
ed-xmos Oct 27, 2023
e7de602
Merge branch 'develop' into feature/missing_disclaimer
xluciano Oct 27, 2023
d45e20b
fix tracealyzer url
BrennanGit Oct 27, 2023
8bc813f
Merge pull request #209 from BrennanGit/feature/missing_disclaimer
xluciano Oct 27, 2023
2c58523
Added a runtime check for RPC being set up for I2S Slave case
Oct 31, 2023
dd78892
Changelog update
Oct 31, 2023
524d1fc
Merge pull request #211 from shuchitak/feature/i2s_slave_rpc_assert
shuchitak Oct 31, 2023
6e9e22f
Include xs1.h in rtos_swmem.c
xluciano Oct 31, 2023
1617355
Merge branch 'develop' into feature/include_xs1
xluciano Oct 31, 2023
a9ca97f
Update info for Windows users
xluciano Oct 31, 2023
faddc53
Merge from remote
xluciano Oct 31, 2023
239fb98
Fix syntax
xluciano Oct 31, 2023
2f451c5
Fix syntax
xluciano Oct 31, 2023
f7bd783
Fix syntax
xluciano Oct 31, 2023
5993932
Remove $
xluciano Oct 31, 2023
581ccc1
Update readme files
xluciano Nov 1, 2023
75e9b52
Merge pull request #213 from lucianomartin/feature/include_xs1
xluciano Nov 1, 2023
90750be
Address review comments
xluciano Nov 2, 2023
0095f79
Exclude more files
xluciano Nov 2, 2023
4e07363
Update doc info
xluciano Nov 2, 2023
093fa23
Remove double underscores
xluciano Nov 3, 2023
9561ee7
Fix text
xluciano Nov 3, 2023
4965d74
Update copyright notices
xluciano Nov 3, 2023
9a1d84a
Manual updates
xluciano Nov 3, 2023
0a21867
Merge pull request #215 from lucianomartin/bugfix/copyright-1
xluciano Nov 3, 2023
c801ce5
Merge branch 'develop' of github.com:xmos/fwk_rtos into feature/docs
xluciano Nov 3, 2023
bc1f350
Re-instate double underscore
xluciano Nov 3, 2023
96f1f6e
Last changes
xluciano Nov 3, 2023
0373456
Undo change
xluciano Nov 3, 2023
25c1ad2
Undo change
xluciano Nov 3, 2023
5fad254
Merge pull request #214 from lucianomartin/feature/docs
xluciano Nov 3, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
44 changes: 0 additions & 44 deletions .github/workflows/docs.yml

This file was deleted.

6 changes: 6 additions & 0 deletions CHANGELOG.rst
Original file line number Diff line number Diff line change
@@ -1,6 +1,12 @@
RTOS Framework change log
=========================

3.0.5
-----

* FIXED: Added dummy definitions of vTaskCoreAffinitySet() and vTaskCoreAffinitySet() functions to
avoid warnings when configNUM_CORES is set to 1.

3.0.4
-----

Expand Down
222 changes: 136 additions & 86 deletions Jenkinsfile
Original file line number Diff line number Diff line change
@@ -1,11 +1,9 @@
@Library('xmos_jenkins_shared_library@v0.20.0') _
@Library('xmos_jenkins_shared_library@v0.27.0') _

getApproval()

pipeline {
agent {
label 'xcore.ai-explorer-us'
}
agent none
options {
disableConcurrentBuilds()
skipDefaultCheckout()
Expand All @@ -32,99 +30,151 @@ pipeline {
LOCAL_WIFI_PASS = credentials('hampton-office-network-wifi-password')
}
stages {
stage('Checkout') {
steps {
checkout scm
sh 'git submodule update --init --recursive --depth 1 --jobs \$(nproc)'
}
}
stage('Build tests and host apps') {
steps {
script {
uid = sh(returnStdout: true, script: 'id -u').trim()
gid = sh(returnStdout: true, script: 'id -g').trim()
}
withTools(params.TOOLS_VERSION) {
sh "bash tools/ci/build_rtos_tests.sh"
sh "bash tools/ci/build_host_apps.sh"
}
// List built files for log
sh "ls -la dist/"
sh "ls -la dist_host/"
}
}
stage('Create virtual environment') {
steps {
// Create venv
sh "pyenv install -s $PYTHON_VERSION"
sh "~/.pyenv/versions/$PYTHON_VERSION/bin/python -m venv $VENV_DIRNAME"
// Install dependencies
withVenv() {
sh "pip install git+https://github0.xmos.com/xmos-int/xtagctl.git"
sh "pip install -r test/requirements.txt"
}
}
}
stage('Cleanup xtagctl') {
steps {
// Cleanup any xtagctl cruft from previous failed runs
withTools(params.TOOLS_VERSION) {
withVenv {
sh "xtagctl reset_all $RTOS_TEST_RIG_TARGET"
stage('Build and Docs') {
parallel {
stage('Build Docs') {
agent { label "docker" }
environment { XMOSDOC_VERSION = "v4.0" }
steps {
checkout scm
sh 'git submodule update --init --recursive --depth 1'
sh "docker pull ghcr.io/xmos/xmosdoc:$XMOSDOC_VERSION"
sh """docker run -u "\$(id -u):\$(id -g)" \
--rm \
-v ${WORKSPACE}:/build \
ghcr.io/xmos/xmosdoc:$XMOSDOC_VERSION -v"""
archiveArtifacts artifacts: "doc/_build/**", allowEmptyArchive: true
}
}
sh "rm -f ~/.xtag/status.lock ~/.xtag/acquired"
}
}
stage('Run RTOS Drivers HIL test') {
steps {
withTools(params.TOOLS_VERSION) {
withVenv {
script {
withXTAG(["$RTOS_TEST_RIG_TARGET"]) { adapterIDs ->
sh "test/rtos_drivers/hil/check_drivers_hil.sh " + adapterIDs[0]
}
sh "pytest test/rtos_drivers/hil"
post {
cleanup {
xcoreCleanSandbox()
}
}
}
}
}
stage('Run RTOS Drivers HIL_Add test') {
steps {
withTools(params.TOOLS_VERSION) {
withVenv {
script {
withXTAG(["$RTOS_TEST_RIG_TARGET"]) { adapterIDs ->
sh "test/rtos_drivers/hil_add/check_drivers_hil_add.sh " + adapterIDs[0]

stage('Build and Test') {
when {
expression { !env.GH_LABEL_DOC_ONLY.toBoolean() }
}
agent {
label 'xcore.ai-explorer-us'
}
stages {
stage('Checkout') {
steps {
checkout scm
sh 'git submodule update --init --recursive --depth 1 --jobs \$(nproc)'
}
sh "pytest test/rtos_drivers/hil_add"
}
}
}
}
}
stage('Run RTOS Drivers WiFi test') {
steps {
withTools(params.TOOLS_VERSION) {
withVenv {
script {
withXTAG(["$RTOS_TEST_RIG_TARGET"]) { adapterIDs ->
sh "test/rtos_drivers/wifi/check_wifi.sh " + adapterIDs[0]
stage('Build tests and host apps') {
steps {
script {
uid = sh(returnStdout: true, script: 'id -u').trim()
gid = sh(returnStdout: true, script: 'id -g').trim()
}
// pull docker
sh "docker pull ghcr.io/xmos/xcore_voice_tester:develop"
withTools(params.TOOLS_VERSION) {
sh "bash tools/ci/build_rtos_tests.sh"
sh "bash tools/ci/build_host_apps.sh"
}
// List built files for log
sh "ls -la dist/"
sh "ls -la dist_host/"
}
}
stage('Create virtual environment') {
steps {
// Create venv
sh "pyenv install -s $PYTHON_VERSION"
sh "~/.pyenv/versions/$PYTHON_VERSION/bin/python -m venv $VENV_DIRNAME"
// Install dependencies
withVenv() {
sh "pip install git+https://github0.xmos.com/xmos-int/xtagctl.git"
sh "pip install -r test/requirements.txt"
}
}
}
stage('Cleanup xtagctl') {
steps {
// Cleanup any xtagctl cruft from previous failed runs
withTools(params.TOOLS_VERSION) {
withVenv {
sh "xtagctl reset_all $RTOS_TEST_RIG_TARGET"
}
}
sh "rm -f ~/.xtag/status.lock ~/.xtag/acquired"
}
}
stage('Run RTOS Drivers WiFi test') {
steps {
withTools(params.TOOLS_VERSION) {
withVenv {
script {
withXTAG(["$RTOS_TEST_RIG_TARGET"]) { adapterIDs ->
sh "test/rtos_drivers/wifi/check_wifi.sh " + adapterIDs[0]
}
sh "pytest test/rtos_drivers/wifi"
}
}
}
}
}
stage('Run RTOS Drivers HIL test') {
steps {
withTools(params.TOOLS_VERSION) {
withVenv {
script {
withXTAG(["$RTOS_TEST_RIG_TARGET"]) { adapterIDs ->
sh "test/rtos_drivers/hil/check_drivers_hil.sh " + adapterIDs[0]
}
sh "pytest test/rtos_drivers/hil"
}
}
}
}
}
stage('Run RTOS Drivers HIL_Add test') {
steps {
withTools(params.TOOLS_VERSION) {
withVenv {
script {
withXTAG(["$RTOS_TEST_RIG_TARGET"]) { adapterIDs ->
sh "test/rtos_drivers/hil_add/check_drivers_hil_add.sh " + adapterIDs[0]
}
sh "pytest test/rtos_drivers/hil_add"
}
}
}
}
}
stage('Run RTOS Drivers USB test') {
steps {
withTools(params.TOOLS_VERSION) {
withVenv {
script {
uid = sh(returnStdout: true, script: 'id -u').trim()
gid = sh(returnStdout: true, script: 'id -g').trim()
withXTAG(["$RTOS_TEST_RIG_TARGET"]) { adapterIDs ->
sh "docker run --rm -u $uid:$gid --privileged -v /dev:/dev -w /fwk_rtos -v $WORKSPACE:/fwk_rtos ghcr.io/xmos/xcore_voice_tester:develop bash -l test/rtos_drivers/usb/check_usb.sh " + adapterIDs[0]
}
sh "pytest test/rtos_drivers/usb"
}
}
}
}
sh "pytest test/rtos_drivers/wifi"
}
}
post {
cleanup {
// cleanWs removes all output and artifacts of the Jenkins pipeline
// Comment out this post section to leave the workspace which can be useful for running items on the Jenkins agent.
// However, beware that this pipeline will not run if the workspace is not manually cleaned.
xcoreCleanSandbox()
}
}
}
}
}
}
post {
cleanup {
// cleanWs removes all output and artifacts of the Jenkins pipeline
// Comment out this post section to leave the workspace which can be useful for running items on the Jenkins agent.
// However, beware that this pipeline will not run if the workspace is not manually cleaned.
cleanWs()
}
}
}
50 changes: 42 additions & 8 deletions doc/README.rst
mbanth marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,9 @@
Documentation Source
####################

xluciano marked this conversation as resolved.
Show resolved Hide resolved
This folder contains source files for the documentation. The sources do not render well in GitHub or an RST viewer.
In addition, some information is not visible at all and some links will not be functional.

**********************
Building Documentation
**********************
Expand All @@ -10,13 +13,7 @@ Building Documentation
Prerequisites
=============

Install `Docker <https://www.docker.com/>`_.

Pull the docker container:

.. code-block:: console

$ docker pull ghcr.io/xmos/doc_builder:latest
Use the `xmosdoc tool <https://github.com/xmos/xmosdoc>`_ either via docker or install it into a pip environment.

========
Building
Expand All @@ -26,4 +23,41 @@ To build the documentation, run the following command in the root of the reposit

.. code-block:: console

$ docker run --rm -t -u "$(id -u):$(id -g)" -v $(pwd):/build -e PDF=1 -e REPO:/build -e DOXYGEN_INCLUDE=/build/doc/Doxyfile.inc -e EXCLUDE_PATTERNS=/build/doc/exclude_patterns.inc -e DOXYGEN_INPUT=ignore ghcr.io/xmos/doc_builder:latest
# via pip package
xmosdoc clean html latex
# via docker
$ docker run --rm -t -u "$(id -u):$(id -g)" -v $(pwd):/build ghcr.io/xmos/xmosdoc clean html latex

HTML document output is saved in the ``doc/_build/html`` folder. Open ``index.html`` to preview the saved documentation.

Please refer to the ``xmosdoc`` documentation for a complete guide on how to use the tool.

**********************
Adding a New Component
**********************

Follow the following steps to add a new component.

- Add an entry for the new component's top-level document to the appropriate TOC in the documents tree.
- If the new component uses `Doxygen`, append the appropriate path(s) to the INPUT variable in `Doxyfile.inc`.
- If the new component includes `.rst` files that should **not** be part of the documentation build, append the appropriate pattern(s) to `exclude_patterns.inc`.

***
FAQ
***

Q: Is it possible to build just a subset of the documentation?

A: Yes, however it is not recommended at this time.

Q: Is it possible to used the ``livehtml`` feature of Sphinx?

A: Yes, run xmosdoc with the ``--auto`` option.

Q: Where can I learn more about the XMOS ``xmosdoc`` tools?

A: See the https://github.com/xmos/xmosdoc repository. See the ``xmosdoc`` repository README for details on additional build options.

Q: How do I suggest enhancements to the XMOS ``xmosdoc`` tool?

A: Create a new issue here: https://github.com/xmos/xmosdoc/issues
1 change: 0 additions & 1 deletion doc/build_system_guide/introduction.rst
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
.. include:: ../substitutions.rst

.. _build_system_guide:

Expand Down
1 change: 0 additions & 1 deletion doc/build_system_guide/targets.rst
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
.. include:: ../substitutions.rst

.. _build_system_targets:

Expand Down
5 changes: 4 additions & 1 deletion doc/exclude_patterns.inc
Original file line number Diff line number Diff line change
@@ -1,10 +1,13 @@
# The following patterns are to be excluded from the documentation build
documents/README.rst
tools
projects
test
xmos_cmake_toolchain
modules/drivers
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

How come this has been excluded?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I reckon it was to avoid building the documents inside that repo. Do you think we should include that folder?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It is an important part of the package. So yes.

modules/FreeRTOS
modules/sw_services
build
build_*
CHANGELOG.rst
LICENSE.rst
**README*
Loading