Skip to content

Releases: analogdevicesinc/msdk

October 2024 Release

18 Oct 14:01
8b51c1f
Compare
Choose a tag to compare

Installation

See the "Installation" in the MSDK User Guide for instructions on installing the MSDK via the online installer.

For existing users, see the "Maintenance" section of the User Guide for instructions on updating the MSDK.

Offline installers tagged at this version of the MSDK are available at the bottom of this release page. Note: The offline installers have the same pre-requisites as the online installers that must be met before running.

New Features

Examples

Build

Tools

BLE

Boards

CMSIS

MiscDrivers

PeriphDrivers

  • Allow info block unlock function be overwritten for MAX32657 (#1213) by @ozersa 469f7f71d9
  • Enable System Clock Divide Support for MAX78002 (#1170) by @hfakkiz 5c1a332338
  • Add Clock Setter APIs for MAX32690 & MAX78002 Peripherals, Add Dual Mode TMR Support, Add MAX32690 Clock Calibration API for IPO, Add MAX32690 RISCV Clock Setter, CFS Support Functions (#1108) by jake.carter@analog.com 3f96590c5f
  • Enable System Clock Divide Support for MAX32690 (#1078) by @ozersa a52a937959
  • Add PinMux tool supporting functions (#997) by @lorne-maxim 6cb136f68c
  • Add SPI v2 support to MAX32690 (#964) by @sihyung-maxim 755e6ffa0d
  • Allow Skipping Clock and GPIO Initialization on CAN (#959) by @karaanil@users.noreply.github.com 2ecc1e45a7
  • Allow Skipping Clock and GPIO Initialization on I2C, SPI, and UART (#932) by @ozersa e75ecd7791

ThirdParty

Other

Bug Fixes

Documentation

Examples

Build

Tools

  • Update Keil support for ECC enabled versions of the MAX32675 (#1001) by @lorne-maxim 187ff74eb7
  • Add JLink Flashing support for MAX32670/75 (#966) by @BrentK-ADI 342b204611

BLE

Boards

  • Configure push buttons with alternate function hyper ram to use VDDIO (#1216) by @EricB-ADI 6041cc9880
  • Update MAX78002 examples list for Eclipse project wizard (#1139) by @sihyung-maxim b2ebb83b9b

CMSIS

MiscDrivers

PeriphDrivers

Read more

February 2024 Release

23 Feb 19:43
b20b398
Compare
Choose a tag to compare

Installation

See the "Installation" in the MSDK User Guide for instructions on installing the MSDK via the online installer.

For existing users, see the "Maintenance" section of the User Guide for instructions on updating the MSDK.

Offline installers tagged at this version of the MSDK are available at the bottom of this release page. Note: The offline installers have the same pre-requisites as the online installers that must be met before running.

New Features

BLE

  • Add documentation for vendor specific HCI commands (#812) by @EricB-ADI
  • Integrate HCI docs into main Cordio doc (#813) by @EricB-ADI
  • Implement RSSI and Phy Enable/Disable in HCI for Cordio HCI (#836) by @EricB-ADI

Build

CMSIS

Examples

MiscDrivers

PeriphDrivers

  • Add clock selection feature to WDT (#808) by @hfakkiz
  • Allow Skipping Clock and GPIO Initialization on Additional Peripherals (#809) by @ozersa
  • Add Ability to Set UART Pin Mapping for MAX32672 (#783) by @Jake-Carter
  • Add SPIMSS_DMA example and SPIMSS Master Trans DMA APIs (#840) by @kilicomercan
  • Add System Clock Div APIs for MAX32670 and MAX32660 (#857) by @ozersa
  • Add System Clock Div APIs for MAX32 MCUs (#873) by @ozersa

SDHC

Fixes

BLE

Boards

  • Add default interrupt handlers for the touchscreen (#795) by @Jacob-Scheiffler
  • Add GC0308 Camera Drivers, Add MAX78000 CAM02_RevA Board Support Package, Add CAM02 face-detect demo (#842) by @Jake-Carter
  • Remove TFT Lib include from the MAX32690 WLP_V1 (no TFT) (#897) by @EricB-ADI

Build

CMSIS

  • Update copyrights in all CMSIS register files (#788) by @sihyung-maxim
  • Update OWM_STAT.presence_detect field position [7] for MAX32690 (#794) by @sihyung-maxim
  • Properly set RISCV vector table addresses for MAX32655 (#819) by @EricB-ADI
  • Fix MAX32690 SRAM Size Calculation (#843) by @ozersa
  • Update RTC SEC and SSEC register size (#859) by @ozersa
  • Add OVR Correction to SystemCoreClock Calculation for MAX32662, MAX32672, and MAX32675 (#867) by @ahmetalincak
  • Fix logic error in SYS Clock Enable/Disable functions and INRO frequency for MAX32662 (#895) by @kilicomercan

Documentation

Examples

  • Fix bug in FaceId RISC-V example (#807) by @vicloginov
  • Highlight JP9/JP10 in printfs for MAX32690EVKIT I2C Example (#828) by @Jake-Carter
  • Updated wording in FCC Examples (#832) by @EricB-ADI
  • Add GC0308 Camera Drivers, Add MAX78000 CAM02_RevA Board Support Package, Add CAM02 face-detect demo (#842) by @Jake-Carter
  • Add ADT7420 I2C Sensor Driver and Example for MAX32655EVKIT (#853) by @selimgullulu
  • Add ADT7320 Temperature Sensor Driver and Example for MAX32665 (#860) by @ersahatmacaa
  • Fix MAX78002 TFT_Demo Example for TFT=ADAFRUIT (#869) by @selimgullulu
  • Fix SW number in MAX32670 RTC example and update MAX32655EVKIT examples list (#916) by @kenan-balci

MAXUSB

MiscDrivers

  • Add Missing C++ Guards to Camera and Display Files (#827) by @Jake-Carter
  • Add GC0308 Camera Drivers, Add MAX78000 CAM02_RevA Board Support Package, Add CAM02 face-detect demo (#842) by @Jake-Carter
  • Clear out-of-bounds warnings seen with GCC v13.2 (#852) by @ahmetalincak
  • Add ADT7420 I2C Sensor Driver and Example for MAX32655EVKIT (#853) by @selimgullulu
  • Add ADT7320 Temperature Sensor Driver and Example for MAX32665 (#860) by @ersahatmacaa

PeriphDrivers

  • Fix UART DMA Transactions and Allow for Full Duplex (#763) by @Jake-Carter
  • Fix false stop detection in I2C interrupt handler (#765) by @Jacob-Scheiffler
  • Update UART Rev. A to support TransactionAsync calls from callback function (#769) by @Jacob-Scheiffler
  • Fix typos in SPI Rx Request Select, new SVD file for MAX32690 (#775) by @Vitorbnc
  • Add update to force scale select sample to occur with ADC and ADC RefSelect for REVA API (#779) by @EricB-ADI
  • Fix OWM Presence Detect Bit and GPIO Alternate Functions, Use VDDIOH by Default (#811) by @ozersa
  • Fix MAX32672 MXC_TMR_GetPeriod for 16-32Mhz Clock (#814) by @Jake-Carter
  • Fix ADC RevB clock source configurations (#817) by @hfakkiz
  • Fix Stuck Timer when PWM is set to 0 (#818) by @ozersa
  • Fix MAX32655 WDT clock source order (#820) by @hfakkiz
  • Fix TMR Rev B Initialization Bug with Non-Default Clock Sources (#829) by @Jake-Carter
  • Fix MAX32675, MAX32680 A5 Silicon AFE Init and Speedups (#830) by @jdk-maxim
  • Fix TMR Shutdown Bug, Stop Timer Before Clearing CTRL0 (#834) by @hfakkiz
  • Add API to lock Debug Access Port (#845) by @Jacob-Scheiffler
  • Add missing timer dual edge capture mode (#846) by @mertekren
  • Fix confused usage of wsize and bits_word register fields in I2S driver (#847) by @ahmetalincak
  • Add I2C RX FIFO status check to receive more than 256-byte of data for I2C synchronous transactions (#868) by @ahmetalincak
  • Update MAX32662 GPIO PAD configuration (#874) by @hfakkiz
  • Add GPIO Chip Select Configuration for MAX32665 SPI driver (#877) by @Brandon-Hurst
  • Re-order VSSEL selection to avoid possible damages on pads (#880) by @ahmetalincak
  • Fix MXC_UART_Shutdown Typo for LPUART0 Pin De-Initialization (#888) by @Jake-Carter
  • Fix logic error in SYS Clock Enable/Disable functions and INRO frequency for MAX32662 (#895) by @kilicomercan
  • Fix IAR build errors and most warnings for MAX32690 (#899) by @sihyung-maxim
  • Remove unused aes_me18.c (#904) by @sihyung-maxim
  • Fix SPI RevA1 DMA Bug When Transaction Length is Less Than the FIFO Size (#905) by @Jake-Carter
  • Add Missing SEC/MSEC/USEC Utility Macros to MAX32650 (#912) by @Jake-Carter

Other

October 2023 Release

11 Oct 03:03
0ee115d
Compare
Choose a tag to compare

Installation

See the "Installation" in the MSDK User Guide for instructions on installing the MSDK via the online installer.

For existing users, see the "Maintenance" section of the User Guide for instructions on updating the MSDK.

Offline installers tagged at this version of the MSDK are available at the bottom of this release page. Note: The offline installers have the same pre-requisites as the online installers that must be met before running.

What's Changed

API Updates

  • fix(Examples)!: Require DMA Channel as Input Argument for ADC DMA Conversions, Fix ADC DMA Transfer Bug for Channels > 0 by @Vignesh-VVadivel in #643
  • feat(PeriphDrivers)!: Add support for configuring GPIO Drive Strength by @sihyung-maxim in #673
  • feat(Examples,PeriphDrivers)!: Add SPI v2 Target Transaction functions by @sihyung-maxim in #662

(Opt-in) Native Make Support on Windows

Installation

As of #653 Native Make binaries are now available on Windows. This is a new default component, so existing installs must manually add it through the maintenance tool. Fresh installs will install it by default.

image

Eclipse and VS Code have been updated to look for the native Windows binaries after the MSYS2 binaries to make this an "opt in" feature and preserve compatibility with existing projects.

To opt in to the native binaries on Windows, uninstall the MSYS2 component and install the GNU Make component. Testing showed some incompatibilities having both MSYS2 tools and native Make on the PATH at the same time. Primarily, the colorized output for parallel builds is broken when both are present.

image

Updating Existing VS Code Projects

The latest .vscode/settings.json in the MSDK projects have made the following changes to add the binary to the path. Existing projects should make the same change.

--- a/.vscode/settings-old.json
+++ b/.vscode/settings.json
@@ -1,6 +1,6 @@
 {
     "terminal.integrated.env.windows": {
-        "Path":"${config:OCD_path};${config:ARM_GCC_path}/bin;${config:xPack_GCC_path}/bin;${config:Make_path};${env:PATH}",
+        "Path":"${config:OCD_path};${config:ARM_GCC_path}/bin;${config:xPack_GCC_path}/bin;${config:MSYS_path}/usr/bin;${config:Make_path};${env:PATH}",
         "MAXIM_PATH":"${config:MAXIM_PATH}"
     },
     "terminal.integrated.defaultProfile.windows": "Command Prompt",
@@ -33,7 +33,8 @@
     "OCD_path":"${config:MAXIM_PATH}/Tools/OpenOCD",
     "ARM_GCC_path":"${config:MAXIM_PATH}/Tools/GNUTools/${config:v_Arm_GCC}",
     "xPack_GCC_path":"${config:MAXIM_PATH}/Tools/xPack/riscv-none-elf-gcc/${config:v_xPack_GCC}",
-    "Make_path":"${config:MAXIM_PATH}/Tools/MSYS2/usr/bin",
+    "Make_path":"${config:MAXIM_PATH}/Tools/GNUTools/Make",
+    "MSYS_path":"${config:MAXIM_PATH}/Tools/MSYS2",

     "C_Cpp.default.includePath": [
         "${workspaceFolder}",

Verification

The following version string can be used to verify the PATH is set up correctly to load the native binaries.

$ make --version

GNU Make 4.4.1
Built for Windows32
Copyright (C) 1988-2023 Free Software Foundation, Inc.
License GPLv3+: GNU GPL version 3 or later <https://gnu.org/licenses/gpl.html>
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.

SDHC Fixes and FatFS Version Upgrade

As of #720 a critical bug in the SDHC library was fixed, which was causing SD cards to be formatted with the incorrect size. Support for FatFS version R0.15 has also been added to enable the exFAT format and higher capacity SDXC cards.

Users who would like to upgrade their projects to R0.15 can use the new FATFS_VERSION build configuration variable to ff15. The previous version (R0.13) has been left the default for this release.

FatFS changed the f_mkfs API to accept a format struct. Existing code can make the following change to comply with the new API:

-    if ((err = f_mkfs("", FM_ANY, 0, work, sizeof(work))) !=
+    MKFS_PARM format_options = {
+        .fmt = FM_ANY
+    };
+
+    if ((err = f_mkfs("", &format_options, work, sizeof(work))) !=
         FR_OK) {
         printf("Error formatting SD card: %s\n", FF_ERRORS[err]);
     }

New Command-Line Interface Library

  • As of #679, a pre-written UART CLI library is now available. Supporting documentation can be found in the MSDK User Guide

image


Helper String Added to Build Output

As of #742 the build system prints the following helper string to improve exposure to the MSDK's supporting documentation and resources.

****************************************************************************
* Analog Devices MSDK
* - User Guide: https://analog-devices-msdk.github.io/msdk/USERGUIDE/
* - Get Support: https://www.analog.com/support/technical-support.html
* - Report Issues: https://github.com/Analog-Devices-MSDK/msdk/issues
* - Contributing: https://analog-devices-msdk.github.io/msdk/CONTRIBUTING/
****************************************************************************

It can be disabled by setting SUPPRESS_HELP = 1 in the build system.


Other Bug Fixes and Improvements

  • fix(workflow): Make pull_request_template.md visible and update trigger-types for auto-labeler workflow by @sihyung-maxim in #647
  • fix(BLE): Struct used in volatile context now marked as volatile by @EricB-ADI in #645
  • docs(BLE): Update MTU configuration procedure by @EdwinFairchild in #636
  • fix(Examples): Fix return value logic for verifyData function in I2C examples by @Jacob-Scheiffler in #651
  • chore(Examples): Test examples on Rev. B production silicon for MAX32655 by @Jacob-Scheiffler in #649
  • fix(BLE,Examples): Log packet count on BLE dats speed test by @EdwinFairchild in #648
  • feat(Examples,MiscDrivers): Add OV5640 DVP camera driver by @vicloginov in #644
  • feat(workflow): Add new workflow for Releases by @ALofthou in #656
  • fix(Examples): Fix double-type subseconds calculation for MAX32655, MAX78000, and MAX78002 by @sihyung-maxim in #650
  • fix(workflow): Expand labeler file filters in case root of repo is unknown by @sihyung-maxim in #655
  • chore(Examples): Remove obsolete directories from project include paths by @ttmut in #659
  • feat(Examples): Update MAX32650 CLCD example to swap Maxim logo for ADI logo by @ronyaugustine in #658
  • fix(Boards): Add weak definition of GPIO0 IRQ handler to MAX32665's MAXREFDES178 BSP by @Jacob-Scheiffler in #664
  • fix(Build): Fix "empty.c file not found" Error on Make v3.81 or Older by @Jake-Carter in #657
  • fix(Build): Allow Users to Give Absolute Paths to SRCS by @Jake-Carter in #666
  • fix(workflow): Fix globstar paths in labeler workflow and revise PR template by @sihyung-maxim in #675
  • feat(Examples): Speedup TFT update in UNet-highres-demo and aisegment_unet-demo for MAX78000 by @aniktash in #670
  • fix(CMSIS, PeriphDrivers): Add support for all 16 PT channels in the MAX32690 by @Jacob-Scheiffler in #678
  • fix(ThirdParty): Fix Wrong Output Filename for lwIP Library by @Jake-Carter in #669
  • refactor(PeriphDrivers): Fix -Warray-bounds warnings for can and dma by @ozersa in #682
  • fix(Build): Link with libphy_hard.a when MFLOAT_ABI = hard by @khpeterson in #676
  • feat(Examples): MSDK-1220: Review and update SDK examples by @ttmut in #663
  • feat(Examples): Speedup TFT update for MAX78002 CameraIF by @vicloginov in #672
  • perf(PeriphDrivers): Reduce SPI_RevA Code Size by @Jake-Carter in #690
  • feat(PeriphDrivers): Provide user a way to manually drive SPI slave select pin by @ozersa in #674
  • fix(PeriphDrivers): Configure SPI0 pins for MAX32672 by @sihyung-maxim in #660
  • fix(CMSIS): Fix OWM_C...
Read more

June 2023 Release

30 Jun 17:02
0c7efe7
Compare
Choose a tag to compare

This is the June 2023 release of the MSDK.

Installation

See the "Installation" in the MSDK User Guide for instructions on installing the MSDK via the online installer.

For existing users, see the "Maintenance" section of the User Guide for instructions on updating the MSDK.

Offline installers tagged at this version of the MSDK are available at the bottom of this release page. Note: The offline installers have the same pre-requisites as the online installers that must be met before running.

What's Changed

RISC-V Toolchain Upgrade

C++ Support

  • Official support for C++ has been added to the MSDK.
  • The AUTOSEARCH mechanism of the build system will now search for .cpp files in the project to add to the build.
  • All microcontrollers now include a Hello_World_Cpp example demonstrating basic language features such as classes.
  • Add C++ Support, Add Basic C++ Example, Consolidate GCC Makefiles by @Jake-Carter in #619

Driver Files for Board Support Packages Move

  • Driver files for some Board Support Packages have been consolidated to the MiscDrivers folder as of _MiscDrivers: Update all boards to use PB, LED, and stdio source files in MiscDrivers. by @Jacob-Scheiffler in #587
  • The BSPs inside the MSDK have been updated to reflect this, but custom BSPs may throw missing file errors if they were using LED/PB/TFT/stdio drivers from the old location.

To resolve these errors, add the updated locations of the source files of your board.mk of your BSP. If these files are included from your project only, add these locations to your project.mk file.

# Locate MiscDrivers directory
MISC_DRIVERS_DIR ?= $(MAXIM_PATH)/Libraries/MiscDrivers

# Note:  The following additions add all of the MiscDrivers folders to the build.
# You probably don't need all of them.

# Add MiscDrivers folders to search for source files
VPATH += $(MISC_DRIVERS_DIR)
VPATH += $(MISC_DRIVERS_DIR)/ADC
VPATH += $(MISC_DRIVERS_DIR)/BarcodeDecoder
VPATH += $(MISC_DRIVERS_DIR)/Camera
VPATH += $(MISC_DRIVERS_DIR)/CODEC
VPATH += $(MISC_DRIVERS_DIR)/Display
VPATH += $(MISC_DRIVERS_DIR)/ExtMemory
VPATH += $(MISC_DRIVERS_DIR)/LED
VPATH += $(MISC_DRIVERS_DIR)/PMIC
VPATH += $(MISC_DRIVERS_DIR)/PushButton
VPATH += $(MISC_DRIVERS_DIR)/TempSensor
VPATH += $(MISC_DRIVERS_DIR)/Touchscreen

# Add MiscDrivers folder to search for header files
IPATH += $(MISC_DRIVERS_DIR)
IPATH += $(MISC_DRIVERS_DIR)/ADC
IPATH += $(MISC_DRIVERS_DIR)/BarcodeDecoder
IPATH += $(MISC_DRIVERS_DIR)/Camera
IPATH += $(MISC_DRIVERS_DIR)/CODEC
IPATH += $(MISC_DRIVERS_DIR)/Display
IPATH += $(MISC_DRIVERS_DIR)/ExtMemory
IPATH += $(MISC_DRIVERS_DIR)/LED
IPATH += $(MISC_DRIVERS_DIR)/PMIC
IPATH += $(MISC_DRIVERS_DIR)/PushButton
IPATH += $(MISC_DRIVERS_DIR)/TempSensor
IPATH += $(MISC_DRIVERS_DIR)/Touchscreen

Build System Improvements

  • "project.mk" is now a tracked file in the dependency graph for the build. When a change is made to project.mk, the project will automatically rebuild. (Rebuild Project when project.mk Changes by @Jake-Carter in #591)
  • User's ability to create custom BSPs and load them from directories outside of the MSDK has been improved. (Allow Users to Set BSP Search Directory, Make mxc.h Safe Against LIB_BOARD=0, Remove MiscDrivers Files from mxc.h by @Jake-Carter in #613)
  • BLE project build times have been reduced by packing Cordio as a static library file. (Build Cordio as a Library File by @kevin-gillespie in #492)
  • A new rule for generating a project_defines.h file with build-time and compiler-specific definitions has been added (Update Project Files by @Jake-Carter in #628)
  • Allow Overriding Linkerfile for SBT Projects by @Jake-Carter in #592
  • Makefile targets for flashing have been added (ex make flash.openocd) (Added Makefile targets for flashing. by @kevin-gillespie in #519)

VS Code Project File Update

Library Updates

Other Notable Features

  • CSI2/ImgCapture Image Processing Pipeline Rework, New MAX78002 QSPI Example, New RetinaNet Example by @Jake-Carter in #583
  • Add GPIO3 support to MAX32655, MAX32680, MAX78000, and MAX78002 by @Jacob-Scheiffler in #597
  • Update HART UART with new transmit features and fixes for MAX32675 and MAX32680 by @jdk-maxim in #600
  • Add Cordio API to get Bluetooth MAC address, trace output of MAC address and advertising name for MAX32655, MAX32665, MAX32690 by @EdwinFairchild in #615
  • Update AppSwitcher example to use new features with External Flash instead of SDHC by @MertCanBoz1 in #571
  • Add Facial Recognition Demo for MAX78000FTHR by @vicloginov in #569
  • Add MAX78000CAM01 Board Support, Add CAM01 Face Detection Demo, Move Debayering Implementation by @Jake-Carter in #611
  • Add SPI v2 Implementation to MAX78002 by @sihyung-maxim in #632
  • Add Examples for Building and Using Static Libraries by @ttmut in #476, #543

Other Changes & Bug Fixes

Read more

March 2023 Release

21 Mar 02:11
1438fa7
Compare
Choose a tag to compare

To install the SDK:

  1. Download and extract the installer for your chosen operating system.

  2. On Linux, retrieve the installer's dependencies before running the installer. These are required by the QT installer framework even on headless systems.

sudo apt install libxcb-glx0 libxcb-icccm4 libxcb-image0 libxcb-shm0 libxcb-util1 libxcb-keysyms1 libxcb-randr0 libxcb-render-util0 libxcb-render0 libxcb-shape0 libxcb-sync1 libxcb-xfixes0 libxcb-xinerama0 libxcb-xkb1 libxcb1 libxkbcommon-x11-0 libxkbcommon0 libgl1 libusb-0.1-4 libhidapi-libusb0 libhidapi-hidraw0
  1. Run the included MaximMicrosSDK_2023_03 executable.

What's Changed

New Contributors

Full Changelog: v2022_11_Release...v2023_03_Release

November 2022 Release

29 Nov 19:25
63cbd56
Compare
Choose a tag to compare

Initial GitHub based release. To install the SDK:

  1. Download and extract the installer for your chosen operating system.

  2. On Linux, retrieve the installer's dependencies before running the installer. These are required by the QT installer framework even on headless systems.

sudo apt install libxcb-glx0 libxcb-icccm4 libxcb-image0 libxcb-shm0 libxcb-util1 libxcb-keysyms1 libxcb-randr0 libxcb-render-util0 libxcb-render0 libxcb-shape0 libxcb-sync1 libxcb-xfixes0 libxcb-xinerama0 libxcb-xkb1 libxcb1 libxkbcommon-x11-0 libxkbcommon0 libgl1 libusb-0.1-4 libhidapi-libusb0 libhidapi-hidraw0
  1. Run the included MaximMicrosSDK_2022_11 executable.