forked from nrfconnect/sdk-nrf
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Added a new section to the Application Development that covers development with custom boards. The section includes a new page about how to connect custom board hardware for programming. NCSDK-28526. Signed-off-by: Grzegorz Ferenc <[email protected]>
- Loading branch information
Showing
9 changed files
with
160 additions
and
4 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
.. _ug_custom_board: | ||
|
||
Developing with custom boards | ||
############################# | ||
|
||
.. |nrf_series| replace:: custom boards | ||
|
||
.. include:: /includes/guides_complementary_to_app_dev.txt | ||
|
||
Custom boards are hardware designs that are not directly provided or supported by Nordic Semiconductor. | ||
These are typically third-party boards that use Nordic Semiconductor Systems on Chip (SoCs) for custom project needs. | ||
|
||
The following sections provide information on how to work with custom boards in the |NCS|. | ||
|
||
.. toctree:: | ||
:maxdepth: 2 | ||
:caption: Subpages: | ||
|
||
defining_custom_board | ||
programming_custom_board |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,47 @@ | ||
To program a custom board using Nordic Semiconductor chips, you'll need to follow these general steps: | ||
|
||
1. Create a custom board definition in the nRF Connect SDK. This involves creating the necessary board files and configurations. | ||
|
||
2. Set up the hardware connections for programming. You'll need to connect the custom board to a debug probe that supports SWD (Serial Wire Debug) interface. | ||
|
||
3. Use the nRF Connect Programmer app or other compatible programming tools to flash your application to the custom board. | ||
|
||
Here's a more detailed breakdown: | ||
|
||
1. Creating a custom board definition: | ||
- Create a new directory for your custom board files | ||
- Define the board in the necessary files (devicetree, Kconfig, etc.) | ||
- Point the build system to your custom board root directory | ||
|
||
You can find detailed instructions on creating custom board files in the [nRF Connect SDK Intermediate course](https://academy.nordicsemi.com/courses/nrf-connect-sdk-intermediate/lessons/lesson-3-adding-custom-board-support/). | ||
|
||
2. Hardware connections: | ||
Connect your custom board to a debug probe (like a Development Kit or a dedicated debug adapter) using the SWD interface. The typical connections needed are: | ||
- SWDCLK | ||
- SWDIO | ||
- GND | ||
- VDD (optional, for powering the board) | ||
- RESET (optional) | ||
|
||
Programming and debugging the nRF5x on our Developments kits is straight forward. Doing the same when you are using other boards might not be so easy. In this blog post we will explain which components are needed in order to program and debug a nRF5x chip. | ||
|
||
The nRF chip is connected to a Debug unit through an interface called "Serial Wire Debug", or "SWD" for short. The debug unit acts as a bridge between the chip and your PC. It communicates with the programming and debugging software on your PC through a “Debug interface”. Your PC must have a driver for the debug unit and debug interface you are using. The driver allows your PC to recognize the debug unit, and allows communication between them over USB. | ||
|
||
When developing applications on a nRF5x Development Kit, you can program it by simply connecting it to your PC with a USB cable. This is possible because the Development Kit has an on-board debug unit supporting the JLINK debug interface. | ||
|
||
Since the on-board debug unit is able to program and debug the on-board chip, it is also able to program any other nRF5x chip. The Development Kit has headers where you can access the Serial Wire Debug pins. The video below describes how connect these headers to a custom board. You can also see section 5.1 of the nRF51 User Guide for more information about the debug out headers. | ||
|
||
If you do not have a nRF5x Development Kit, you can always use a dedicated debug adapter. There exist several manufacturers and debug interfaces. With the nRF5x series, it is common to use JLINK debug adapters from Segger. You can also use debug units using other debug interfaces like the CMSIS-DAP interface, as long as you have the proper drivers and software on your PC. If you are having any problems, stop by our Developer Zone forum or support portal, where my colleagues and I will do our best to help you out. | ||
|
||
3. Programming: | ||
Use the nRF Connect Programmer app to flash your application. The general steps are: | ||
- Open nRF Connect for Desktop and launch the Programmer app | ||
- Connect your board and select it from the device list | ||
- Add your application's HEX file | ||
- Click "Write" to program the board | ||
|
||
Detailed instructions can be found in the [Programming devices documentation](https://docs.nordicsemi.com/bundle/nrf-connect-programmer/page/programming_dk.html#programming-devices). | ||
|
||
Remember to ensure that your custom board is properly powered and that all connections are secure before attempting to program it. | ||
|
||
If you encounter any issues during programming, try restarting the Programmer app (Ctrl+R or Command+R on macOS) and attempt the programming process again. |
75 changes: 75 additions & 0 deletions
75
doc/nrf/app_dev/device_guides/custom/programming_custom_board.rst
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,75 @@ | ||
.. _programming_custom_board: | ||
|
||
Connecting custom boards for programming | ||
######################################## | ||
|
||
.. contents:: | ||
:local: | ||
:depth: 2 | ||
|
||
After you :ref:`created custom board files <defining_custom_board>`, you need to connect your custom board to a debug probe for programming. | ||
|
||
Hardware requirements | ||
********************* | ||
|
||
To connect a custom board for programming, you need the following hardware: | ||
|
||
* A debug probe supporting Serial Wire Debug (SWD), such as: | ||
|
||
* A Development Kit (DK) from Nordic Semiconductor (all include an onboard debug probe) | ||
* Dedicated debug adapter (like SEGGER J-Link) | ||
|
||
* Connecting wires | ||
* USB cable | ||
|
||
Required connections | ||
******************** | ||
|
||
You will have to connect the following pins between your custom board and the debug probe: | ||
|
||
* Essential connections: | ||
|
||
* SWDCLK (Clock) | ||
* SWDIO (Data) | ||
* GND (Ground) | ||
|
||
* Optional connections: | ||
|
||
* VDD (for powering the board from debug probe) | ||
* RESET | ||
|
||
Connecting the debug probe | ||
************************** | ||
|
||
The following steps describe how to connect your custom board to a debug probe. | ||
|
||
.. tabs:: | ||
|
||
.. group-tab:: Using a DK as debug probe | ||
|
||
Development Kits from Nordic Semiconductor include an onboard debug probe that supports the J-Link interface. | ||
|
||
To connect your custom board to this onboard debug probe, complete the following steps: | ||
|
||
1. Locate the SWD debug output header pins on your DK. | ||
Check the DK user guide on `Nordic Semiconductor TechDocs`_ for the exact location of these pins. | ||
For example, for the nRF52840 DK, read the `Debug output <nRF52840 DK Debug output_>`_ page. | ||
#. Connect the required pins to your custom board. | ||
#. Connect the DK to your PC using the USB cable. | ||
#. Install required J-Link drivers if not already present. | ||
|
||
.. group-tab:: Using a dedicated debug adapter | ||
|
||
If you don't have a Development Kit, use a dedicated debug adapter: | ||
|
||
1. Connect a compatible debug probe (like SEGGER J-Link) to your custom board. | ||
2. Install the appropriate debug interface drivers. | ||
3. Connect the debug probe to your PC using the USB cable. | ||
|
||
.. note:: | ||
The |NCS| supports various debug interfaces like J-Link and CMSIS-DAP, provided you have the proper drivers installed. | ||
|
||
Programming custom boards | ||
************************* | ||
|
||
After you connected the custom board, you can program your application to the board using either the :ref:`standard programming instructions <programming>` or the `Programmer app`_ from `nRF Connect for Desktop`_. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters