-
Notifications
You must be signed in to change notification settings - Fork 8.2k
TI MSPM0 SoC series Support #88725
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Merged
Merged
TI MSPM0 SoC series Support #88725
Changes from all commits
Commits
Show all changes
12 commits
Select commit
Hold shift + click to select a range
ee0f23f
west: west.yml pointed to ti_hal with MSPM0 support
ssekar15 d1f99e2
soc: mspm0: Add a support for TI MSPM0-G series SoC
ssekar15 144ebbf
dts: ti: mspm0: Add a support for TI MSPMO-G series SoC
ssekar15 82aa831
drivers: clock: ti: Add initial support TI MSPM0 clock module
ssekar15 6f9a70d
dts: arm: ti: mspm0: Add a support for MSPM0 clock module
ssekar15 37f4d84
drivers: pinctrl: mspm0: Add a pinctrl driver for TI MSPM0
ssekar15 6834f73
drivers: gpio: mspm0: Add a gpio support for MSPM0 family
ssekar15 1b25c7f
dts: arm: mspm0: Add pinctrl and gpio entry for MSPM0
ssekar15 d520a01
drivers: serial: Add initial support TI MSPM0 UART
ssekar15 58534c5
dts: arm: ti: mspm0: Add a support for uart
ssekar15 bfd82c7
boards: ti: lp_mspm0g3507: Add initial support TI LP_MSPM0G3507 board
ssekar15 ac60c15
MAINTAINERS: Add maintainers for Texas Instruments MSPM0
ssekar15 File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains hidden or 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 hidden or 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,5 @@ | ||
| # Copyright (c) 2025 Texas Instruments | ||
| # SPDX-License-Identifier: Apache-2.0 | ||
|
|
||
| config BOARD_LP_MSPM0G3507 | ||
| select SOC_MSPM0G3507 |
This file contains hidden or 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,5 @@ | ||
| # SPDX-License-Identifier: Apache-2.0 | ||
|
|
||
| board_runner_args(jlink "--device=MSPM0G3507" "--speed=4000") | ||
| include(${ZEPHYR_BASE}/boards/common/openocd.board.cmake) | ||
| include(${ZEPHYR_BASE}/boards/common/jlink.board.cmake) |
This file contains hidden or 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,6 @@ | ||
| board: | ||
| name: lp_mspm0g3507 | ||
| full_name: MSPM0G3507 Launchpad | ||
| vendor: ti | ||
| socs: | ||
| - name: mspm0g3507 |
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 hidden or 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,160 @@ | ||
| .. zephyr:board:: lp_mspm0g3507 | ||
|
|
||
| Overview | ||
| ******** | ||
|
|
||
| MSPM0G350x microcontrollers (MCUs) are part of the MSP highly integrated, ultra-low-power 32-bit MCU | ||
| family based on the enhanced Arm® Cortex®-M0+ 32-bit core platform operating at up to 80-MHz frequency. | ||
| These cost-optimized MCUs offer high-performance analog peripheral integration, support extended temperature | ||
| ranges from -40°C to 125°C, and operate with supply voltages ranging from 1.62 V to 3.6 V. | ||
|
|
||
| The MSPM0G350x devices provide up to 128KB embedded flash program memory with built-in error correction | ||
| code (ECC) and up to 32KB SRAM with a hardware parity option. These MCUs also incorporate a | ||
| memory protection unit, 7-channel DMA, math accelerator, and a variety of peripherals including | ||
|
|
||
| * Analog. | ||
|
|
||
| * Two 12-bit 4-Msps ADCs. | ||
|
|
||
| * Configurable internal shared voltage reference. | ||
|
|
||
| * One 12-bit 1-Msps DAC. | ||
|
|
||
| * Three high speed comparators with built-in reference DACs. | ||
|
|
||
| * Two zero-drift zero-crossover op-amps with programmable gain. | ||
|
|
||
| * Digital. | ||
|
|
||
| * Two 16-bit advanced control timers. | ||
|
|
||
| * Five general-purpose timers. | ||
|
|
||
| * One 16-bit general-purpose timer for QEI interface. | ||
|
|
||
| * One 32-bit high resolution general-purpose timer. | ||
|
|
||
| * Two 16-bit timers with deadband support and up to 12 PWM Channels. | ||
|
|
||
| * Two windowed-watchdog timers. | ||
|
|
||
| * One RTC with alarm and calendar modes. | ||
|
|
||
| * Data Integrity and Encryption. | ||
|
|
||
| * One AES HW accelerator capable of CTR, CBC, and ECB modes. | ||
|
|
||
| * One Cyclic Redundancy Check (CRC) accelerator. | ||
|
|
||
| * One True Random Number Generator (TRNG). | ||
|
|
||
| * Communication. | ||
|
|
||
| * Four UARTs, one with support for advanced modes such as LIN and Manchester. | ||
|
|
||
| * Two I2C supporting SMBUS/PMBUS and speeds up to FM+ (1Mbits/s). | ||
|
|
||
| * Two SPI, one with max speed 32Mbits/s. | ||
|
|
||
| * One CAN interface supporting CAN 2.0 A or B and CAN-FD. | ||
|
|
||
| .. image:: img/lp_mspm0g3507.webp | ||
| :align: center | ||
| :alt: MSPM0G3507 LaunchPad development board | ||
|
|
||
| Zephyr uses the ``lp_mspm0g3507`` board for building LP_MSPM0G3507 | ||
|
|
||
| Features: | ||
| ********* | ||
|
|
||
| - Onboard XDS110 debug probe | ||
| - EnergyTrace technology available for ultra-low-power debugging | ||
| - 2 buttons, 1 LED and 1 RGB LED for user interaction | ||
| - Temperature sensor circuit | ||
| - Light sensor circuit | ||
| - External OPA2365 (default buffer mode) for ADC (up to 4 Msps) evaluation | ||
| - Onboard 32.768-kHz and 40-MHz crystals | ||
| - RC filter for ADC input (unpopulated by default) | ||
|
|
||
| Details on the MSPM0G3507 LaunchPad can be found on the `TI LP_MSPM0G3507 Product Page`_. | ||
|
|
||
| Supported Features | ||
| ================== | ||
|
|
||
| .. zephyr:board-supported-hw:: | ||
|
|
||
| Building and Flashing | ||
| ********************* | ||
|
|
||
| Building | ||
| ======== | ||
|
|
||
| Follow the :ref:`getting_started` instructions for Zephyr application development. | ||
|
|
||
| For example, to build the blinky application for the MSPM0G3507 LaunchPad: | ||
|
|
||
| .. zephyr-app-commands:: | ||
| :zephyr-app: samples/hello_world | ||
| :board: lp_mspm0g3507 | ||
| :goals: build | ||
|
|
||
| The resulting ``zephyr.bin`` binary in the build directory can be flashed onto | ||
| MSPM0G3507 LaunchPad using the steps mentioned below. | ||
|
|
||
| Flashing | ||
| ======== | ||
|
|
||
| Open OCD is used to program the flash memory on the devices. It may be necessary in | ||
| earlier versions to use a branch of open OCD onto the device. | ||
|
|
||
| Before OpenOCD is public, one can clone `This Repo <https://github.com/openocd-org/openocd.git>`_, | ||
| and then this can be built with | ||
|
|
||
| ``` | ||
| cd <cloned_OPENOCD_dir> | ||
| ./bootstrap (when building from the git repository) | ||
| ./configure | ||
| make | ||
| sudo make install | ||
| ``` | ||
|
|
||
| Then after the build, it is possible to flash the device by passing additional arguments to the flash command | ||
|
|
||
| ``` | ||
| west flash --openocd <path to cloned dir>/src/openocd --openocd-search <path to cloned dir>/tcl | ||
| ``` | ||
|
|
||
| Flashing using JLINK | ||
|
|
||
| ``` | ||
| west flash --runner=jlink | ||
| ``` | ||
|
|
||
| Debugging | ||
| ========= | ||
|
|
||
| You can debug an application in the usual way. Here is an example for the | ||
| :zephyr:code-sample:`hello_world` application. | ||
|
|
||
| .. zephyr-app-commands:: | ||
| :zephyr-app: samples/hello_world | ||
| :board: lp_mspm0g3507 | ||
| :goals: debug | ||
|
|
||
| References | ||
| ********** | ||
|
|
||
| TI MSPM0 MCU Page: | ||
| https://www.ti.com/microcontrollers-mcus-processors/arm-based-microcontrollers/arm-cortex-m0-mcus/overview.html | ||
|
|
||
| TI MSPM0G3507 Product Page: | ||
| https://www.ti.com/product/MSPM0G3507 | ||
|
|
||
| TI MSPM0 SDK: | ||
| https://www.ti.com/tool/MSPM0-SDK | ||
|
|
||
| .. _MSPM0G3507 TRM: | ||
| https://www.ti.com/lit/slau846 | ||
|
|
||
| .. _TI LP_MSPM0G3507 Product Page: | ||
| https://www.ti.com/tool/LP-MSPM0G3507 | ||
This file contains hidden or 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,107 @@ | ||
| /* | ||
| * Copyright (c) 2025 Texas Instruments | ||
| * Copyright (c) 2025 Linumiz | ||
| * | ||
| * SPDX-License-Identifier: Apache-2.0 | ||
| */ | ||
|
|
||
| /dts-v1/; | ||
|
|
||
| #include <ti/mspm0/g/mspm0g3507.dtsi> | ||
| #include <ti/mspm0/g/mspm0g1x0x_g3x0x-pinctrl.dtsi> | ||
| #include <zephyr/dt-bindings/clock/mspm0_clock.h> | ||
| #include <zephyr/dt-bindings/gpio/gpio.h> | ||
|
|
||
| / { | ||
| model = "TI LP_MSPM0G3507/MSPM0G3507"; | ||
| compatible = "ti,mspm0g3507"; | ||
|
|
||
| aliases { | ||
| led0 = &led0; | ||
| }; | ||
|
|
||
| chosen { | ||
| zephyr,sram = &sram0; | ||
| zephyr,flash = &flash0; | ||
| zephyr,console = &uart0; | ||
| zephyr,shell-uart = &uart0; | ||
| zephyr,code-partition = &slot0_partition; | ||
| }; | ||
|
|
||
| leds { | ||
| compatible = "gpio-leds"; | ||
|
|
||
| led0: led_0 { | ||
ssekar15 marked this conversation as resolved.
Show resolved
Hide resolved
|
||
| gpios = <&gpiob 22 GPIO_ACTIVE_HIGH>; | ||
| label = "Blue LED"; | ||
| }; | ||
| }; | ||
| }; | ||
|
|
||
| &cpu0 { | ||
| clock-frequency = <DT_FREQ_M(80)>; | ||
| }; | ||
|
|
||
| &ulpclk { | ||
| clock-frequency = <DT_FREQ_M(40)>; | ||
| clk-div = <2>; | ||
| }; | ||
|
|
||
| &mclk { | ||
| clock-frequency = <DT_FREQ_M(80)>; | ||
| clocks = <&hsclk 0>; | ||
| }; | ||
|
|
||
| &hsclk { | ||
| clocks = <&syspll2x 0>; | ||
| status = "okay"; | ||
| }; | ||
|
|
||
| &syspll2x { | ||
| status = "okay"; | ||
| }; | ||
|
|
||
| &flash0 { | ||
| status = "okay"; | ||
|
|
||
| partitions { | ||
ssekar15 marked this conversation as resolved.
Show resolved
Hide resolved
|
||
| compatible = "fixed-partitions"; | ||
| #address-cells = <1>; | ||
| #size-cells = <1>; | ||
|
|
||
| boot_partition: partition@0 { | ||
| label = "mcuboot"; | ||
| reg = <0x00000000 0x8000>; | ||
| }; | ||
|
|
||
| slot0_partition: partition@8000 { | ||
| label = "image-0"; | ||
| reg = <0x00008000 0xC000>; | ||
| }; | ||
|
|
||
| slot1_partition: partition@14000 { | ||
| label = "image-1"; | ||
| reg = <0x00014000 0xC000>; | ||
| }; | ||
| }; | ||
| }; | ||
|
|
||
| &pinctrl { | ||
| status = "okay"; | ||
| }; | ||
|
|
||
| &gpioa { | ||
| status = "okay"; | ||
| }; | ||
|
|
||
| &gpiob { | ||
| status = "okay"; | ||
| }; | ||
|
|
||
| &uart0 { | ||
| status = "okay"; | ||
|
|
||
| current-speed = <115200>; | ||
| pinctrl-0 = <&uart0_tx_pa10 &uart0_rx_pa11>; | ||
| pinctrl-names = "default"; | ||
| }; | ||
This file contains hidden or 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 @@ | ||
| identifier: lp_mspm0g3507 | ||
| name: TI MSPM0G3507 Launchpad | ||
| type: mcu | ||
| arch: arm | ||
| toolchain: | ||
| - zephyr | ||
| - gnuarmemb | ||
| - xtools | ||
| ram: 32 | ||
| flash: 128 | ||
| supported: | ||
| - uart | ||
| - gpio | ||
| vendor: ti |
This file contains hidden or 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,10 @@ | ||
| # SPDX-License-Identifier: Apache-2.0 | ||
|
|
||
| # Enable UART driver | ||
| CONFIG_SERIAL=y | ||
|
|
||
| # Enable Console | ||
| CONFIG_CONSOLE=y | ||
| CONFIG_UART_CONSOLE=y | ||
|
|
||
| CONFIG_CLOCK_CONTROL=y |
This file contains hidden or 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,4 @@ | ||
| source [find interface/xds110.cfg] | ||
| adapter speed 10000 | ||
|
|
||
| source [find target/ti_mspm0.cfg] |
This file contains hidden or 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 hidden or 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 hidden or 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,11 @@ | ||
| # TI MSPM0 Family | ||
|
|
||
| # Copyright (c) 2025, Texas Instruments Inc. | ||
| # SPDX-License-Identifier: Apache-2.0 | ||
|
|
||
| config CLOCK_CONTROL_MSPM0 | ||
| bool "TI MSPM0 clock" | ||
| default y | ||
| depends on SOC_FAMILY_TI_MSPM0 | ||
| help | ||
| This option enables the TI MSPM0 Clock Control Enabler |
Oops, something went wrong.
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Uh oh!
There was an error while loading. Please reload this page.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just noticed this -- this is not correct for ReStructuredText format, please use
.. code-block ::Please fix in a follow-up PR