forked from zephyrproject-rtos/zephyr
-
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.
boards: add new board Electronut-labs Blip
Added config for https://github.com/electronut/ElectronutLabs-blip/ Signed-off-by: Tavish Naruka <[email protected]>
- Loading branch information
Showing
10 changed files
with
450 additions
and
1 deletion.
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
# Kconfig - Electronut Labs Blip board configuration | ||
# | ||
# Copyright (c) 2018 Electronut Labs | ||
# | ||
# SPDX-License-Identifier: Apache-2.0 | ||
|
||
if BOARD_NRF52840_BLIP | ||
|
||
config BOARD_ENABLE_DCDC | ||
bool "Enable DCDC mode" | ||
select SOC_DCDC_NRF52X | ||
default y | ||
|
||
endif # BOARD_NRF52840_BLIP |
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,9 @@ | ||
# Kconfig - Electronut Labs Blip board configuration | ||
# | ||
# Copyright (c) 2018 Electronut Labs | ||
# | ||
# SPDX-License-Identifier: Apache-2.0 | ||
|
||
config BOARD_NRF52840_BLIP | ||
bool "Electronut Labs Blip" | ||
depends on SOC_NRF52840_QIAA |
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,29 @@ | ||
# Kconfig - Electronut Labs Blip board configuration | ||
# | ||
# Copyright (c) 2018 Electronut Labs | ||
# | ||
# SPDX-License-Identifier: Apache-2.0 | ||
|
||
if BOARD_NRF52840_BLIP | ||
|
||
config BOARD | ||
default "nrf52840_blip" | ||
|
||
if USB | ||
|
||
config USB_NRF52840 | ||
default y | ||
|
||
config USB_DEVICE_STACK | ||
default y | ||
|
||
endif # USB | ||
|
||
if IEEE802154 | ||
|
||
config IEEE802154_NRF5 | ||
default y | ||
|
||
endif # IEEE802154 | ||
|
||
endif # BOARD_NRF52840_BLIP |
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 @@ | ||
include(${ZEPHYR_BASE}/boards/common/blackmagicprobe.board.cmake) |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
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,198 @@ | ||
.. _nrf52840_blip: | ||
|
||
Electronut Labs Blip | ||
#################### | ||
|
||
Overview | ||
******** | ||
|
||
Zephyr applications use the nrf52840_blip board configuration | ||
to run on Electronut Labs Blip hardware. It provides | ||
support for the Nordic Semiconductor nRF52840 ARM Cortex-M4F CPU and | ||
the following devices: | ||
|
||
* :abbr:`ADC (Analog to Digital Converter)` | ||
* CLOCK | ||
* FLASH | ||
* :abbr:`GPIO (General Purpose Input Output)` | ||
* :abbr:`I2C (Inter-Integrated Circuit)` | ||
* :abbr:`MPU (Memory Protection Unit)` | ||
* :abbr:`NVIC (Nested Vectored Interrupt Controller)` | ||
* :abbr:`PWM (Pulse Width Modulation)` | ||
* RADIO (Bluetooth Low Energy and 802.15.4) | ||
* :abbr:`RTC (nRF RTC System Clock)` | ||
* Segger RTT (RTT Console) | ||
* :abbr:`SPI (Serial Peripheral Interface)` | ||
* :abbr:`UART (Universal asynchronous receiver-transmitter)` | ||
* :abbr:`USB (Universal Serial Bus)` | ||
* :abbr:`WDT (Watchdog Timer)` | ||
|
||
.. figure:: img/nrf52840_blip.jpg | ||
:width: 442px | ||
:align: center | ||
:alt: Electronut Labs Blip | ||
|
||
Electronut Labs Blip (Credit: Electronut Labs) | ||
|
||
More information about the board is available at https://github.com/electronut/ElectronutLabs-blip. | ||
|
||
Hardware | ||
******** | ||
|
||
Blip has two external oscillators. The frequency of | ||
the slow clock is 32.768 kHz. The frequency of the main clock | ||
is 32 MHz. | ||
|
||
Supported Features | ||
================== | ||
|
||
The nrf52840_blip board configuration supports the following | ||
hardware features currently: | ||
|
||
+-----------+------------+----------------------+ | ||
| Interface | Controller | Driver/Component | | ||
+===========+============+======================+ | ||
| ADC | on-chip | adc | | ||
+-----------+------------+----------------------+ | ||
| CLOCK | on-chip | clock_control | | ||
+-----------+------------+----------------------+ | ||
| FLASH | on-chip | flash | | ||
+-----------+------------+----------------------+ | ||
| GPIO | on-chip | gpio | | ||
+-----------+------------+----------------------+ | ||
| I2C(M) | on-chip | i2c | | ||
+-----------+------------+----------------------+ | ||
| MPU | on-chip | arch/arm | | ||
+-----------+------------+----------------------+ | ||
| NVIC | on-chip | arch/arm | | ||
+-----------+------------+----------------------+ | ||
| PWM | on-chip | pwm | | ||
+-----------+------------+----------------------+ | ||
| RADIO | on-chip | Bluetooth, | | ||
| | | ieee802154 | | ||
+-----------+------------+----------------------+ | ||
| RTC | on-chip | system clock | | ||
+-----------+------------+----------------------+ | ||
| RTT | Segger | console | | ||
+-----------+------------+----------------------+ | ||
| SPI(M/S) | on-chip | spi | | ||
+-----------+------------+----------------------+ | ||
| UART | on-chip | serial | | ||
+-----------+------------+----------------------+ | ||
| USB | on-chip | usb | | ||
+-----------+------------+----------------------+ | ||
| WDT | on-chip | watchdog | | ||
+-----------+------------+----------------------+ | ||
|
||
Connections and IOs | ||
=================== | ||
|
||
LED | ||
--- | ||
|
||
* LED1 (green) = P0.13 | ||
* LED2 (green) = P0.14 | ||
* LED3 (green) = P0.15 | ||
|
||
Push buttons | ||
------------ | ||
|
||
* BUTTON1 = SW1 = P1.07 | ||
* Reset = SW5 = P0.18 (can be used as GPIO also) | ||
|
||
UART | ||
---- | ||
|
||
BMP does not support hardware flow control, so only RX/TX pins are connected. | ||
|
||
* TX = P0.6 | ||
* RX = P0.8 | ||
|
||
I2C | ||
--- | ||
|
||
I2C pins connected to onboard sensors: | ||
|
||
* SDA = P0.12 | ||
* SCL = P0.11 | ||
|
||
SPI | ||
--- | ||
|
||
* SCK = P0.25 | ||
* MOSI = P1.02 | ||
* MISO = P0.24 | ||
|
||
Microsd is connected to these pins, and CS pin is connected to P0.17. | ||
|
||
Programming and Debugging | ||
************************* | ||
|
||
Applications for the ``nrf52840_blip`` board configuration can be | ||
built and flashed in the usual way (see :ref:`build_an_application` | ||
and :ref:`application_run` for more details); The onboard Black Magic | ||
Probe debugger presents itself as two USB-serial ports. On Linux, | ||
they may come up as ``/dev/ttyACM0`` and ``/dev/ttyACM1``. The first | ||
one of these (``/dev/ttyACM0`` here) is the debugger port. | ||
GDB can directly connect to this port without requiring a GDB server by specifying | ||
``target external /dev/ttyACM0``. The second port acts as a | ||
serial port, connected to the SoC. | ||
|
||
Flashing | ||
======== | ||
|
||
Applications are flashed and run as usual (see :ref:`build_an_application` and | ||
:ref:`application_run` for more details). | ||
|
||
Here is an example for the :ref:`hello_world` application. | ||
|
||
First, run your favorite terminal program to listen for output. | ||
|
||
.. code-block:: console | ||
$ minicom -D <tty_device> -b 115200 | ||
Replace :code:`<tty_device>` with the serial port of Black Magic Probe. | ||
For example, under Linux, :code:`/dev/ttyACM1`. | ||
|
||
Then build and flash the application in the usual way. | ||
|
||
.. zephyr-app-commands:: | ||
:zephyr-app: samples/hello_world | ||
:board: nrf52840_blip | ||
:goals: build flash | ||
|
||
Debugging | ||
========= | ||
|
||
Debug and attach configurations are available using Black Magic Probe, and | ||
``ninja debug``, or ``ninja attach`` (or with ``make``) are available. | ||
|
||
NOTE: You may need to press the reset button once after using ``ninja flash`` | ||
to start executing the code. (not required with ``debug`` or ``attach``) | ||
|
||
|
||
Testing the LEDs and buttons in the nRF52840 PDK | ||
************************************************ | ||
|
||
There are 2 samples that allow you to test that the buttons (switches) and LEDs on | ||
the board are working properly with Zephyr: | ||
|
||
* :ref:`blinky-sample` | ||
* :ref:`button-sample` | ||
|
||
You can build and flash the examples to make sure Zephyr is running correctly on | ||
your board. The button and LED definitions can be found in :file:`boards/arm/nrf52840_blip/nrf52840_blip.dts`. | ||
|
||
|
||
References | ||
********** | ||
|
||
.. target-notes:: | ||
|
||
.. _Electronut Labs website: https://electronut.in | ||
.. _Store link: https://www.tindie.com/stores/ElectronutLabs/ | ||
.. _Blip website: https://github.com/electronut/ElectronutLabs-blip | ||
.. _Schematic: https://github.com/electronut/ElectronutLabs-blip/blob/master/blip_v0.3_schematic.pdf | ||
.. _Nordic Semiconductor Infocenter: http://infocenter.nordicsemi.com/ | ||
.. _Black Magic Probe website: https://github.com/blacksphere/blackmagic |
Oops, something went wrong.