mirror of
https://github.com/meshtastic/firmware.git
synced 2025-08-20 04:01:14 +00:00

* Fix protobuf structs handling (#4140) * Fix protobuf structs handling * Log instead of assert --------- Co-authored-by: Ben Meadors <benmmeadors@gmail.com> * BLE based logging (#4146) * WIP log characteristic * Bluetooth logging plumbing * Characteristic * Callback * Check for nullptr * Esp32 bluetooth impl * Formatting * Add thread name and log level * Add settings guard * Remove comments * Field name * Fixes esp32 * Open it up * Whoops * Move va_end past our logic * Use `upload_protocol = esptool` as with the other heltec devices instead of `esp-builtin` (#4151) * Standardize lat/lon position logs (#4156) * Standardize lat/lon position logs * Missed sone and condensed logs * [create-pull-request] automated change (#4157) Co-authored-by: thebentern <9000580+thebentern@users.noreply.github.com> * Pause BLE logging during want_config flow (#4162) * Update NimBLE to 1.4.2 (#4163) * Implement replies for all telemetry types based on variant tag (#4164) * Implement replies for all telemetry types based on variant tag * Remove check for `ignoreRequest`: modules can set this, don't need to check --------- Co-authored-by: Ben Meadors <benmmeadors@gmail.com> * Esptool is better * Explicitly set characteristic * fix INA3221 sensor (#4168) - pass wire to begin() - remove redundant setAddr() (already set in header) * Show compass on waypoint frame; clear when waypoint deleted (#4116) * Clear expired or deleted waypoint frame * Return 0 to CallbackObserver * Add a missing comment * Draw compass for waypoint frame * Display our own waypoints * [create-pull-request] automated change (#4171) Co-authored-by: thebentern <9000580+thebentern@users.noreply.github.com> * Add semihosting support for nrf52 devices (#4137) * Turn off vscode cmake prompt - we don't use cmake on meshtastic * Add rak4631_dap variant for debugging with NanoDAP debug probe device. * The rak device can also run freertos (which is underneath nrf52 arduino) * Add semihosting support for nrf52840 devices Initial platformio.ini file only supports rak4630 Default to non TCP for the semihosting log output for now... Fixes https://github.com/meshtastic/firmware/issues/4135 * fix my botched merge - keep board_level = extra flag for rak3631_dbg --------- Co-authored-by: Ben Meadors <benmmeadors@gmail.com> * [create-pull-request] automated change (#4174) Co-authored-by: thebentern <9000580+thebentern@users.noreply.github.com> * Display alerts (#4170) * Move static functions into Screen.h, show compass during calibration * Move to _fontHeight macro to avoid collision * Move some alert functions to new alert handler * Catch missed reboot code * ESP32 fixes * Bump esp8266-oled-ssd1306 * Fixes for when a device has no screen * Use new startAlert(char*) helper class * Add EINK bits back to alert handling * Add noop class for no-display devices --------- Co-authored-by: Ben Meadors <benmmeadors@gmail.com> * Send file system manifest up on want_config (#4176) * Send file system manifest up on want_config * Platform specific methods * Helps to actually make the change * Clear * tell vscode, if formatting, use whatever our trunk formatter wants (#4186) without this flag if the user has set some other formatter (clang) in their user level settings, it will be looking in the wrong directory for the clang options (we want the options in .trunk/clang) Note: formatOnSave is true in master, which means a bunch of our older files are non compliant and if you edit them it will generate lots of formatting related diffs. I guess I'll start letting that happen with my future commits ;-). * fix the build - would loop forever if there were no files to send (#4188) * Show owner.short_name on boot (and E-Ink sleep screen) (#4134) * Show owner.short_name on boot and sleep screen (on e-ink) * Update Screen.cpp - new line for short_name Boot screen short_name now below the region setting. Looks better on small screens. * Draw short_name on right --------- Co-authored-by: Thomas Göttgens <tgoettgens@gmail.com> Co-authored-by: todd-herbert <herbert.todd@gmail.com> Co-authored-by: Ben Meadors <benmmeadors@gmail.com> * nrf52 soft device will watchdog if you use ICE while BT on... (#4189) so have debugger disable bluetooth. * correct xiao_ble build preventing sx1262 init (#4191) * Force a compile time failur if FromRadio or ToRadio get larger than (#4190) a BLE packet size. We are actually very close to this threshold so important to make sure we don't accidentally pass it. * Clear vector after complete config state (#4194) * Clear after complete config * Don't collect . entries * Log file name and size * [create-pull-request] automated change (#4200) Co-authored-by: thebentern <9000580+thebentern@users.noreply.github.com> * Make the logs Colorful! (#4199) * Squash needlessly static functions (#4183) * Trim extra vprintf and filter for unprintable characters * Deprecate Router Client role (and make it Client) (#4201) * [create-pull-request] automated change (#4205) Co-authored-by: thebentern <9000580+thebentern@users.noreply.github.com> * Move waypoint (#4202) * Move waypoint screen draw into the waypoint module * Get the observer set up for the waypoint screen draw * Static squashing: screen dimensions Macros moved back to Screen.cpp, as a band-aid until we eventually move all those static functions into the Screen class. * Move getCompassDiam into Screen class (supress compiler warnings) At this stage, the method is still static, because it's used by drawNodeInfo, which has no tidy reference to our screen instance. This is probably just another band-aid until these static functions all move. * Use new getCompassDiam function in AccelerometerThread * Properly gate display code in WaypointModule --------- Co-authored-by: Todd Herbert <herbert.todd@gmail.com> * Fix flakey phone api transition from file manifest to complete (#4209) * Try fix flakey phone api transition from file manifest to complete * Skip * enable colors in platformio serial monitor (#4217) * When talking via serial, encapsulate log messages in protobufs if necessary (#4187) * clean up RedirectablePrint::log so it doesn't have three very different implementations inline. * remove NoopPrint - it is no longer needed * when talking to API clients via serial, don't turn off log msgs instead encapsuate them * fix the build - would loop forever if there were no files to send * don't use Segger code if not talking to a Segger debugger * when encapsulating logs, make sure the strings always has nul terminators * nrf52 soft device will watchdog if you use ICE while BT on... so have debugger disable bluetooth. * Important to not print debug messages while writing to the toPhone scratch buffer * don't include newlines if encapsulating log records as protobufs --------- Co-authored-by: Ben Meadors <benmmeadors@gmail.com> * [create-pull-request] automated change (#4218) Co-authored-by: thebentern <9000580+thebentern@users.noreply.github.com> * Fix SHT41 support (#4222) * Add SHT41 Serial to I2c Detection Code On the Seeed Wio-WM1110 Dev Kit board, the SHT41 chip was being incorrectly detected as SHT31. This patch adds the necessary serial number for the SHT41 chip to be correctly detected. fixes meshtastic/firmware#4221 * Add missing sensor read for SHT41 * Typo fix in logs - mhz - MHz (#4225) As reported by karamo, a few different places in our logs had incorrect capitalization of MHz. fixes meshtastic/firmware#4126 * New new BLE logging characteristic with LogRecord protos (#4220) * New UUID * New log radio characteristic with LogRecord protobuf * LogRecord * Merge derp * How did you get there * Trunk * Fix length * Remove assert * minor cleanup proposal (#4169) * MESHTASTIC_EXCLUDE_WIFI and HAS_WIFI cleanup... Our code was checking HAS_WIFI and the new MESHTASTIC_EXCLUDE_WIFI flags in various places (even though EXCLUDE_WIFI forces HAS_WIFI to 0). Instead just check HAS_WIFI, only use EXCLUDE_WIFI inside configuration.h * cleanup: use HAS_NETWORKING instead of HAS_WIFI || HAS_ETHERNET We already had HAS_NETWORKING as flag in MQTT to mean 'we have tcpip'. Generallize that and move it into configuration.h so that we can use it elsewhere. * Use #pragma once, because supported by gcc and all modern compilers instead of #ifdef DOTHFILE_H etc... --------- Co-authored-by: Jonathan Bennett <jbennett@incomsystems.biz> * Add PowerMon support (#4155) * Turn off vscode cmake prompt - we don't use cmake on meshtastic * Add rak4631_dap variant for debugging with NanoDAP debug probe device. * The rak device can also run freertos (which is underneath nrf52 arduino) * Add semihosting support for nrf52840 devices Initial platformio.ini file only supports rak4630 Default to non TCP for the semihosting log output for now... Fixes https://github.com/meshtastic/firmware/issues/4135 * powermon WIP (for https://github.com/meshtastic/firmware/issues/4136 ) * oops - mean't to mark the _dbg variant as an 'extra' board. * powermon wip * Make serial port on wio-sdk-wm1110 board work By disabling the (inaccessible) adafruit USB * Instrument (radiolib only for now) lora for powermon per https://github.com/meshtastic/firmware/issues/4136 * powermon gps support https://github.com/meshtastic/firmware/issues/4136 * Add CPU deep and light sleep powermon states https://github.com/meshtastic/firmware/issues/4136 * Change the board/swversion bootstring so it is a new "structured" log msg. * powermon wip * add example script for getting esp S3 debugging working Not yet used but I didn't want these nasty tricks to get lost yet. * Add PowerMon reporting for screen and bluetooth pwr. * make power.powermon_enables config setting work. * update to latest protobufs * fix bogus shellcheck warning * make powermon optional (but default enabled because tiny and no runtime impact) * tell vscode, if formatting, use whatever our trunk formatter wants without this flag if the user has set some other formatter (clang) in their user level settings, it will be looking in the wrong directory for the clang options (we want the options in .trunk/clang) Note: formatOnSave is true in master, which means a bunch of our older files are non compliant and if you edit them it will generate lots of formatting related diffs. I guess I'll start letting that happen with my future commits ;-). * add PowerStress module * nrf52 arduino is built upon freertos, so let platformio debug it * don't accidentally try to Segger ICE if we are using another ICE * clean up RedirectablePrint::log so it doesn't have three very different implementations inline. * remove NoopPrint - it is no longer needed * when talking to API clients via serial, don't turn off log msgs instead encapsuate them * fix the build - would loop forever if there were no files to send * don't use Segger code if not talking to a Segger debugger * when encapsulating logs, make sure the strings always has nul terminators * nrf52 soft device will watchdog if you use ICE while BT on... so have debugger disable bluetooth. * Important to not print debug messages while writing to the toPhone scratch buffer * don't include newlines if encapsulating log records as protobufs * update to latest protobufs (needed for powermon goo) * PowerStress WIP * fix linter warning * Cleanup buffer * Merge hex for wm1110 target(s) * Only sdk * Sudo * Fix exclude macros (#4233) * fix MESHTASTIC_EXCLUDE_BLUETOOTH * fix HAS_SCREEN=0 * fix MESHTASTIC_EXCLUDE_GPS * fix typo in build-nrf52.sh (#4231) chmod is the command, '+x' is the argument. * Tidy Wireless Paper variant files (#4238) * Quick tidy of pins_arduino.h Matches requests made at https://github.com/meshtastic/firmware/pull/4226#discussion_r1664183480) * Tidy variant.h * Change deprecated ADC attenuation parameter From 11dB to 12dB. Resolves compiler warning. Allegly, no impact on function: `This is deprecated, it behaves the same as `ADC_ATTEN_DB_12` * Updated raspbian CI to update apt repository ahead of libbluetooth. (#4243) * Fix BLE logging on nrf52 (#4244) * allow ble logrecords to be fetched either by NOTIFY or INDICATE ble types This allows 'lossless' log reading. If client has requested INDICATE (rather than NOTIFY) each log record emitted via log() will have to fetched by the client device before the meshtastic node can continue. * Fix serious problem with nrf52 BLE logging. When doing notifies of LogRecords it is important to use the binary write routines - writing using the 'string' write won't work. Because protobufs can contain \0 nuls inside of them which if being parsed as a string will cause only a portion of the protobuf to be sent. I noticed this because some log messages were not getting through. --------- Co-authored-by: Ben Meadors <benmmeadors@gmail.com> * Fix build when HAS_NETWORKING is false on nrf52 (#4237) (tested on a rak4631 by setting HAS_ETHERNET false when shrinking image) * If `toPhoneQueue` is full, still increment `fromNum` to avoid client never getting packets (#4246) * Update to SoftDevice 7.3.0 for wio-sdk-wm1110 and wio-tracker-wm1110 (#4248) * Update variant.h * Update wio-tracker-wm1110.json * Update wio-sdk-wm1110.json * Update platformio.ini * Update platformio.ini * Add files via upload * Add files via upload * Update variant.h --------- Co-authored-by: Mike <mikhael.skvortsov@gmail.com> Co-authored-by: Ben Meadors <benmmeadors@gmail.com> Co-authored-by: Mike G <mkgin@users.noreply.github.com> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: thebentern <9000580+thebentern@users.noreply.github.com> Co-authored-by: GUVWAF <78759985+GUVWAF@users.noreply.github.com> Co-authored-by: Warren Guy <5602790+warrenguy@users.noreply.github.com> Co-authored-by: todd-herbert <herbert.todd@gmail.com> Co-authored-by: geeksville <kevinh@geeksville.com> Co-authored-by: Jonathan Bennett <jbennett@incomsystems.biz> Co-authored-by: Alexander <156134901+Dorn8010@users.noreply.github.com> Co-authored-by: Thomas Göttgens <tgoettgens@gmail.com> Co-authored-by: quimnut <github@dopegoat.com> Co-authored-by: Manuel <71137295+mverch67@users.noreply.github.com> Co-authored-by: Agent Blu, 006 <blu006@ucr.edu> Co-authored-by: Mark Trevor Birss <markbirss@gmail.com>
260 lines
11 KiB
C
260 lines
11 KiB
C
/*
|
|
* Copyright (c) 2014 - 2017, Nordic Semiconductor ASA
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without modification,
|
|
* are permitted provided that the following conditions are met:
|
|
*
|
|
* 1. Redistributions of source code must retain the above copyright notice, this
|
|
* list of conditions and the following disclaimer.
|
|
*
|
|
* 2. Redistributions in binary form, except as embedded into a Nordic
|
|
* Semiconductor ASA integrated circuit in a product or a software update for
|
|
* such product, must reproduce the above copyright notice, this list of
|
|
* conditions and the following disclaimer in the documentation and/or other
|
|
* materials provided with the distribution.
|
|
*
|
|
* 3. Neither the name of Nordic Semiconductor ASA nor the names of its
|
|
* contributors may be used to endorse or promote products derived from this
|
|
* software without specific prior written permission.
|
|
*
|
|
* 4. This software, with or without modification, must only be used with a
|
|
* Nordic Semiconductor ASA integrated circuit.
|
|
*
|
|
* 5. Any software provided in binary form under this license must not be reverse
|
|
* engineered, decompiled, modified and/or disassembled.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS
|
|
* OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
* OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
* DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA OR CONTRIBUTORS BE
|
|
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
|
|
* GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
|
|
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
*/
|
|
|
|
/**
|
|
@defgroup nrf_mbr_api Master Boot Record API
|
|
@{
|
|
|
|
@brief APIs for updating SoftDevice and BootLoader
|
|
|
|
*/
|
|
|
|
#ifndef NRF_MBR_H__
|
|
#define NRF_MBR_H__
|
|
|
|
#include "nrf_svc.h"
|
|
#include <stdint.h>
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/** @addtogroup NRF_MBR_DEFINES Defines
|
|
* @{ */
|
|
|
|
/**@brief MBR SVC Base number. */
|
|
#define MBR_SVC_BASE (0x18)
|
|
|
|
/**@brief Page size in words. */
|
|
#define MBR_PAGE_SIZE_IN_WORDS (1024)
|
|
|
|
/** @brief The size that must be reserved for the MBR when a SoftDevice is written to flash.
|
|
This is the offset where the first byte of the SoftDevice hex file is written. */
|
|
#define MBR_SIZE (0x1000)
|
|
|
|
/** @brief Location (in the flash memory) of the bootloader address. */
|
|
#define MBR_BOOTLOADER_ADDR (0xFF8)
|
|
|
|
/** @brief Location (in UICR) of the bootloader address. */
|
|
#define MBR_UICR_BOOTLOADER_ADDR (&(NRF_UICR->NRFFW[0]))
|
|
|
|
/** @brief Location (in the flash memory) of the address of the MBR parameter page. */
|
|
#define MBR_PARAM_PAGE_ADDR (0xFFC)
|
|
|
|
/** @brief Location (in UICR) of the address of the MBR parameter page. */
|
|
#define MBR_UICR_PARAM_PAGE_ADDR (&(NRF_UICR->NRFFW[1]))
|
|
|
|
/** @} */
|
|
|
|
/** @addtogroup NRF_MBR_ENUMS Enumerations
|
|
* @{ */
|
|
|
|
/**@brief nRF Master Boot Record API SVC numbers. */
|
|
enum NRF_MBR_SVCS {
|
|
SD_MBR_COMMAND = MBR_SVC_BASE, /**< ::sd_mbr_command */
|
|
};
|
|
|
|
/**@brief Possible values for ::sd_mbr_command_t.command */
|
|
enum NRF_MBR_COMMANDS {
|
|
SD_MBR_COMMAND_COPY_BL, /**< Copy a new BootLoader. @see ::sd_mbr_command_copy_bl_t*/
|
|
SD_MBR_COMMAND_COPY_SD, /**< Copy a new SoftDevice. @see ::sd_mbr_command_copy_sd_t*/
|
|
SD_MBR_COMMAND_INIT_SD, /**< Initialize forwarding interrupts to SD, and run reset function in SD. Does not require any
|
|
parameters in ::sd_mbr_command_t params.*/
|
|
SD_MBR_COMMAND_COMPARE, /**< This command works like memcmp. @see ::sd_mbr_command_compare_t*/
|
|
SD_MBR_COMMAND_VECTOR_TABLE_BASE_SET, /**< Change the address the MBR starts after a reset. @see
|
|
::sd_mbr_command_vector_table_base_set_t*/
|
|
SD_MBR_COMMAND_RESERVED,
|
|
SD_MBR_COMMAND_IRQ_FORWARD_ADDRESS_SET, /**< Start forwarding all interrupts to this address. @see
|
|
::sd_mbr_command_irq_forward_address_set_t*/
|
|
};
|
|
|
|
/** @} */
|
|
|
|
/** @addtogroup NRF_MBR_TYPES Types
|
|
* @{ */
|
|
|
|
/**@brief This command copies part of a new SoftDevice
|
|
*
|
|
* The destination area is erased before copying.
|
|
* If dst is in the middle of a flash page, that whole flash page will be erased.
|
|
* If (dst+len) is in the middle of a flash page, that whole flash page will be erased.
|
|
*
|
|
* The user of this function is responsible for setting the BPROT registers.
|
|
*
|
|
* @retval ::NRF_SUCCESS indicates that the contents of the memory blocks where copied correctly.
|
|
* @retval ::NRF_ERROR_INTERNAL indicates that the contents of the memory blocks where not verified correctly after copying.
|
|
*/
|
|
typedef struct {
|
|
uint32_t *src; /**< Pointer to the source of data to be copied.*/
|
|
uint32_t *dst; /**< Pointer to the destination where the content is to be copied.*/
|
|
uint32_t len; /**< Number of 32 bit words to copy. Must be a multiple of @ref MBR_PAGE_SIZE_IN_WORDS words.*/
|
|
} sd_mbr_command_copy_sd_t;
|
|
|
|
/**@brief This command works like memcmp, but takes the length in words.
|
|
*
|
|
* @retval ::NRF_SUCCESS indicates that the contents of both memory blocks are equal.
|
|
* @retval ::NRF_ERROR_NULL indicates that the contents of the memory blocks are not equal.
|
|
*/
|
|
typedef struct {
|
|
uint32_t *ptr1; /**< Pointer to block of memory. */
|
|
uint32_t *ptr2; /**< Pointer to block of memory. */
|
|
uint32_t len; /**< Number of 32 bit words to compare.*/
|
|
} sd_mbr_command_compare_t;
|
|
|
|
/**@brief This command copies a new BootLoader.
|
|
*
|
|
* The MBR assumes that either @ref MBR_BOOTLOADER_ADDR or @ref MBR_UICR_BOOTLOADER_ADDR is set to
|
|
* the address where the bootloader will be copied. If both addresses are set, the MBR will prioritize
|
|
* @ref MBR_BOOTLOADER_ADDR.
|
|
*
|
|
* The bootloader destination is erased by this function.
|
|
* If (destination+bl_len) is in the middle of a flash page, that whole flash page will be erased.
|
|
*
|
|
* This command requires that @ref MBR_PARAM_PAGE_ADDR or @ref MBR_UICR_PARAM_PAGE_ADDR is set,
|
|
* see @ref sd_mbr_command.
|
|
*
|
|
* This command will use the flash protect peripheral (BPROT or ACL) to protect the flash that is
|
|
* not intended to be written.
|
|
*
|
|
* On success, this function will not return. It will start the new bootloader from reset-vector as normal.
|
|
*
|
|
* @retval ::NRF_ERROR_INTERNAL indicates an internal error that should not happen.
|
|
* @retval ::NRF_ERROR_FORBIDDEN if the bootloader address is not set.
|
|
* @retval ::NRF_ERROR_INVALID_LENGTH if parameters attempts to read or write outside flash area.
|
|
* @retval ::NRF_ERROR_NO_MEM No MBR parameter page is provided. See @ref sd_mbr_command.
|
|
*/
|
|
typedef struct {
|
|
uint32_t *bl_src; /**< Pointer to the source of the bootloader to be be copied.*/
|
|
uint32_t bl_len; /**< Number of 32 bit words to copy for BootLoader. */
|
|
} sd_mbr_command_copy_bl_t;
|
|
|
|
/**@brief Change the address the MBR starts after a reset
|
|
*
|
|
* Once this function has been called, this address is where the MBR will start to forward
|
|
* interrupts to after a reset.
|
|
*
|
|
* To restore default forwarding, this function should be called with @ref address set to 0. If a
|
|
* bootloader is present, interrupts will be forwarded to the bootloader. If not, interrupts will
|
|
* be forwarded to the SoftDevice.
|
|
*
|
|
* The location of a bootloader can be specified in @ref MBR_BOOTLOADER_ADDR or
|
|
* @ref MBR_UICR_BOOTLOADER_ADDR. If both addresses are set, the MBR will prioritize
|
|
* @ref MBR_BOOTLOADER_ADDR.
|
|
*
|
|
* This command requires that @ref MBR_PARAM_PAGE_ADDR or @ref MBR_UICR_PARAM_PAGE_ADDR is set,
|
|
* see @ref sd_mbr_command.
|
|
*
|
|
* On success, this function will not return. It will reset the device.
|
|
*
|
|
* @retval ::NRF_ERROR_INTERNAL indicates an internal error that should not happen.
|
|
* @retval ::NRF_ERROR_INVALID_ADDR if parameter address is outside of the flash size.
|
|
* @retval ::NRF_ERROR_NO_MEM No MBR parameter page is provided. See @ref sd_mbr_command.
|
|
*/
|
|
typedef struct {
|
|
uint32_t address; /**< The base address of the interrupt vector table for forwarded interrupts.*/
|
|
} sd_mbr_command_vector_table_base_set_t;
|
|
|
|
/**@brief Sets the base address of the interrupt vector table for interrupts forwarded from the MBR
|
|
*
|
|
* Unlike sd_mbr_command_vector_table_base_set_t, this function does not reset, and it does not
|
|
* change where the MBR starts after reset.
|
|
*
|
|
* @retval ::NRF_SUCCESS
|
|
*/
|
|
typedef struct {
|
|
uint32_t address; /**< The base address of the interrupt vector table for forwarded interrupts.*/
|
|
} sd_mbr_command_irq_forward_address_set_t;
|
|
|
|
/**@brief Input structure containing data used when calling ::sd_mbr_command
|
|
*
|
|
* Depending on what command value that is set, the corresponding params value type must also be
|
|
* set. See @ref NRF_MBR_COMMANDS for command types and corresponding params value type. If command
|
|
* @ref SD_MBR_COMMAND_INIT_SD is set, it is not necessary to set any values under params.
|
|
*/
|
|
typedef struct {
|
|
uint32_t command; /**< Type of command to be issued. See @ref NRF_MBR_COMMANDS. */
|
|
union {
|
|
sd_mbr_command_copy_sd_t copy_sd; /**< Parameters for copy SoftDevice.*/
|
|
sd_mbr_command_compare_t compare; /**< Parameters for verify.*/
|
|
sd_mbr_command_copy_bl_t copy_bl; /**< Parameters for copy BootLoader. Requires parameter page. */
|
|
sd_mbr_command_vector_table_base_set_t base_set; /**< Parameters for vector table base set. Requires parameter page.*/
|
|
sd_mbr_command_irq_forward_address_set_t irq_forward_address_set; /**< Parameters for irq forward address set*/
|
|
} params; /**< Command parameters. */
|
|
} sd_mbr_command_t;
|
|
|
|
/** @} */
|
|
|
|
/** @addtogroup NRF_MBR_FUNCTIONS Functions
|
|
* @{ */
|
|
|
|
/**@brief Issue Master Boot Record commands
|
|
*
|
|
* Commands used when updating a SoftDevice and bootloader.
|
|
*
|
|
* The @ref SD_MBR_COMMAND_COPY_BL and @ref SD_MBR_COMMAND_VECTOR_TABLE_BASE_SET requires
|
|
* parameters to be retained by the MBR when resetting the IC. This is done in a separate flash
|
|
* page. The location of the flash page should be provided by the application in either
|
|
* @ref MBR_PARAM_PAGE_ADDR or @ref MBR_UICR_PARAM_PAGE_ADDR. If both addresses are set, the MBR
|
|
* will prioritize @ref MBR_PARAM_PAGE_ADDR. This page will be cleared by the MBR and is used to
|
|
* store the command before reset. When an address is specified, the page it refers to must not be
|
|
* used by the application. If no address is provided by the application, i.e. both
|
|
* @ref MBR_PARAM_PAGE_ADDR and @ref MBR_UICR_PARAM_PAGE_ADDR is 0xFFFFFFFF, MBR commands which use
|
|
* flash will be unavailable and return @ref NRF_ERROR_NO_MEM.
|
|
*
|
|
* @param[in] param Pointer to a struct describing the command.
|
|
*
|
|
* @note For a complete set of return values, see ::sd_mbr_command_copy_sd_t,
|
|
* ::sd_mbr_command_copy_bl_t, ::sd_mbr_command_compare_t,
|
|
* ::sd_mbr_command_vector_table_base_set_t, ::sd_mbr_command_irq_forward_address_set_t
|
|
*
|
|
* @retval ::NRF_ERROR_NO_MEM No MBR parameter page provided
|
|
* @retval ::NRF_ERROR_INVALID_PARAM if an invalid command is given.
|
|
*/
|
|
SVCALL(SD_MBR_COMMAND, uint32_t, sd_mbr_command(sd_mbr_command_t *param));
|
|
|
|
/** @} */
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
#endif // NRF_MBR_H__
|
|
|
|
/**
|
|
@}
|
|
*/
|