/* * Copyright 2018 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 v5.0 processor: LPC845 package_id: LPC845M301JBD48 mcu_data: ksdk2_0 processor_version: 5.0.0 pin_labels: - {pin_num: '11', pin_signal: PIO1_0/CAPT_X1, label: LED GREEN} - {pin_num: '14', pin_signal: PIO1_1/CAPT_X2, label: LED BLUE} - {pin_num: '16', pin_signal: PIO1_2/CAPT_X3, label: LED RED} * BE CAREFUL MODIFYING THIS COMMENT - IT IS YAML SETTINGS FOR TOOLS *********** */ /* clang-format on */ #include "fsl_common.h" #include "fsl_iocon.h" #include "fsl_swm.h" #include "pin_mux.h" /* FUNCTION ************************************************************************************************************ * * Function Name : BOARD_InitBootPins * Description : Calls initialization functions. * * END ****************************************************************************************************************/ void BOARD_InitBootPins(void) { BOARD_InitSWD_DEBUGPins(); BOARD_InitBUTTONsPins(); BOARD_InitLEDsPins(); BOARD_InitDEBUG_UARTPins(); } /* clang-format off */ /* * TEXT BELOW IS USED AS SETTING FOR TOOLS ************************************* BOARD_InitSWD_DEBUGPins: - options: {callFromInitBoot: 'true', coreID: core0, enableClock: 'true'} - pin_list: - {pin_num: '8', peripheral: SWD, signal: SWCLK, pin_signal: SWCLK/PIO0_3, mode: pullUp, invert: disabled, hysteresis: enabled, opendrain: disabled, smode: bypass, clkdiv: div0} - {pin_num: '10', peripheral: SWD, signal: SWDIO, pin_signal: SWDIO/PIO0_2, mode: pullUp, invert: disabled, hysteresis: enabled, opendrain: disabled, smode: bypass, clkdiv: div0} * BE CAREFUL MODIFYING THIS COMMENT - IT IS YAML SETTINGS FOR TOOLS *********** */ /* clang-format on */ /* FUNCTION ************************************************************************************************************ * * Function Name : BOARD_InitSWD_DEBUGPins * Description : Configures pin routing and optionally pin electrical features. * * END ****************************************************************************************************************/ /* Function assigned for the Cortex-M0P */ void BOARD_InitSWD_DEBUGPins(void) { /* Enables clock for IOCON.: enable */ CLOCK_EnableClock(kCLOCK_Iocon); /* Enables clock for switch matrix.: enable */ CLOCK_EnableClock(kCLOCK_Swm); const uint32_t IOCON_INDEX_PIO0_2_config = (/* Selects pull-up function */ IOCON_PIO_MODE_PULLUP | /* Enable hysteresis */ IOCON_PIO_HYS_EN | /* Input not invert */ IOCON_PIO_INV_DI | /* Disables Open-drain function */ IOCON_PIO_OD_DI | /* Bypass input filter */ IOCON_PIO_SMODE_BYPASS | /* IOCONCLKDIV0 */ IOCON_PIO_CLKDIV0); /* PORT0 PIN2 (coords: ) is configured as */ IOCON_PinMuxSet(IOCON, IOCON_INDEX_PIO0_2, IOCON_INDEX_PIO0_2_config); const uint32_t IOCON_INDEX_PIO0_3_config = (/* Selects pull-up function */ IOCON_PIO_MODE_PULLUP | /* Enable hysteresis */ IOCON_PIO_HYS_EN | /* Input not invert */ IOCON_PIO_INV_DI | /* Disables Open-drain function */ IOCON_PIO_OD_DI | /* Bypass input filter */ IOCON_PIO_SMODE_BYPASS | /* IOCONCLKDIV0 */ IOCON_PIO_CLKDIV0); /* PORT0 PIN3 (coords: ) is configured as */ IOCON_PinMuxSet(IOCON, IOCON_INDEX_PIO0_3, IOCON_INDEX_PIO0_3_config); /* SWCLK connect to P0_3 */ SWM_SetFixedPinSelect(SWM0, kSWM_SWCLK, true); /* SWDIO connect to P0_2 */ SWM_SetFixedPinSelect(SWM0, kSWM_SWDIO, true); /* Disable clock for switch matrix. */ CLOCK_DisableClock(kCLOCK_Swm); } /* clang-format off */ /* * TEXT BELOW IS USED AS SETTING FOR TOOLS ************************************* BOARD_InitBUTTONsPins: - options: {callFromInitBoot: 'true', coreID: core0, enableClock: 'true'} - pin_list: - {pin_num: '6', peripheral: GPIO, signal: 'PIO0, 4', pin_signal: PIO0_4/ADC_11, mode: pullUp, invert: disabled, hysteresis: enabled, opendrain: disabled, smode: bypass, clkdiv: div0} * BE CAREFUL MODIFYING THIS COMMENT - IT IS YAML SETTINGS FOR TOOLS *********** */ /* clang-format on */ /* FUNCTION ************************************************************************************************************ * * Function Name : BOARD_InitBUTTONsPins * Description : Configures pin routing and optionally pin electrical features. * * END ****************************************************************************************************************/ /* Function assigned for the Cortex-M0P */ void BOARD_InitBUTTONsPins(void) { /* Enables clock for IOCON.: enable */ CLOCK_EnableClock(kCLOCK_Iocon); const uint32_t IOCON_INDEX_PIO0_4_config = (/* Selects pull-up function */ IOCON_PIO_MODE_PULLUP | /* Enable hysteresis */ IOCON_PIO_HYS_EN | /* Input not invert */ IOCON_PIO_INV_DI | /* Disables Open-drain function */ IOCON_PIO_OD_DI | /* Bypass input filter */ IOCON_PIO_SMODE_BYPASS | /* IOCONCLKDIV0 */ IOCON_PIO_CLKDIV0); /* PORT0 PIN4 (coords: ) is configured as */ IOCON_PinMuxSet(IOCON, IOCON_INDEX_PIO0_4, IOCON_INDEX_PIO0_4_config); /* Disable clock for switch matrix. */ CLOCK_DisableClock(kCLOCK_Swm); } /* clang-format off */ /* * TEXT BELOW IS USED AS SETTING FOR TOOLS ************************************* BOARD_InitLEDsPins: - options: {callFromInitBoot: 'true', coreID: core0, enableClock: 'true'} - pin_list: - {pin_num: '11', peripheral: GPIO, signal: 'PIO1, 0', pin_signal: PIO1_0/CAPT_X1, mode: pullUp, invert: disabled, hysteresis: enabled, opendrain: disabled, smode: bypass, clkdiv: div0} - {pin_num: '14', peripheral: GPIO, signal: 'PIO1, 1', pin_signal: PIO1_1/CAPT_X2, mode: pullUp, invert: disabled, hysteresis: enabled, opendrain: disabled, smode: bypass, clkdiv: div0} - {pin_num: '16', peripheral: GPIO, signal: 'PIO1, 2', pin_signal: PIO1_2/CAPT_X3, mode: pullUp, invert: disabled, hysteresis: enabled, opendrain: disabled, smode: bypass, clkdiv: div0} * BE CAREFUL MODIFYING THIS COMMENT - IT IS YAML SETTINGS FOR TOOLS *********** */ /* clang-format on */ /* FUNCTION ************************************************************************************************************ * * Function Name : BOARD_InitLEDsPins * Description : Configures pin routing and optionally pin electrical features. * * END ****************************************************************************************************************/ /* Function assigned for the Cortex-M0P */ void BOARD_InitLEDsPins(void) { /* Enables clock for IOCON.: enable */ CLOCK_EnableClock(kCLOCK_Iocon); const uint32_t IOCON_INDEX_PIO1_0_config = (/* Selects pull-up function */ IOCON_PIO_MODE_PULLUP | /* Enable hysteresis */ IOCON_PIO_HYS_EN | /* Input not invert */ IOCON_PIO_INV_DI | /* Disables Open-drain function */ IOCON_PIO_OD_DI | /* Bypass input filter */ IOCON_PIO_SMODE_BYPASS | /* IOCONCLKDIV0 */ IOCON_PIO_CLKDIV0); /* PORT1 PIN0 (coords: ) is configured as */ IOCON_PinMuxSet(IOCON, IOCON_INDEX_PIO1_0, IOCON_INDEX_PIO1_0_config); const uint32_t IOCON_INDEX_PIO1_1_config = (/* Selects pull-up function */ IOCON_PIO_MODE_PULLUP | /* Enable hysteresis */ IOCON_PIO_HYS_EN | /* Input not invert */ IOCON_PIO_INV_DI | /* Disables Open-drain function */ IOCON_PIO_OD_DI | /* Bypass input filter */ IOCON_PIO_SMODE_BYPASS | /* IOCONCLKDIV0 */ IOCON_PIO_CLKDIV0); /* PORT1 PIN1 (coords: ) is configured as */ IOCON_PinMuxSet(IOCON, IOCON_INDEX_PIO1_1, IOCON_INDEX_PIO1_1_config); const uint32_t IOCON_INDEX_PIO1_2_config = (/* Selects pull-up function */ IOCON_PIO_MODE_PULLUP | /* Enable hysteresis */ IOCON_PIO_HYS_EN | /* Input not invert */ IOCON_PIO_INV_DI | /* Disables Open-drain function */ IOCON_PIO_OD_DI | /* Bypass input filter */ IOCON_PIO_SMODE_BYPASS | /* IOCONCLKDIV0 */ IOCON_PIO_CLKDIV0); /* PORT1 PIN2 (coords: ) is configured as */ IOCON_PinMuxSet(IOCON, IOCON_INDEX_PIO1_2, IOCON_INDEX_PIO1_2_config); /* Disable clock for switch matrix. */ CLOCK_DisableClock(kCLOCK_Swm); } /* clang-format off */ /* * TEXT BELOW IS USED AS SETTING FOR TOOLS ************************************* BOARD_InitDEBUG_UARTPins: - options: {callFromInitBoot: 'true', coreID: core0, enableClock: 'true'} - pin_list: - {pin_num: '20', peripheral: USART0, signal: RXD, pin_signal: PIO0_24, mode: pullUp, invert: disabled, hysteresis: enabled, opendrain: disabled, smode: bypass, clkdiv: div0} - {pin_num: '19', peripheral: USART0, signal: TXD, pin_signal: PIO0_25, mode: pullUp, invert: disabled, hysteresis: enabled, opendrain: disabled, smode: bypass, clkdiv: div0} * BE CAREFUL MODIFYING THIS COMMENT - IT IS YAML SETTINGS FOR TOOLS *********** */ /* clang-format on */ /* FUNCTION ************************************************************************************************************ * * Function Name : BOARD_InitDEBUG_UARTPins * Description : Configures pin routing and optionally pin electrical features. * * END ****************************************************************************************************************/ /* Function assigned for the Cortex-M0P */ void BOARD_InitDEBUG_UARTPins(void) { /* Enables clock for IOCON.: enable */ CLOCK_EnableClock(kCLOCK_Iocon); /* Enables clock for switch matrix.: enable */ CLOCK_EnableClock(kCLOCK_Swm); const uint32_t IOCON_INDEX_PIO0_24_config = (/* Selects pull-up function */ IOCON_PIO_MODE_PULLUP | /* Enable hysteresis */ IOCON_PIO_HYS_EN | /* Input not invert */ IOCON_PIO_INV_DI | /* Disables Open-drain function */ IOCON_PIO_OD_DI | /* Bypass input filter */ IOCON_PIO_SMODE_BYPASS | /* IOCONCLKDIV0 */ IOCON_PIO_CLKDIV0); /* PORT0 PIN24 (coords: ) is configured as */ IOCON_PinMuxSet(IOCON, IOCON_INDEX_PIO0_24, IOCON_INDEX_PIO0_24_config); const uint32_t IOCON_INDEX_PIO0_25_config = (/* Selects pull-up function */ IOCON_PIO_MODE_PULLUP | /* Enable hysteresis */ IOCON_PIO_HYS_EN | /* Input not invert */ IOCON_PIO_INV_DI | /* Disables Open-drain function */ IOCON_PIO_OD_DI | /* Bypass input filter */ IOCON_PIO_SMODE_BYPASS | /* IOCONCLKDIV0 */ IOCON_PIO_CLKDIV0); /* PORT0 PIN25 (coords: ) is configured as */ IOCON_PinMuxSet(IOCON, IOCON_INDEX_PIO0_25, IOCON_INDEX_PIO0_25_config); /* USART0_TXD connect to P0_25 */ SWM_SetMovablePinSelect(SWM0, kSWM_USART0_TXD, kSWM_PortPin_P0_25); /* USART0_RXD connect to P0_24 */ SWM_SetMovablePinSelect(SWM0, kSWM_USART0_RXD, kSWM_PortPin_P0_24); /* Disable clock for switch matrix. */ CLOCK_DisableClock(kCLOCK_Swm); } /*********************************************************************************************************************** * EOF **********************************************************************************************************************/