Zephyr Lab Installation and Preparation - nxp-mcuxpresso/vscode-for-mcux GitHub Wiki

Objectives

In this lab, you will learn to install/import the tools below. This guide is written for Windows10. But Linux or macOS can also be used following similar steps.

  • Visual Studio Code
  • MCUXpresso Extension for VS Code
  • Dependencies for Zephyr development, including the Zephyr SDK
  • Zephyr Repository in VS Code
  • MCUXpresso SDK Repository in VS Code

Zephyr Revision

Before importing the Zephyr repository, determine the Zephyr revision to checkout. Upstream Zephyr manages the revisions with Git: Zephyr releases have Git tags for the versions, or the latest code is in the main branch.

For development, it is ideal to use a Zephyr release. Releases go through the Zephyr Project's release flow and quality checks. This is why the Repository Importer in the MCUXpresso extension defaults to the latest Zephyr release. To learn more about Zephyr releases, see Releases. However, as boards and features are added after a release, it may be necessary to use the latest code in the main branch. For example, NXP's FRDM-MCXN947 board was upstreamed after Zephyr's v3.6.0 release. Until v3.7.0 was released in July 2024, the main branch was imported if using this board.

One resource available to confirm support in different revisions is the Zephyr Project documentation. For example, this latest URL is a living document for the Supported Boards currently in the main branch, and is updated frequently. Clicking a board link will detail the latest features supported on that board. But this v3.6.0 URL is the same page, but frozen for the v3.6.0 release. Clicking a board link there will show the board documentation and supported features in the v3.6.0 release. The upstream repo also has release notes for each release. Here are the v3.6.0 Release Notes.

Installation Lab

1. Install VS Code and the MCUXpresso extension

  1. To install Visual Studio Code (VS Code), download the installer here: https://code.visualstudio.com/download

  1. Open VS Code, and install the MCUXpresso extension.

    Click the Extensions view (Ctrl+Shift+X) in VS Code. Click the search field at the top of the Extensions view, and enter mcuxpresso.

    Click the Install button to install the extension.

    Install Extension

    The MCUXpresso extension will be added to the Installed list after successful installation.


2. Install the Zephyr dependencies and debugger tools

  1. Open the MCUXpresso Extension. In the Quickstart Panel, click Open MCUXpresso Installer.

Open MCUXpresso Installer

  1. The Zephyr Developer option is required to support CMake, Python, the Zephyr SDK (includes the GCC build tools) and other Zephyr dependencies. LinkServer is also required to debug with the NXP on-board probes.

Note this lab guide assumes a LinkServer debug probe is used, which is default on the evaluation boards. When using other supported debug probes, this Installer can also install Segger JLink and PEmicro tools.

After selecting the install options, click the Install button. The status bar at the bottom displays the status of the installation.

Installer for Zephyr

  1. Restart VS Code to enable the changes to enviornment variables.

3. Import the software repositories

  1. To import the Zephyr repository, open the MCUXpresso view in VS Code and click Import Repository in the Quickstart Panel.

    Import Repository


Note The next two steps show options for importing different revisions of the Zephyr repo. The first option imports a Zephyr release tag. The second option imports the main branch for the latest code in the repo. For more details, see Zephyr Revision.


7a. Import Zephyr Release: Select the folder location C:\Users\...\zephyrproject and Zephyr Repository. For revision, the Importer defaults to the latest Zephyr release, shown here as v3.6.0. If desired, change to a different release. When finished, click Import. Import Zephyr release

7b. Import Zephyr main branch: Select the folder location C:\Users\...\zephyrproject and Zephyr Repository. Change the revision to main. When finished, click Import. Import Zephyr main branch

> **Note** This import step takes a long time to clone the Zephyr repo, and dependency repos (currently 55!).  VS Code shows a progress bar pop-up with the status of the West tool as it clones all the repos. The repository should be added to the Installed Repository view once the import is successful.

  1. Optionally, the MCUXpresso SDK repository can be imported the same way. This is not required when working with Zephyr. But the debugger guide in Training Zephyr Getting Started shows how to add the Peripheral Register view to the debugger, and this requires some SVD files located in the MCUXpresso SDK repository. To add this repo, select the folder location:

    C:\Users\...\mcux-sdk

    Import MCUX Repository


The repositories are successfully added to the Installed Repository view once the import is successful.

Installed Repositories

  1. To import any example application from the Zephyr Repository, click Import example from Repository in the Quickstart Panel. The Zephyr SDK installed is selected automatically as the default SDK (if no other SDK version is located in the same path).

    Import Zephyr Example

  2. To ensure successfull installation, follow the steps in the Hello World guide to run the hello_world example from the Zephyr repo.

4. (Optional) Install Embedded Tools extension

When debugging Zephyr applications, thread awareness can be enabled, and can be viewed in the debugger with the Embedded Tools extension. The debug lab guides in Training Zephyr Getting Started detail how to use thread awareness. To install this additional extension:

  1. Click the Extensions view, type embedded tools in the search field, and then click the Install button for the Microsoft Embedded Tools extension.

    Embedded Tools extension


Lab completed. Return to the Zephyr Labs Overview Training Zephyr Getting Started

⚠️ **GitHub.com Fallback** ⚠️