About Bridle

Bridle demonstrate the integration of TiaC Systems support in open source projects, like the Zephyr Project, with libraries and source code for applications. It is a combination of software developed by TiaC Systems and open source projects, hosted as Git repositories in the DevZone or the Zephyr GitHub organization.

Every Bridle release consists of a combination of all those repositories at different revisions. See the Repositories and revisions section for a comprehensive list of repositories and their current revisions. The revision of each of those repositories is determined by the current revision of the main (manifest) repository, tiac-bridle, which contains the Bridle manifest file that helps manage the repositories as one code base with the West Tool.

About the Bridle license

Licenses are located close to the source files. You can find a LICENSE file, containing the details of the license, at the top of every Bridle repository. Each file included in the repositories also has an SPDX identifier that mentions this license.

If a folder or set of files is open source and included in Bridle under its own license (for example, any of the Apache or MIT licenses), it will have either its own LICENSE file included in the folder or the license information embedded inside the source files themselves.

The SPDX tool is used to generate license reports on each release of the Bridle. You can also use SPDX to generate license reports for your projects that are specific to the code included in your application.

Documentation pages

The documentation consists of several inter-linked documentation sets, one for each repository. You can switch between these documentation sets by using the selector in the bottom-left corner of each page.

The entry point is the Bridle documentation that you are currently reading. The local Zephyr Project Documentation is a slightly extended version of the official Zephyr Project documentation, containing some additions specific to TiaC Systems.

Bridle documentation set selector

Bridle documentation set selector

The Bridle documentation contains all information that is specific to the Bridle and describes our libraries, samples, and applications. The API documentation is extracted from the source code and included with the library documentation.

For instructions about building the documentation locally, see Building Bridle documentation. For more information about the documentation conventions and templates, see About this documentation.

Tools and configuration

The figure below visualizes the tools and configuration methods in the Bridle. They are based on the Zephyr Project. All of them have a role in the creation of an application, from configuring the libraries or applications to building them.

Bridle tools and configuration

Bridle tools and configuration methods

Git Tool

Git is a free and open source distributed version control system that allows managing the changes in the code or other collections of information (set of files) over time.

Git organizes data (files or directories) in project repositories. The data is managed like a series of snapshots. Every time you commit, or save the state of your project, Git takes a snapshot of what the files look like at that exact moment and stores a reference to that snapshot. For unchanged files, Git provides just a link to the previous identical file it has already stored.

Git offers a lot of flexibility in how users manage changes, and repositories are easily duplicated. In Bridle, forking is the agreed-upon Git workflow. To contribute, the official public repository in GitHub is forked.

When you say you are forking a repository, you are creating a copy of the repository under your GitHub ID. This means that you are creating an identical copy that might diverge from the original over time. This copy is your personal public repository that nobody else is allowed to push to, but changes can be pulled from it.

The original repository is called the upstream repository, and the newly created copy the downstream repository. Any changes made to the original repository are reflected back to your forked repositories by using fetch and rebase commands.

A git clone command is used to get a copy of your downstream repository onto your local machine. This serves as a private development environment.

Local commits are pushed to your own downstream repository, and not the official one. To integrate the changes into the main upstream repository, a pull request is created explicitly. Before it is merged, the pull request also serves as a convenient discussion thread if there are issues with the contributed code. If your pull request is approved, the changes are merged with the existing original content. Until then, your changes are reflected only in the copy you forked.

A fork can be hosted on any server, including a public Git hosting site like GitHub. It is, however, important to differentiate between the generic concept of a fork and GitHub’s concept of a GitHub fork. When you create a GitHub fork, GitHub copies the original repository and tags the downstream repository (the fork) with a flag that allows users to send pull requests from the fork to its upstream repository. GitHub also supports creating forks without linking them to the upstream respository. See the GitHub documentation for information about how to do this.

Everything in Git is checksummed before it is stored and is then referred to by that checksum. The mechanism that Git uses for this checksumming is called a SHA-1 hash. This hash is a 40-character string, composed of hexadecimal characters (0–9 and a–f), and calculated based on the contents of a file or directory structure in Git.

West Tool

The Zephyr project includes a tool called west. The Bridle uses west to manage the combination of multiple Git repositories and versions.

Some of west’s features are similar to those provided by Git Submodules and Google’s Repo tool. But west also includes custom features required by the Zephyr Project that were not sufficiently supported by the existing tools. For more details about the reasons behind the introduction of west, see the History and Motivation section of the Zephyr documentation.

West’s workspace contains exactly one manifest repository, which is a main Git repository containing a west manifest file. Additional Git repositories in the workspace managed by west are called projects. The manifest repository controls which commits to use from the different projects through the manifest file. In the Bridle, the main repository tiac-bridle contains a west manifest file west.yml, that determines the revision of all other repositories and that is complete different from Zephyr’s west manifest file west.yml. This means that tiac-bridle acts as the manifest repository, while the other repositories are projects, like Zephyr in the case of Bridle. When developing in the Bridle, your application will use libraries and features from folders that are cloned from different repositories or projects. The west tool keeps control of which commits to use from the different projects. It also makes it fairly simple to add and remove modules.

