Skip to content

Open-CMSIS-Pack/BSP-Pack-HandsOn

Repository files navigation

Create a Board Support Pack - Hands-On Example

This repository explains the steps to create a board support pack using the Open-CMSIS-Pack technology.

The pack contains a development board from the imaginary "ACME Corp.". It contains:

  • Source code, libraries, header/configuration files for the underlying hardware and documentation (user manuals, getting started guides, and schematics).
  • A CMSIS-Driver VIO for on-baord LEDs
  • Flash programming algorithm for external board memory
Content Description
gen_pack.sh Script that builds the pack; refer to usage information for configuration details.
.github/workflows/pack.yaml GitHub workflow that generates the pack on every commit.

Benefits of Software Pack Delivery

The CMSIS-Pack technology is available in multiple toolchains. Below is a brief history:

  • 2008: CMSIS-Core has been introduced and CMSIS has been since then continuously extended.
  • 2012: CMSIS-Pack has been started to simplify Product Lifecycle Management (PLM) of Keil MDK and improve overall user experience.
  • 2014: CMSIS-Pack is part of Keil MDK for device support, middleware which resulted in higher adoption and lower support.
  • 2017: Eclipse version of the CMSIS-Pack system is integrated in Arm DS and IAR toolchains. Sharing packs across toolchains is now possible.
  • 2020: Discussions with ST and NXP resulted in the Open-CMSIS-Pack project and the VS Code integration.

Benefits for a Board Vendor

  • Connection to users: as board vendor you control distribution to multiple tools and web portals. For the Arm pack system new releases are scanned once per day, making it available to the entire user base. Documentation links in the software pack let you connect with your users.

  • One way to distribute: for all relevant toolchains as CMSIS supports Arm Compiler, GCC, and IAR. Software scales to many devices when APIs are applied (as in this example CMSIS-Driver).

  • Reduces support efforts: as it is easier for customer to use a board in projects. Product Lifecycle Management simplifies updates and notifies users about outdated configuration files and deprecation of products.

To learn more review the session about Generating CMSIS-Packs for Boards.

Pack Development

The following section explains how to create a pack.

Tool-Environment (Recommended)

Steps to Create a Board Support Pack

  • Gather technical details
    • Gather all technical details of your development board that need to be listed.
    • Create Flash programming algorithms for external memories (if applicable).
  • Organize and create the file list that will be delivered as Pack
  • Create the PDSC file using your favorite editor (we recommend VS Code with XML extension).
  • Validate the software pack using the packchk tool.
  • Create the software pack using the gen_pack library.

A board support example is explained in this meeting recording starting at xx:xx.

Local Pack Development

  1. Clone this repository (as it serves as a getting started example)

  2. Register this pack with cpackget via PDSC file using this commands:

    cpackget update-index                // optional to ensure that pack index is up-to-date
    cpackget add ACME.ACMECM4_BSP.pdsc   // pack now appears in toolchains, i.e. in MDK
    csolution list packs
  3. The content of the pack can now be seen in the Manage Component dialog of uVision.

For changing the PDSC file it is recommended to use VS Code with XML extension, but any editor would work.

After modifications to the PDSC file run packchk; include all packs that are required by your software in the validation:

Using Command Prompt:

packchk ACME.ACMECM4_BSP.pdsc -i %CMSIS_PACK_ROOT%/ARM/CMSIS/5.9.0/ARM.CMSIS.pdsc

Using Git Bash console:

packchk ACME.ACMECM4_BSP.pdsc -i $CMSIS_PACK_ROOT/ARM/CMSIS/5.9.0/ARM.CMSIS.pdsc

With CMSIS-Toolbox v1.7.0 the XML schema check is available with packchk, the command may be then extended to:

packchk ACME.ACMECM4_BSP.pdsc -i $CMSIS_PACK_ROOT/ARM/CMSIS/5.9.0/ARM.CMSIS.pdsc -s /c/Keil_v5/UV4/PACK.xsd

The pack can be created locally in the directory output using Git Bash:

./gen_pack.sh -v

Verify Pack in Tools

To verify the tools such as the VS Code - Keil Studio Desktop extension, install the pack with:

cpackget add ./output/ACME.ACMECM4_BSP.1.0.0.pack

Notes:

  • VS Code - Keil Studio Desktop does not yet support pack installation from local repositories.
  • To continue local pack development, change add a new <release> version. During development semantic version labels to indicate a pre-release may be used as shown below:
  <releases>
    <release version="1.0.1-rc0">
      Further development
    </release>
    <release version="1.0.0" date="2023-04-22">
      Initial version
    </release>
  </releases>

Pack Creation on GitHub

Once changes are committed the GitHub Action creates the pack.

Publish Pack

The pack can be hosted on the <url> specified in the *.pdsc file.

Refer to Publish a Pack in the Open-CMSIS-Pack specification for further details.

Issues and Questions

Use Issues on this GitHub to raise questions or submit problems.

Happy Packing!

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •