Bunny brain board created, but not modified yet
Bunny brain board created, but not modified yet
This commit is contained in:
		
							
								
								
									
										21
									
								
								hw/bsp/mcx/boards/bunny-brain/board.cmake
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								hw/bsp/mcx/boards/bunny-brain/board.cmake
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | |||||||
|  | set(MCU_VARIANT MCXN947) | ||||||
|  | set(MCU_CORE MCXN947_cm33_core0) | ||||||
|  |  | ||||||
|  | set(JLINK_DEVICE MCXN947_M33_0) | ||||||
|  | set(PYOCD_TARGET MCXN947) | ||||||
|  | set(NXPLINK_DEVICE MCXN947:MCXN947) | ||||||
|  |  | ||||||
|  | set(PORT 1) | ||||||
|  |  | ||||||
|  | function(update_board TARGET) | ||||||
|  |   target_compile_definitions(${TARGET} PUBLIC | ||||||
|  |     CPU_MCXN947VDF_cm33_core0 | ||||||
|  |     BOARD_TUD_RHPORT=${PORT} | ||||||
|  |     # port 0 is fullspeed, port 1 is highspeed | ||||||
|  |     BOARD_TUD_MAX_SPEED=$<IF:${PORT},OPT_MODE_HIGH_SPEED,OPT_MODE_FULL_SPEED> | ||||||
|  |     ) | ||||||
|  |   target_sources(${TARGET} PUBLIC | ||||||
|  |     ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/clock_config.c | ||||||
|  |     ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/pin_mux.c | ||||||
|  |     ) | ||||||
|  | endfunction() | ||||||
							
								
								
									
										66
									
								
								hw/bsp/mcx/boards/bunny-brain/board.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								hw/bsp/mcx/boards/bunny-brain/board.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,66 @@ | |||||||
|  | /* | ||||||
|  |  * The MIT License (MIT) | ||||||
|  |  * | ||||||
|  |  * Copyright (c) 2021, Ha Thach (tinyusb.org) | ||||||
|  |  * | ||||||
|  |  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||||
|  |  * of this software and associated documentation files (the "Software"), to deal | ||||||
|  |  * in the Software without restriction, including without limitation the rights | ||||||
|  |  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||||
|  |  * copies of the Software, and to permit persons to whom the Software is | ||||||
|  |  * furnished to do so, subject to the following conditions: | ||||||
|  |  * | ||||||
|  |  * The above copyright notice and this permission notice shall be included in | ||||||
|  |  * all copies or substantial portions of the Software. | ||||||
|  |  * | ||||||
|  |  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||||
|  |  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||||
|  |  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||||
|  |  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||||
|  |  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||||
|  |  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||||
|  |  * THE SOFTWARE. | ||||||
|  |  * | ||||||
|  |  * This file is part of the TinyUSB stack. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | #ifndef BOARD_H_ | ||||||
|  | #define BOARD_H_ | ||||||
|  |  | ||||||
|  | #ifdef __cplusplus | ||||||
|  |  extern "C" { | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | // LED | ||||||
|  | #define LED_GPIO              GPIO3 | ||||||
|  | #define LED_CLK               kCLOCK_Gpio3 | ||||||
|  | #define LED_PIN               4 // red | ||||||
|  | #define LED_STATE_ON          0 | ||||||
|  |  | ||||||
|  | // WAKE button (Dummy, use unused pin | ||||||
|  | #define BUTTON_GPIO           GPIO0 | ||||||
|  | #define BUTTON_CLK            kCLOCK_Gpio0 | ||||||
|  | #define BUTTON_PIN            6 | ||||||
|  | #define BUTTON_STATE_ACTIVE   0 | ||||||
|  |  | ||||||
|  | // UART | ||||||
|  | #define UART_DEV              LPUART4 | ||||||
|  |  | ||||||
|  | static inline void board_uart_init_clock(void) { | ||||||
|  |   /* attach FRO 12M to FLEXCOMM4 */ | ||||||
|  |   CLOCK_SetClkDiv(kCLOCK_DivFlexcom4Clk, 1u); | ||||||
|  |   CLOCK_AttachClk(kFRO12M_to_FLEXCOMM4); | ||||||
|  |   RESET_ClearPeripheralReset(kFC4_RST_SHIFT_RSTn); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | //#define UART_RX_PINMUX        0, 24, IOCON_PIO_DIG_FUNC1_EN | ||||||
|  | //#define UART_TX_PINMUX        0, 25, IOCON_PIO_DIG_FUNC1_EN | ||||||
|  |  | ||||||
|  | // XTAL | ||||||
|  | #define XTAL0_CLK_HZ          (24 * 1000 * 1000U) | ||||||
|  |  | ||||||
|  | #ifdef __cplusplus | ||||||
|  |  } | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #endif | ||||||
							
								
								
									
										11
									
								
								hw/bsp/mcx/boards/bunny-brain/board.mk
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								hw/bsp/mcx/boards/bunny-brain/board.mk
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | |||||||
|  | MCU_VARIANT = MCXN947 | ||||||
|  | MCU_CORE = MCXN947_cm33_core0 | ||||||
|  | PORT ?= 1 | ||||||
|  |  | ||||||
|  | CFLAGS += -DCPU_MCXN947VDF_cm33_core0 | ||||||
|  |  | ||||||
|  | JLINK_DEVICE = MCXN947_M33_0 | ||||||
|  | PYOCD_TARGET = MCXN947 | ||||||
|  |  | ||||||
|  | # flash using pyocd | ||||||
|  | flash: flash-jlink | ||||||
							
								
								
									
										338
									
								
								hw/bsp/mcx/boards/bunny-brain/clock_config.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										338
									
								
								hw/bsp/mcx/boards/bunny-brain/clock_config.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,338 @@ | |||||||
|  | /* | ||||||
|  |  * Copyright 2022 NXP | ||||||
|  |  * All rights reserved. | ||||||
|  |  * | ||||||
|  |  * SPDX-License-Identifier: BSD-3-Clause | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | /*********************************************************************************************************************** | ||||||
|  |  * This file was generated by the MCUXpresso Config Tools. Any manual edits made to this file | ||||||
|  |  * will be overwritten if the respective MCUXpresso Config Tools is used to update this file. | ||||||
|  |  **********************************************************************************************************************/ | ||||||
|  | /* | ||||||
|  |  * How to setup clock using clock driver functions: | ||||||
|  |  * | ||||||
|  |  * 1. Setup clock sources. | ||||||
|  |  * | ||||||
|  |  * 2. Set up wait states of the flash. | ||||||
|  |  * | ||||||
|  |  * 3. Set up all dividers. | ||||||
|  |  * | ||||||
|  |  * 4. Set up all selectors to provide selected clocks. | ||||||
|  |  * | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | /* clang-format off */ | ||||||
|  | /* TEXT BELOW IS USED AS SETTING FOR TOOLS ************************************* | ||||||
|  | !!GlobalInfo | ||||||
|  | product: Clocks v10.0 | ||||||
|  | processor: MCXN947 | ||||||
|  | package_id: MCXN947VDF | ||||||
|  | mcu_data: ksdk2_0 | ||||||
|  | processor_version: 0.12.3 | ||||||
|  | board: MCX-N9XX-EVK | ||||||
|  |  * BE CAREFUL MODIFYING THIS COMMENT - IT IS YAML SETTINGS FOR TOOLS **********/ | ||||||
|  | /* clang-format on */ | ||||||
|  |  | ||||||
|  | #include "clock_config.h" | ||||||
|  | #include "fsl_clock.h" | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  * Definitions | ||||||
|  |  ******************************************************************************/ | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  * Variables | ||||||
|  |  ******************************************************************************/ | ||||||
|  | /* System clock frequency. */ | ||||||
|  | // extern uint32_t SystemCoreClock; | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  ************************ BOARD_InitBootClocks function ************************ | ||||||
|  |  ******************************************************************************/ | ||||||
|  | void BOARD_InitBootClocks(void) | ||||||
|  | { | ||||||
|  |     BOARD_BootClockPLL150M(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  ******************** Configuration BOARD_BootClockFRO12M ********************** | ||||||
|  |  ******************************************************************************/ | ||||||
|  | /* clang-format off */ | ||||||
|  | /* TEXT BELOW IS USED AS SETTING FOR TOOLS ************************************* | ||||||
|  | !!Configuration | ||||||
|  | name: BOARD_BootClockFRO12M | ||||||
|  | outputs: | ||||||
|  | - {id: CLK_144M_clock.outFreq, value: 144 MHz} | ||||||
|  | - {id: CLK_48M_clock.outFreq, value: 48 MHz} | ||||||
|  | - {id: FRO_12M_clock.outFreq, value: 12 MHz} | ||||||
|  | - {id: MAIN_clock.outFreq, value: 12 MHz} | ||||||
|  | - {id: Slow_clock.outFreq, value: 3 MHz} | ||||||
|  | - {id: System_clock.outFreq, value: 12 MHz} | ||||||
|  | - {id: gdet_clock.outFreq, value: 48 MHz} | ||||||
|  | - {id: trng_clock.outFreq, value: 48 MHz} | ||||||
|  | settings: | ||||||
|  | - {id: SCGMode, value: SIRC} | ||||||
|  | - {id: SCG.SCSSEL.sel, value: SCG.SIRC} | ||||||
|  | - {id: SCG_FIRCCSR_FIRCEN_CFG, value: Disabled} | ||||||
|  | - {id: SYSCON.FREQMEREFCLKSEL.sel, value: SYSCON.evtg_out0a} | ||||||
|  | - {id: SYSCON.FREQMETARGETCLKSEL.sel, value: SYSCON.evtg_out0a} | ||||||
|  |  * BE CAREFUL MODIFYING THIS COMMENT - IT IS YAML SETTINGS FOR TOOLS **********/ | ||||||
|  | /* clang-format on */ | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  * Variables for BOARD_BootClockFRO12M configuration | ||||||
|  |  ******************************************************************************/ | ||||||
|  | /******************************************************************************* | ||||||
|  |  * Code for BOARD_BootClockFRO12M configuration | ||||||
|  |  ******************************************************************************/ | ||||||
|  | void BOARD_BootClockFRO12M(void) | ||||||
|  | { | ||||||
|  |     /*!< Enable SCG clock */ | ||||||
|  |     CLOCK_EnableClock(kCLOCK_Scg); | ||||||
|  |  | ||||||
|  |     /*!< Set up clock selectors - Attach clocks to the peripheries */ | ||||||
|  |     CLOCK_AttachClk(kFRO12M_to_MAIN_CLK);                 /*!< Switch MAIN_CLK to FRO12M */ | ||||||
|  |  | ||||||
|  |     /*!< Set up dividers */ | ||||||
|  |     CLOCK_SetClkDiv(kCLOCK_DivAhbClk, 1U);           /*!< Set AHBCLKDIV divider to value 1 */ | ||||||
|  |  | ||||||
|  |     /* Set SystemCoreClock variable */ | ||||||
|  |     SystemCoreClock = BOARD_BOOTCLOCKFRO12M_CORE_CLOCK; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  ******************* Configuration BOARD_BootClockFROHF48M ********************* | ||||||
|  |  ******************************************************************************/ | ||||||
|  | /* clang-format off */ | ||||||
|  | /* TEXT BELOW IS USED AS SETTING FOR TOOLS ************************************* | ||||||
|  | !!Configuration | ||||||
|  | name: BOARD_BootClockFROHF48M | ||||||
|  | outputs: | ||||||
|  | - {id: CLK_144M_clock.outFreq, value: 144 MHz} | ||||||
|  | - {id: CLK_48M_clock.outFreq, value: 48 MHz} | ||||||
|  | - {id: FRO_12M_clock.outFreq, value: 12 MHz} | ||||||
|  | - {id: FRO_HF_clock.outFreq, value: 48 MHz} | ||||||
|  | - {id: MAIN_clock.outFreq, value: 48 MHz} | ||||||
|  | - {id: Slow_clock.outFreq, value: 12 MHz} | ||||||
|  | - {id: System_clock.outFreq, value: 48 MHz} | ||||||
|  | - {id: gdet_clock.outFreq, value: 48 MHz} | ||||||
|  | - {id: trng_clock.outFreq, value: 48 MHz} | ||||||
|  | settings: | ||||||
|  | - {id: SYSCON.FLEXCAN0CLKSEL.sel, value: NO_CLOCK} | ||||||
|  | - {id: SYSCON.FLEXCAN1CLKSEL.sel, value: NO_CLOCK} | ||||||
|  | - {id: SYSCON.FREQMEREFCLKSEL.sel, value: SYSCON.evtg_out0a} | ||||||
|  | - {id: SYSCON.FREQMETARGETCLKSEL.sel, value: SYSCON.evtg_out0a} | ||||||
|  |  * BE CAREFUL MODIFYING THIS COMMENT - IT IS YAML SETTINGS FOR TOOLS **********/ | ||||||
|  | /* clang-format on */ | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  * Variables for BOARD_BootClockFROHF48M configuration | ||||||
|  |  ******************************************************************************/ | ||||||
|  | /******************************************************************************* | ||||||
|  |  * Code for BOARD_BootClockFROHF48M configuration | ||||||
|  |  ******************************************************************************/ | ||||||
|  | void BOARD_BootClockFROHF48M(void) | ||||||
|  | { | ||||||
|  |     /*!< Enable SCG clock */ | ||||||
|  |     CLOCK_EnableClock(kCLOCK_Scg); | ||||||
|  |  | ||||||
|  |     CLOCK_SetupFROHFClocking(48000000U);                /*!< Enable FRO HF(48MHz) output */ | ||||||
|  |  | ||||||
|  |     /*!< Set up clock selectors - Attach clocks to the peripheries */ | ||||||
|  |     CLOCK_AttachClk(kFRO_HF_to_MAIN_CLK);                 /*!< Switch MAIN_CLK to FRO_HF */ | ||||||
|  |  | ||||||
|  |     /*!< Set up dividers */ | ||||||
|  |     CLOCK_SetClkDiv(kCLOCK_DivAhbClk, 1U);           /*!< Set AHBCLKDIV divider to value 1 */ | ||||||
|  |  | ||||||
|  |     /* Set SystemCoreClock variable */ | ||||||
|  |     SystemCoreClock = BOARD_BOOTCLOCKFROHF48M_CORE_CLOCK; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  ******************* Configuration BOARD_BootClockFROHF144M ******************** | ||||||
|  |  ******************************************************************************/ | ||||||
|  | /* clang-format off */ | ||||||
|  | /* TEXT BELOW IS USED AS SETTING FOR TOOLS ************************************* | ||||||
|  | !!Configuration | ||||||
|  | name: BOARD_BootClockFROHF144M | ||||||
|  | outputs: | ||||||
|  | - {id: CLK_144M_clock.outFreq, value: 144 MHz} | ||||||
|  | - {id: CLK_48M_clock.outFreq, value: 48 MHz} | ||||||
|  | - {id: FRO_12M_clock.outFreq, value: 12 MHz} | ||||||
|  | - {id: FRO_HF_clock.outFreq, value: 144 MHz} | ||||||
|  | - {id: MAIN_clock.outFreq, value: 144 MHz} | ||||||
|  | - {id: Slow_clock.outFreq, value: 18 MHz} | ||||||
|  | - {id: System_clock.outFreq, value: 72 MHz} | ||||||
|  | - {id: gdet_clock.outFreq, value: 48 MHz} | ||||||
|  | - {id: trng_clock.outFreq, value: 48 MHz} | ||||||
|  | settings: | ||||||
|  | - {id: SYSCON.AHBCLKDIV.scale, value: '2', locked: true} | ||||||
|  | - {id: SYSCON.FLEXCAN0CLKSEL.sel, value: NO_CLOCK} | ||||||
|  | - {id: SYSCON.FLEXCAN1CLKSEL.sel, value: NO_CLOCK} | ||||||
|  | - {id: SYSCON.FREQMEREFCLKSEL.sel, value: SYSCON.evtg_out0a} | ||||||
|  | - {id: SYSCON.FREQMETARGETCLKSEL.sel, value: SYSCON.evtg_out0a} | ||||||
|  | sources: | ||||||
|  | - {id: SCG.FIRC.outFreq, value: 144 MHz} | ||||||
|  |  * BE CAREFUL MODIFYING THIS COMMENT - IT IS YAML SETTINGS FOR TOOLS **********/ | ||||||
|  | /* clang-format on */ | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  * Variables for BOARD_BootClockFROHF144M configuration | ||||||
|  |  ******************************************************************************/ | ||||||
|  | /******************************************************************************* | ||||||
|  |  * Code for BOARD_BootClockFROHF144M configuration | ||||||
|  |  ******************************************************************************/ | ||||||
|  | void BOARD_BootClockFROHF144M(void) | ||||||
|  | { | ||||||
|  |     /*!< Enable SCG clock */ | ||||||
|  |     CLOCK_EnableClock(kCLOCK_Scg); | ||||||
|  |  | ||||||
|  |     CLOCK_SetupFROHFClocking(144000000U);               /*!< Enable FRO HF(144MHz) output */ | ||||||
|  |  | ||||||
|  |     /*!< Set up clock selectors - Attach clocks to the peripheries */ | ||||||
|  |     CLOCK_AttachClk(kFRO_HF_to_MAIN_CLK);                 /*!< Switch MAIN_CLK to FRO_HF */ | ||||||
|  |  | ||||||
|  |     /*!< Set up dividers */ | ||||||
|  |     CLOCK_SetClkDiv(kCLOCK_DivAhbClk, 2U);           /*!< Set AHBCLKDIV divider to value 2 */ | ||||||
|  |  | ||||||
|  |     /* Set SystemCoreClock variable */ | ||||||
|  |     SystemCoreClock = BOARD_BOOTCLOCKFROHF144M_CORE_CLOCK; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  ******************** Configuration BOARD_BootClockPLL150M ********************* | ||||||
|  |  ******************************************************************************/ | ||||||
|  | /* clang-format off */ | ||||||
|  | /* TEXT BELOW IS USED AS SETTING FOR TOOLS ************************************* | ||||||
|  | !!Configuration | ||||||
|  | name: BOARD_BootClockPLL150M | ||||||
|  | called_from_default_init: true | ||||||
|  | outputs: | ||||||
|  | - {id: CLK_144M_clock.outFreq, value: 144 MHz} | ||||||
|  | - {id: CLK_48M_clock.outFreq, value: 48 MHz} | ||||||
|  | - {id: FRO_12M_clock.outFreq, value: 12 MHz} | ||||||
|  | - {id: FRO_HF_clock.outFreq, value: 48 MHz} | ||||||
|  | - {id: MAIN_clock.outFreq, value: 150 MHz} | ||||||
|  | - {id: PLL0_CLK_clock.outFreq, value: 150 MHz} | ||||||
|  | - {id: Slow_clock.outFreq, value: 37.5 MHz} | ||||||
|  | - {id: System_clock.outFreq, value: 150 MHz} | ||||||
|  | - {id: gdet_clock.outFreq, value: 48 MHz} | ||||||
|  | - {id: trng_clock.outFreq, value: 48 MHz} | ||||||
|  | settings: | ||||||
|  | - {id: PLL0_Mode, value: Normal} | ||||||
|  | - {id: RunPowerMode, value: OD} | ||||||
|  | - {id: SCGMode, value: PLL0} | ||||||
|  | - {id: SCG.PLL0M_MULT.scale, value: '50', locked: true} | ||||||
|  | - {id: SCG.PLL0SRCSEL.sel, value: SCG.FIRC_48M} | ||||||
|  | - {id: SCG.PLL0_NDIV.scale, value: '8', locked: true} | ||||||
|  | - {id: SCG.SCSSEL.sel, value: SCG.PLL0_CLK} | ||||||
|  | - {id: SYSCON.FLEXCAN0CLKSEL.sel, value: NO_CLOCK} | ||||||
|  | - {id: SYSCON.FLEXCAN1CLKSEL.sel, value: NO_CLOCK} | ||||||
|  | - {id: SYSCON.FREQMEREFCLKSEL.sel, value: SYSCON.evtg_out0a} | ||||||
|  | - {id: SYSCON.FREQMETARGETCLKSEL.sel, value: SYSCON.evtg_out0a} | ||||||
|  |  * BE CAREFUL MODIFYING THIS COMMENT - IT IS YAML SETTINGS FOR TOOLS **********/ | ||||||
|  | /* clang-format on */ | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  * Variables for BOARD_BootClockPLL150M configuration | ||||||
|  |  ******************************************************************************/ | ||||||
|  | /******************************************************************************* | ||||||
|  |  * Code for BOARD_BootClockPLL150M configuration | ||||||
|  |  ******************************************************************************/ | ||||||
|  | void BOARD_BootClockPLL150M(void) | ||||||
|  | { | ||||||
|  |     /*!< Enable SCG clock */ | ||||||
|  |     CLOCK_EnableClock(kCLOCK_Scg); | ||||||
|  |  | ||||||
|  |     CLOCK_SetupFROHFClocking(48000000U);                /*!< Enable FRO HF(48MHz) output */ | ||||||
|  |  | ||||||
|  |     /*!< Set up PLL0 */ | ||||||
|  |     const pll_setup_t pll0Setup = { | ||||||
|  |         .pllctrl = SCG_APLLCTRL_SOURCE(1U) | SCG_APLLCTRL_SELI(27U) | SCG_APLLCTRL_SELP(13U), | ||||||
|  |         .pllndiv = SCG_APLLNDIV_NDIV(8U), | ||||||
|  |         .pllpdiv = SCG_APLLPDIV_PDIV(1U), | ||||||
|  |         .pllmdiv = SCG_APLLMDIV_MDIV(50U), | ||||||
|  |         .pllRate = 150000000U | ||||||
|  |     }; | ||||||
|  |     CLOCK_SetPLL0Freq(&pll0Setup);                       /*!< Configure PLL0 to the desired values */ | ||||||
|  |     CLOCK_SetPll0MonitorMode(kSCG_Pll0MonitorDisable);    /* Pll0 Monitor is disabled */ | ||||||
|  |  | ||||||
|  |     /*!< Set up clock selectors - Attach clocks to the peripheries */ | ||||||
|  |     CLOCK_AttachClk(kPLL0_to_MAIN_CLK);                 /*!< Switch MAIN_CLK to PLL0 */ | ||||||
|  |  | ||||||
|  |     /*!< Set up dividers */ | ||||||
|  |     CLOCK_SetClkDiv(kCLOCK_DivAhbClk, 1U);           /*!< Set AHBCLKDIV divider to value 1 */ | ||||||
|  |  | ||||||
|  |     /* Set SystemCoreClock variable */ | ||||||
|  |     SystemCoreClock = BOARD_BOOTCLOCKPLL150M_CORE_CLOCK; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  ******************** Configuration BOARD_BootClockPLL100M ********************* | ||||||
|  |  ******************************************************************************/ | ||||||
|  | /* clang-format off */ | ||||||
|  | /* TEXT BELOW IS USED AS SETTING FOR TOOLS ************************************* | ||||||
|  | !!Configuration | ||||||
|  | name: BOARD_BootClockPLL100M | ||||||
|  | outputs: | ||||||
|  | - {id: CLK_144M_clock.outFreq, value: 144 MHz} | ||||||
|  | - {id: CLK_48M_clock.outFreq, value: 48 MHz} | ||||||
|  | - {id: CLK_IN_clock.outFreq, value: 24 MHz} | ||||||
|  | - {id: FRO_12M_clock.outFreq, value: 12 MHz} | ||||||
|  | - {id: MAIN_clock.outFreq, value: 100 MHz} | ||||||
|  | - {id: PLL1_CLK_clock.outFreq, value: 100 MHz} | ||||||
|  | - {id: Slow_clock.outFreq, value: 25 MHz} | ||||||
|  | - {id: System_clock.outFreq, value: 100 MHz} | ||||||
|  | - {id: gdet_clock.outFreq, value: 48 MHz} | ||||||
|  | - {id: trng_clock.outFreq, value: 48 MHz} | ||||||
|  | settings: | ||||||
|  | - {id: PLL1_Mode, value: Normal} | ||||||
|  | - {id: SCGMode, value: PLL1} | ||||||
|  | - {id: SCG.PLL1M_MULT.scale, value: '100', locked: true} | ||||||
|  | - {id: SCG.PLL1_NDIV.scale, value: '6', locked: true} | ||||||
|  | - {id: SCG.PLL1_PDIV.scale, value: '4', locked: true} | ||||||
|  | - {id: SCG.SCSSEL.sel, value: SCG.PLL1_CLK} | ||||||
|  | - {id: SCG_FIRCCSR_FIRCEN_CFG, value: Disabled} | ||||||
|  | - {id: SCG_SOSCCSR_SOSCEN_CFG, value: Enabled} | ||||||
|  | - {id: SYSCON.FREQMEREFCLKSEL.sel, value: SYSCON.evtg_out0a} | ||||||
|  | - {id: SYSCON.FREQMETARGETCLKSEL.sel, value: SYSCON.evtg_out0a} | ||||||
|  | sources: | ||||||
|  | - {id: SCG.SOSC.outFreq, value: 24 MHz, enabled: true} | ||||||
|  |  * BE CAREFUL MODIFYING THIS COMMENT - IT IS YAML SETTINGS FOR TOOLS **********/ | ||||||
|  | /* clang-format on */ | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  * Variables for BOARD_BootClockPLL100M configuration | ||||||
|  |  ******************************************************************************/ | ||||||
|  | /******************************************************************************* | ||||||
|  |  * Code for BOARD_BootClockPLL100M configuration | ||||||
|  |  ******************************************************************************/ | ||||||
|  | void BOARD_BootClockPLL100M(void) | ||||||
|  | { | ||||||
|  |     /*!< Enable SCG clock */ | ||||||
|  |     CLOCK_EnableClock(kCLOCK_Scg); | ||||||
|  |  | ||||||
|  |     CLOCK_SetupExtClocking(24000000U); | ||||||
|  |     CLOCK_SetSysOscMonitorMode(kSCG_SysOscMonitorDisable);    /* System OSC Clock Monitor is disabled */ | ||||||
|  |  | ||||||
|  |     /*!< Set up PLL1 */ | ||||||
|  |     const pll_setup_t pll1Setup = { | ||||||
|  |         .pllctrl = SCG_SPLLCTRL_SOURCE(0U) | SCG_SPLLCTRL_SELI(53U) | SCG_SPLLCTRL_SELP(26U), | ||||||
|  |         .pllndiv = SCG_SPLLNDIV_NDIV(6U), | ||||||
|  |         .pllpdiv = SCG_SPLLPDIV_PDIV(2U), | ||||||
|  |         .pllmdiv = SCG_SPLLMDIV_MDIV(100U), | ||||||
|  |         .pllRate = 100000000U | ||||||
|  |     }; | ||||||
|  |     CLOCK_SetPLL1Freq(&pll1Setup);                       /*!< Configure PLL1 to the desired values */ | ||||||
|  |     CLOCK_SetPll1MonitorMode(kSCG_Pll1MonitorDisable);    /* Pll1 Monitor is disabled */ | ||||||
|  |  | ||||||
|  |     /*!< Set up clock selectors - Attach clocks to the peripheries */ | ||||||
|  |     CLOCK_AttachClk(kPLL1_to_MAIN_CLK);                 /*!< Switch MAIN_CLK to PLL1 */ | ||||||
|  |  | ||||||
|  |     /*!< Set up dividers */ | ||||||
|  |     CLOCK_SetClkDiv(kCLOCK_DivAhbClk, 1U);           /*!< Set AHBCLKDIV divider to value 1 */ | ||||||
|  |  | ||||||
|  |     /* Set SystemCoreClock variable */ | ||||||
|  |     SystemCoreClock = BOARD_BOOTCLOCKPLL100M_CORE_CLOCK; | ||||||
|  | } | ||||||
							
								
								
									
										177
									
								
								hw/bsp/mcx/boards/bunny-brain/clock_config.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										177
									
								
								hw/bsp/mcx/boards/bunny-brain/clock_config.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,177 @@ | |||||||
|  | /* | ||||||
|  |  * Copyright 2022 NXP | ||||||
|  |  * All rights reserved. | ||||||
|  |  * | ||||||
|  |  * SPDX-License-Identifier: BSD-3-Clause | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | /*********************************************************************************************************************** | ||||||
|  |  * This file was generated by the MCUXpresso Config Tools. Any manual edits made to this file | ||||||
|  |  * will be overwritten if the respective MCUXpresso Config Tools is used to update this file. | ||||||
|  |  **********************************************************************************************************************/ | ||||||
|  |  | ||||||
|  | #ifndef _CLOCK_CONFIG_H_ | ||||||
|  | #define _CLOCK_CONFIG_H_ | ||||||
|  |  | ||||||
|  | #include "fsl_common.h" | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  * Definitions | ||||||
|  |  ******************************************************************************/ | ||||||
|  | #define BOARD_XTAL0_CLK_HZ                         24000000U  /*!< Board xtal frequency in Hz */ | ||||||
|  | #define BOARD_XTAL32K_CLK_HZ                          32768U  /*!< Board xtal32K frequency in Hz */ | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  ************************ BOARD_InitBootClocks function ************************ | ||||||
|  |  ******************************************************************************/ | ||||||
|  |  | ||||||
|  | #if defined(__cplusplus) | ||||||
|  | extern "C" { | ||||||
|  | #endif /* __cplusplus*/ | ||||||
|  |  | ||||||
|  | /*! | ||||||
|  |  * @brief This function executes default configuration of clocks. | ||||||
|  |  * | ||||||
|  |  */ | ||||||
|  | void BOARD_InitBootClocks(void); | ||||||
|  |  | ||||||
|  | #if defined(__cplusplus) | ||||||
|  | } | ||||||
|  | #endif /* __cplusplus*/ | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  ******************** Configuration BOARD_BootClockFRO12M ********************** | ||||||
|  |  ******************************************************************************/ | ||||||
|  | /******************************************************************************* | ||||||
|  |  * Definitions for BOARD_BootClockFRO12M configuration | ||||||
|  |  ******************************************************************************/ | ||||||
|  | #define BOARD_BOOTCLOCKFRO12M_CORE_CLOCK           12000000U  /*!< Core clock frequency: 12000000Hz */ | ||||||
|  | #define BOARD_BOOTCLOCKFRO12M_ROSC_CLOCK                  0U  /*!< ROSC clock frequency: 0Hz */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  * API for BOARD_BootClockFRO12M configuration | ||||||
|  |  ******************************************************************************/ | ||||||
|  | #if defined(__cplusplus) | ||||||
|  | extern "C" { | ||||||
|  | #endif /* __cplusplus*/ | ||||||
|  |  | ||||||
|  | /*! | ||||||
|  |  * @brief This function executes configuration of clocks. | ||||||
|  |  * | ||||||
|  |  */ | ||||||
|  | void BOARD_BootClockFRO12M(void); | ||||||
|  |  | ||||||
|  | #if defined(__cplusplus) | ||||||
|  | } | ||||||
|  | #endif /* __cplusplus*/ | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  ******************* Configuration BOARD_BootClockFROHF48M ********************* | ||||||
|  |  ******************************************************************************/ | ||||||
|  | /******************************************************************************* | ||||||
|  |  * Definitions for BOARD_BootClockFROHF48M configuration | ||||||
|  |  ******************************************************************************/ | ||||||
|  | #define BOARD_BOOTCLOCKFROHF48M_CORE_CLOCK         48000000U  /*!< Core clock frequency: 48000000Hz */ | ||||||
|  | #define BOARD_BOOTCLOCKFROHF48M_ROSC_CLOCK                0U  /*!< ROSC clock frequency: 0Hz */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  * API for BOARD_BootClockFROHF48M configuration | ||||||
|  |  ******************************************************************************/ | ||||||
|  | #if defined(__cplusplus) | ||||||
|  | extern "C" { | ||||||
|  | #endif /* __cplusplus*/ | ||||||
|  |  | ||||||
|  | /*! | ||||||
|  |  * @brief This function executes configuration of clocks. | ||||||
|  |  * | ||||||
|  |  */ | ||||||
|  | void BOARD_BootClockFROHF48M(void); | ||||||
|  |  | ||||||
|  | #if defined(__cplusplus) | ||||||
|  | } | ||||||
|  | #endif /* __cplusplus*/ | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  ******************* Configuration BOARD_BootClockFROHF144M ******************** | ||||||
|  |  ******************************************************************************/ | ||||||
|  | /******************************************************************************* | ||||||
|  |  * Definitions for BOARD_BootClockFROHF144M configuration | ||||||
|  |  ******************************************************************************/ | ||||||
|  | #define BOARD_BOOTCLOCKFROHF144M_CORE_CLOCK       144000000U  /*!< Core clock frequency: 144000000Hz */ | ||||||
|  | #define BOARD_BOOTCLOCKFROHF144M_ROSC_CLOCK               0U  /*!< ROSC clock frequency: 0Hz */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  * API for BOARD_BootClockFROHF144M configuration | ||||||
|  |  ******************************************************************************/ | ||||||
|  | #if defined(__cplusplus) | ||||||
|  | extern "C" { | ||||||
|  | #endif /* __cplusplus*/ | ||||||
|  |  | ||||||
|  | /*! | ||||||
|  |  * @brief This function executes configuration of clocks. | ||||||
|  |  * | ||||||
|  |  */ | ||||||
|  | void BOARD_BootClockFROHF144M(void); | ||||||
|  |  | ||||||
|  | #if defined(__cplusplus) | ||||||
|  | } | ||||||
|  | #endif /* __cplusplus*/ | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  ******************** Configuration BOARD_BootClockPLL150M ********************* | ||||||
|  |  ******************************************************************************/ | ||||||
|  | /******************************************************************************* | ||||||
|  |  * Definitions for BOARD_BootClockPLL150M configuration | ||||||
|  |  ******************************************************************************/ | ||||||
|  | #define BOARD_BOOTCLOCKPLL150M_CORE_CLOCK         150000000U  /*!< Core clock frequency: 150000000Hz */ | ||||||
|  | #define BOARD_BOOTCLOCKPLL150M_ROSC_CLOCK                 0U  /*!< ROSC clock frequency: 0Hz */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  * API for BOARD_BootClockPLL150M configuration | ||||||
|  |  ******************************************************************************/ | ||||||
|  | #if defined(__cplusplus) | ||||||
|  | extern "C" { | ||||||
|  | #endif /* __cplusplus*/ | ||||||
|  |  | ||||||
|  | /*! | ||||||
|  |  * @brief This function executes configuration of clocks. | ||||||
|  |  * | ||||||
|  |  */ | ||||||
|  | void BOARD_BootClockPLL150M(void); | ||||||
|  |  | ||||||
|  | #if defined(__cplusplus) | ||||||
|  | } | ||||||
|  | #endif /* __cplusplus*/ | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  ******************** Configuration BOARD_BootClockPLL100M ********************* | ||||||
|  |  ******************************************************************************/ | ||||||
|  | /******************************************************************************* | ||||||
|  |  * Definitions for BOARD_BootClockPLL100M configuration | ||||||
|  |  ******************************************************************************/ | ||||||
|  | #define BOARD_BOOTCLOCKPLL100M_CORE_CLOCK         100000000U  /*!< Core clock frequency: 100000000Hz */ | ||||||
|  | #define BOARD_BOOTCLOCKPLL100M_ROSC_CLOCK                 0U  /*!< ROSC clock frequency: 0Hz */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  |  * API for BOARD_BootClockPLL100M configuration | ||||||
|  |  ******************************************************************************/ | ||||||
|  | #if defined(__cplusplus) | ||||||
|  | extern "C" { | ||||||
|  | #endif /* __cplusplus*/ | ||||||
|  |  | ||||||
|  | /*! | ||||||
|  |  * @brief This function executes configuration of clocks. | ||||||
|  |  * | ||||||
|  |  */ | ||||||
|  | void BOARD_BootClockPLL100M(void); | ||||||
|  |  | ||||||
|  | #if defined(__cplusplus) | ||||||
|  | } | ||||||
|  | #endif /* __cplusplus*/ | ||||||
|  |  | ||||||
|  | #endif /* _CLOCK_CONFIG_H_ */ | ||||||
							
								
								
									
										141
									
								
								hw/bsp/mcx/boards/bunny-brain/pin_mux.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										141
									
								
								hw/bsp/mcx/boards/bunny-brain/pin_mux.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,141 @@ | |||||||
|  | /* | ||||||
|  |  * Copyright 2022 NXP | ||||||
|  |  * All rights reserved. | ||||||
|  |  * | ||||||
|  |  * SPDX-License-Identifier: BSD-3-Clause | ||||||
|  |  */ | ||||||
|  | /*********************************************************************************************************************** | ||||||
|  |  * This file was generated by the MCUXpresso Config Tools. Any manual edits made to this file | ||||||
|  |  * will be overwritten if the respective MCUXpresso Config Tools is used to update this file. | ||||||
|  |  **********************************************************************************************************************/ | ||||||
|  |  | ||||||
|  | /* clang-format off */ | ||||||
|  | /* | ||||||
|  |  * TEXT BELOW IS USED AS SETTING FOR TOOLS ************************************* | ||||||
|  | !!GlobalInfo | ||||||
|  | product: Pins v12.0 | ||||||
|  | processor: MCXN947 | ||||||
|  | package_id: MCXN947VDF | ||||||
|  | mcu_data: ksdk2_0 | ||||||
|  | processor_version: 0.12.3 | ||||||
|  |  * BE CAREFUL MODIFYING THIS COMMENT - IT IS YAML SETTINGS FOR TOOLS *********** | ||||||
|  |  */ | ||||||
|  | /* clang-format on */ | ||||||
|  |  | ||||||
|  | #include "fsl_common.h" | ||||||
|  | #include "fsl_port.h" | ||||||
|  | #include "pin_mux.h" | ||||||
|  |  | ||||||
|  | /* FUNCTION ************************************************************************************************************ | ||||||
|  |  * | ||||||
|  |  * Function Name : BOARD_InitBootPins | ||||||
|  |  * Description   : Calls initialization functions. | ||||||
|  |  * | ||||||
|  |  * END ****************************************************************************************************************/ | ||||||
|  | void BOARD_InitBootPins(void) | ||||||
|  | { | ||||||
|  |     BOARD_InitPins(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /* clang-format off */ | ||||||
|  | /* | ||||||
|  |  * TEXT BELOW IS USED AS SETTING FOR TOOLS ************************************* | ||||||
|  | BOARD_InitPins: | ||||||
|  | - options: {callFromInitBoot: 'true', coreID: cm33_core0, enableClock: 'true'} | ||||||
|  | - pin_list: | ||||||
|  |   - {pin_num: A1, peripheral: LPFlexcomm4, signal: LPFLEXCOMM_P0, pin_signal: PIO1_8/WUU0_IN10/LPTMR1_ALT3/TRACE_DATA0/FC4_P0/FC5_P4/CT_INP8/SCT0_OUT2/FLEXIO0_D16/PLU_OUT0/ENET0_TXD2/I3C1_SDA/TSI0_CH17/ADC1_A8, | ||||||
|  |     slew_rate: fast, open_drain: disable, drive_strength: low, pull_select: down, pull_enable: disable, passive_filter: disable, pull_value: low, input_buffer: enable, | ||||||
|  |     invert_input: normal} | ||||||
|  |   - {pin_num: B1, peripheral: LPFlexcomm4, signal: LPFLEXCOMM_P1, pin_signal: PIO1_9/TRACE_DATA1/FC4_P1/FC5_P5/CT_INP9/SCT0_OUT3/FLEXIO0_D17/PLU_OUT1/ENET0_TXD3/I3C1_SCL/TSI0_CH18/ADC1_A9, | ||||||
|  |     slew_rate: fast, open_drain: disable, drive_strength: low, pull_select: down, pull_enable: disable, passive_filter: disable, input_buffer: enable, invert_input: normal} | ||||||
|  |   - {pin_num: F14, peripheral: GPIO3, signal: 'GPIO, 4', pin_signal: PIO3_4/FC7_P2/CT_INP18/PWM0_X2/FLEXIO0_D12/SIM1_CLK, slew_rate: fast, open_drain: disable, drive_strength: low, | ||||||
|  |     pull_select: down, pull_enable: disable, input_buffer: enable, invert_input: normal} | ||||||
|  |  * BE CAREFUL MODIFYING THIS COMMENT - IT IS YAML SETTINGS FOR TOOLS *********** | ||||||
|  |  */ | ||||||
|  | /* clang-format on */ | ||||||
|  |  | ||||||
|  | /* FUNCTION ************************************************************************************************************ | ||||||
|  |  * | ||||||
|  |  * Function Name : BOARD_InitPins | ||||||
|  |  * Description   : Configures pin routing and optionally pin electrical features. | ||||||
|  |  * | ||||||
|  |  * END ****************************************************************************************************************/ | ||||||
|  | void BOARD_InitPins(void) | ||||||
|  | { | ||||||
|  |     /* Enables the clock for PORT1: Enables clock */ | ||||||
|  |     CLOCK_EnableClock(kCLOCK_Port1); | ||||||
|  |     /* Enables the clock for PORT3: Enables clock */ | ||||||
|  |     CLOCK_EnableClock(kCLOCK_Port3); | ||||||
|  |  | ||||||
|  |     const port_pin_config_t port1_8_pinA1_config = {/* Internal pull-up/down resistor is disabled */ | ||||||
|  |                                                     kPORT_PullDisable, | ||||||
|  |                                                     /* Low internal pull resistor value is selected. */ | ||||||
|  |                                                     kPORT_LowPullResistor, | ||||||
|  |                                                     /* Fast slew rate is configured */ | ||||||
|  |                                                     kPORT_FastSlewRate, | ||||||
|  |                                                     /* Passive input filter is disabled */ | ||||||
|  |                                                     kPORT_PassiveFilterDisable, | ||||||
|  |                                                     /* Open drain output is disabled */ | ||||||
|  |                                                     kPORT_OpenDrainDisable, | ||||||
|  |                                                     /* Low drive strength is configured */ | ||||||
|  |                                                     kPORT_LowDriveStrength, | ||||||
|  |                                                     /* Pin is configured as FC4_P0 */ | ||||||
|  |                                                     kPORT_MuxAlt2, | ||||||
|  |                                                     /* Digital input enabled */ | ||||||
|  |                                                     kPORT_InputBufferEnable, | ||||||
|  |                                                     /* Digital input is not inverted */ | ||||||
|  |                                                     kPORT_InputNormal, | ||||||
|  |                                                     /* Pin Control Register fields [15:0] are not locked */ | ||||||
|  |                                                     kPORT_UnlockRegister}; | ||||||
|  |     /* PORT1_8 (pin A1) is configured as FC4_P0 */ | ||||||
|  |     PORT_SetPinConfig(PORT1, 8U, &port1_8_pinA1_config); | ||||||
|  |  | ||||||
|  |     const port_pin_config_t port1_9_pinB1_config = {/* Internal pull-up/down resistor is disabled */ | ||||||
|  |                                                     kPORT_PullDisable, | ||||||
|  |                                                     /* Low internal pull resistor value is selected. */ | ||||||
|  |                                                     kPORT_LowPullResistor, | ||||||
|  |                                                     /* Fast slew rate is configured */ | ||||||
|  |                                                     kPORT_FastSlewRate, | ||||||
|  |                                                     /* Passive input filter is disabled */ | ||||||
|  |                                                     kPORT_PassiveFilterDisable, | ||||||
|  |                                                     /* Open drain output is disabled */ | ||||||
|  |                                                     kPORT_OpenDrainDisable, | ||||||
|  |                                                     /* Low drive strength is configured */ | ||||||
|  |                                                     kPORT_LowDriveStrength, | ||||||
|  |                                                     /* Pin is configured as FC4_P1 */ | ||||||
|  |                                                     kPORT_MuxAlt2, | ||||||
|  |                                                     /* Digital input enabled */ | ||||||
|  |                                                     kPORT_InputBufferEnable, | ||||||
|  |                                                     /* Digital input is not inverted */ | ||||||
|  |                                                     kPORT_InputNormal, | ||||||
|  |                                                     /* Pin Control Register fields [15:0] are not locked */ | ||||||
|  |                                                     kPORT_UnlockRegister}; | ||||||
|  |     /* PORT1_9 (pin B1) is configured as FC4_P1 */ | ||||||
|  |     PORT_SetPinConfig(PORT1, 9U, &port1_9_pinB1_config); | ||||||
|  |  | ||||||
|  |     const port_pin_config_t port3_4_pinF14_config = {/* Internal pull-up/down resistor is disabled */ | ||||||
|  |                                                      kPORT_PullDisable, | ||||||
|  |                                                      /* Low internal pull resistor value is selected. */ | ||||||
|  |                                                      kPORT_LowPullResistor, | ||||||
|  |                                                      /* Fast slew rate is configured */ | ||||||
|  |                                                      kPORT_FastSlewRate, | ||||||
|  |                                                      /* Passive input filter is disabled */ | ||||||
|  |                                                      kPORT_PassiveFilterDisable, | ||||||
|  |                                                      /* Open drain output is disabled */ | ||||||
|  |                                                      kPORT_OpenDrainDisable, | ||||||
|  |                                                      /* Low drive strength is configured */ | ||||||
|  |                                                      kPORT_LowDriveStrength, | ||||||
|  |                                                      /* Pin is configured as PIO3_4 */ | ||||||
|  |                                                      kPORT_MuxAlt0, | ||||||
|  |                                                      /* Digital input enabled */ | ||||||
|  |                                                      kPORT_InputBufferEnable, | ||||||
|  |                                                      /* Digital input is not inverted */ | ||||||
|  |                                                      kPORT_InputNormal, | ||||||
|  |                                                      /* Pin Control Register fields [15:0] are not locked */ | ||||||
|  |                                                      kPORT_UnlockRegister}; | ||||||
|  |     /* PORT3_4 (pin F14) is configured as PIO3_4 */ | ||||||
|  |     PORT_SetPinConfig(PORT3, 4U, &port3_4_pinF14_config); | ||||||
|  | } | ||||||
|  | /*********************************************************************************************************************** | ||||||
|  |  * EOF | ||||||
|  |  **********************************************************************************************************************/ | ||||||
							
								
								
									
										51
									
								
								hw/bsp/mcx/boards/bunny-brain/pin_mux.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								hw/bsp/mcx/boards/bunny-brain/pin_mux.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,51 @@ | |||||||
|  | /* | ||||||
|  |  * Copyright 2022 NXP | ||||||
|  |  * All rights reserved. | ||||||
|  |  * | ||||||
|  |  * SPDX-License-Identifier: BSD-3-Clause | ||||||
|  |  */ | ||||||
|  | /*********************************************************************************************************************** | ||||||
|  |  * This file was generated by the MCUXpresso Config Tools. Any manual edits made to this file | ||||||
|  |  * will be overwritten if the respective MCUXpresso Config Tools is used to update this file. | ||||||
|  |  **********************************************************************************************************************/ | ||||||
|  |  | ||||||
|  | #ifndef _PIN_MUX_H_ | ||||||
|  | #define _PIN_MUX_H_ | ||||||
|  |  | ||||||
|  | /*! | ||||||
|  |  * @addtogroup pin_mux | ||||||
|  |  * @{ | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | /*********************************************************************************************************************** | ||||||
|  |  * API | ||||||
|  |  **********************************************************************************************************************/ | ||||||
|  |  | ||||||
|  | #if defined(__cplusplus) | ||||||
|  | extern "C" { | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | /*! | ||||||
|  |  * @brief Calls initialization functions. | ||||||
|  |  * | ||||||
|  |  */ | ||||||
|  | void BOARD_InitBootPins(void); | ||||||
|  |  | ||||||
|  | /*! | ||||||
|  |  * @brief Configures pin routing and optionally pin electrical features. | ||||||
|  |  * | ||||||
|  |  */ | ||||||
|  | void BOARD_InitPins(void); | ||||||
|  |  | ||||||
|  | #if defined(__cplusplus) | ||||||
|  | } | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | /*! | ||||||
|  |  * @} | ||||||
|  |  */ | ||||||
|  | #endif /* _PIN_MUX_H_ */ | ||||||
|  |  | ||||||
|  | /*********************************************************************************************************************** | ||||||
|  |  * EOF | ||||||
|  |  **********************************************************************************************************************/ | ||||||
		Reference in New Issue
	
	Block a user
	 Jerry Palacios
					Jerry Palacios