Some west commands are related to Git commands with the same name, but operate on the entire west workspace. Some west commands take projects as arguments. The two most important workspace-related commands in west are west init and west update. The west init command creates a west workspace, and you typically need to run it only once to initialize west with the revision of the Bridle that you want to check out. It clones the manifest repository into the workspace. However, the content of the manifest repository is managed using Git commands, since west does not modify or update it. To clone the project repositories, use the west update command. This command makes sure your workspace contains Git repositories matching the projects defined in the manifest file. Whenever you check out a different revision in your manifest repository, you should run west update to make sure your workspace contains the project repositories the new revision expects (according to the manifest file).

For more information about west init, west update, and other built-in commands, see Built-in commands. For more information about the west tool, see the West (Zephyr’s meta-tool) user guide.

See Getting started for information about how to install Bridle and about the first steps. See Development model for more information about the Bridle code base and how to manage it.

Repositories and revisions

The following table lists all the repositories (and their respective revisions) that are included as part of Bridle v4.0.99 release:

Project

Revision

zephyr

tiacsys/main

ubxlib

62c0021cbf079b43cdd9a219e9b10b49ea616e19

canopennode

dec12fa3f0d790cafa8414a4c2930ea71ab72ffd

chre

3b32c76efee705af146124fb4190f71be5a4e36e

psa-arch-tests

2cadb02a72eacda7042505dcbdd492371e8ce024

tf-m-tests

502ea90105ee18f20c78f710e2ba2ded0fc0756e

acpica

8d24867bc9c9d81c81eeac59391cda59333affd4

cmsis

4b96cbb174678dcd3ca86e11e1f24bc5f8726da0

edtt

b9ca3c7030518f07b7937dacf970d37a47865a76

fatfs

427159bf95ea49b7680facffaa29ad506b42709b

hal_adi

b1a10239e1001502c3089e0cf938e938f99b1f30

hal_altera

4fe4df959d4593ce66e676aeba0b57f546dba0fe

hal_ambiq

87a188b91aca22ce3ce7deb4a1cbf7780d784673

hal_atmel

56d60ebc909ad065bf6554cee73487969857614b

hal_espressif

e52371024732a47a67fa9c889fbccd0aa6355f3a

hal_ethos_u

8e2cf756b474eff9a32a9bdf1775d9620f1eadcf

hal_gigadevice

2994b7dde8b0b0fa9b9c0ccb13474b6a486cddc3

hal_infineon

a9b75e0d1827b6ef1f8ca82784b38ed2079bac5a

hal_intel

0355bb816263c54eed23c7781034447af5d8200c

hal_microchip

71eba057c0cb7fc11b6f33eb40a82f1ebe2c571c

hal_nordic

fae15426c6b5a1f67362d508cf51b691ae5ab4b4

hal_nuvoton

466c3eed9c98453fb23953bf0e0427fea01924be

hal_nxp

0ac830233092247c26f5dd01a07b0a484532ea4c

hal_openisa

eabd530a64d71de91d907bad257cd61aacf607bc

hal_quicklogic

bad894440fe72c814864798c8e3a76d13edffb6c

hal_renesas

3a8466b2ceca87d05280a071b9b9aabda1915235

hal_rpi_pico

79ee0f9e058a6327fc943d2f2a19cf3ade107cec

hal_silabs

6371fa823663b11090b0b30561a8b9196d4ef981

hal_st

b2f548fe672f24122c7f92027b2c9eeea8a0483a

hal_stm32

37842371f5ef0078ad32f16e5059c1df58b51892

hal_tdk

e0ade95b29841d915c38bc157bb5509270e8aa21

hal_telink

4226c7fc17d5a34e557d026d428fc766191a0800

hal_ti

2e7b95ad079e9f636884eedc6853e6ad98b85f65

hal_wurthelektronik

e3e2797b224fc48fdef1bc3e5a12a7c73108bba2

hal_xtensa

baa56aa3e119b5aae43d16f9b2d2c8112e052871

liblc3

bb85f7dde4195bfc0fca9e9c7c2eed0f8694203c

libmetal

3e8781aae9d7285203118c05bc01d4eb0ca565a7

littlefs

009bcff0ed4853a53df8256039fa815bda6854dd

loramac-node

fb00b383072518c918e2258b0916c996f2d4eebe

lvgl

2b498e6f36d6b82ae1da12c8b7742e318624ecf5

mbedtls

4952e1328529ee549d412b498ea71c54f30aa3b1

mcuboot

a2bc982b3379d51fefda3e17a6a067342dce1a8b

mipi-sys-t

71ace1f5caa03e56c8740a09863e685efb4b2360

net-tools

93acc8bac4661e74e695eb1aea94c7c5262db2e2

open-amp

52bb1783521c62c019451cee9b05b8eda9d7425f

openthread

2aeb8b833ba760ec29d5f340dd1ce7bcb61c5d56

picolibc

82d62ed1ac55b4e34a12d0390aced2dc9af13fc9

segger

cf56b1d9c80f81a26e2ac5727c9cf177116a4692

tinycrypt

1012a3ebee18c15ede5efc8332ee2fc37817670f

trusted-firmware-a

713ffbf96c5bcbdeab757423f10f73eb304eff07

trusted-firmware-m

fa020a8b001843bb5a115bc4692eaf6787e3d1de