mbed-os/targets/TARGET_Silicon_Labs/TARGET_EFM32/TARGET_EFR32MG1/PeripheralPins.c

462 lines
11 KiB
C

/***************************************************************************//**
* @file PeripheralPins.c
*******************************************************************************
* @section License
* <b>(C) Copyright 2015 Silicon Labs, http://www.silabs.com</b>
*******************************************************************************
*
* SPDX-License-Identifier: Apache-2.0
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may
* not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
******************************************************************************/
#include "PeripheralPins.h"
#include "mbed_toolchain.h"
/************ADC***************/
/* The third "function" value is used to select the correct ADC channel */
MBED_WEAK const PinMap PinMap_ADC[] = {
#ifdef ADC0_BASE
{PA0, ADC_0, adcPosSelAPORT3XCH8},
{PA1, ADC_0, adcPosSelAPORT4XCH9},
{PA2, ADC_0, adcPosSelAPORT3XCH10},
{PA3, ADC_0, adcPosSelAPORT4XCH11},
{PA4, ADC_0, adcPosSelAPORT3XCH12},
{PA5, ADC_0, adcPosSelAPORT4XCH13},
{PB11, ADC_0, adcPosSelAPORT4XCH27},
{PB12, ADC_0, adcPosSelAPORT3XCH28},
{PB14, ADC_0, adcPosSelAPORT3XCH30},
{PB15, ADC_0, adcPosSelAPORT4XCH31},
{PC6, ADC_0, adcPosSelAPORT1XCH6},
{PC7, ADC_0, adcPosSelAPORT2XCH7},
{PC8, ADC_0, adcPosSelAPORT1XCH8},
{PC9, ADC_0, adcPosSelAPORT2XCH9},
{PC10, ADC_0, adcPosSelAPORT1XCH10},
{PC11, ADC_0, adcPosSelAPORT2XCH11},
{PD9, ADC_0, adcPosSelAPORT4XCH1},
{PD10, ADC_0, adcPosSelAPORT3XCH2},
{PD11, ADC_0, adcPosSelAPORT3YCH3},
{PD12, ADC_0, adcPosSelAPORT3XCH4},
{PD13, ADC_0, adcPosSelAPORT3YCH5},
{PD14, ADC_0, adcPosSelAPORT3XCH6},
{PD15, ADC_0, adcPosSelAPORT4XCH7},
{PF0, ADC_0, adcPosSelAPORT1XCH16},
{PF1, ADC_0, adcPosSelAPORT2XCH17},
{PF2, ADC_0, adcPosSelAPORT1XCH18},
{PF3, ADC_0, adcPosSelAPORT2XCH19},
{PF4, ADC_0, adcPosSelAPORT1XCH20},
{PF5, ADC_0, adcPosSelAPORT2XCH21},
{PF6, ADC_0, adcPosSelAPORT1XCH22},
{PF7, ADC_0, adcPosSelAPORT2XCH23},
#endif
{NC , NC , NC}
};
/************I2C SCL***********/
MBED_WEAK const PinMap PinMap_I2C_SCL[] = {
#ifdef I2C0_BASE
/* I2C0 */
{PA1, I2C_0, 0},
{PA2, I2C_0, 1},
{PA3, I2C_0, 2},
{PA4, I2C_0, 3},
{PA5, I2C_0, 4},
{PB11, I2C_0, 5},
{PB12, I2C_0, 6},
{PB13, I2C_0, 7},
{PB14, I2C_0, 8},
{PB15, I2C_0, 9},
{PC6, I2C_0, 10},
{PC7, I2C_0, 11},
{PC8, I2C_0, 12},
{PC9, I2C_0, 13},
{PC10, I2C_0, 14},
{PC11, I2C_0, 15},
{PD9, I2C_0, 16},
{PD10, I2C_0, 17},
{PD11, I2C_0, 18},
{PD12, I2C_0, 19},
{PD13, I2C_0, 20},
{PD14, I2C_0, 21},
{PD15, I2C_0, 22},
{PF0, I2C_0, 23},
{PF1, I2C_0, 24},
{PF2, I2C_0, 25},
{PF3, I2C_0, 26},
{PF4, I2C_0, 27},
{PF5, I2C_0, 28},
{PF6, I2C_0, 29},
{PF7, I2C_0, 30},
{PA0, I2C_0, 31},
#endif
{NC , NC , NC}
};
/************I2C SDA***********/
MBED_WEAK const PinMap PinMap_I2C_SDA[] = {
#ifdef I2C0_BASE
/* I2C0 */
{PA0, I2C_0, 0},
{PA1, I2C_0, 1},
{PA2, I2C_0, 2},
{PA3, I2C_0, 3},
{PA4, I2C_0, 4},
{PA5, I2C_0, 5},
{PB11, I2C_0, 6},
{PB12, I2C_0, 7},
{PB13, I2C_0, 8},
{PB14, I2C_0, 9},
{PB15, I2C_0, 10},
{PC6, I2C_0, 11},
{PC7, I2C_0, 12},
{PC8, I2C_0, 13},
{PC9, I2C_0, 14},
{PC10, I2C_0, 15},
{PC11, I2C_0, 16},
{PD9, I2C_0, 17},
{PD10, I2C_0, 18},
{PD11, I2C_0, 19},
{PD12, I2C_0, 20},
{PD13, I2C_0, 21},
{PD14, I2C_0, 22},
{PD15, I2C_0, 23},
{PF0, I2C_0, 24},
{PF1, I2C_0, 25},
{PF2, I2C_0, 26},
{PF3, I2C_0, 27},
{PF4, I2C_0, 28},
{PF5, I2C_0, 29},
{PF6, I2C_0, 30},
{PF7, I2C_0, 31},
#endif
/* Not connected */
{NC , NC , NC}
};
/************PWM***************/
MBED_WEAK const PinMap PinMap_PWM[] = {
#if defined(TIMER_ROUTE_CC0PEN) || defined(TIMER_ROUTEPEN_CC0PEN)
/* PWM0 */
{PA0, PWM_CH0, 0},
{PB14, PWM_CH0, 9},
{PB15, PWM_CH0, 10},
{PC6, PWM_CH0, 11},
{PD10, PWM_CH0, 18},
{PD14, PWM_CH0, 22},
{PF0, PWM_CH0, 24},
{PF4, PWM_CH0, 28},
#endif
#if defined(TIMER_ROUTE_CC1PEN) || defined(TIMER_ROUTEPEN_CC1PEN)
/* PWM1 */
{PA1, PWM_CH1, 0},
{PB11, PWM_CH1, 5},
{PC7, PWM_CH1, 11},
{PD11, PWM_CH1, 18},
{PD15, PWM_CH1, 22},
{PF1, PWM_CH1, 24},
{PF5, PWM_CH1, 28},
#endif
#if defined(TIMER_ROUTE_CC2PEN) || defined(TIMER_ROUTEPEN_CC2PEN)
/* PWM2 */
{PA2, PWM_CH2, 0},
{PA4, PWM_CH2, 2},
{PB12, PWM_CH2, 5},
{PC8, PWM_CH2, 11},
{PC10, PWM_CH2, 13},
{PD12, PWM_CH2, 18},
{PF2, PWM_CH2, 24},
{PF6, PWM_CH2, 28},
#endif
#if defined(TIMER_ROUTE_CC3PEN) || defined(TIMER_ROUTEPEN_CC3PEN)
/* PWM3 */
{PA3, PWM_CH3, 0},
{PA5, PWM_CH3, 2},
{PB13, PWM_CH3, 5},
{PC9, PWM_CH3, 11},
{PC11, PWM_CH3, 13},
{PD9, PWM_CH3, 14},
{PD13, PWM_CH3, 18},
{PF3, PWM_CH3, 24},
{PF7, PWM_CH3, 28},
#endif
{NC , NC , NC}
};
/*************SPI**************/
MBED_WEAK const PinMap PinMap_SPI_MOSI[] = {
#ifdef USART0_BASE
/* USART0 */
{PA0, SPI_0, 0},
{PA1, SPI_0, 1},
{PA2, SPI_0, 2},
{PA3, SPI_0, 3},
{PA4, SPI_0, 4},
{PA5, SPI_0, 5},
{PB11, SPI_0, 6},
{PB12, SPI_0, 7},
{PB13, SPI_0, 8},
{PB14, SPI_0, 9},
{PB15, SPI_0, 10},
{PD9, SPI_0, 17},
{PD10, SPI_0, 18},
{PD11, SPI_0, 19},
{PD12, SPI_0, 20},
{PD13, SPI_0, 21},
{PD14, SPI_0, 22},
{PD15, SPI_0, 23},
#endif
#ifdef USART1_BASE
/* USART1 */
{PC6, SPI_1, 11},
{PC7, SPI_1, 12},
{PC8, SPI_1, 13},
{PC9, SPI_1, 14},
{PC10, SPI_1, 15},
{PC11, SPI_1, 16},
{PF0, SPI_1, 24},
{PF1, SPI_1, 25},
{PF2, SPI_1, 26},
{PF3, SPI_1, 27},
{PF4, SPI_1, 28},
{PF5, SPI_1, 29},
{PF6, SPI_1, 30},
{PF7, SPI_1, 31},
#endif
{NC , NC , NC}
};
MBED_WEAK const PinMap PinMap_SPI_MISO[] = {
#ifdef USART0_BASE
/* USART0 */
{PA0, SPI_0, 31},
{PA1, SPI_0, 0},
{PA2, SPI_0, 1},
{PA3, SPI_0, 2},
{PA4, SPI_0, 3},
{PA5, SPI_0, 4},
{PB11, SPI_0, 5},
{PB12, SPI_0, 6},
{PB13, SPI_0, 7},
{PB14, SPI_0, 8},
{PB15, SPI_0, 9},
{PD9, SPI_0, 16},
{PD10, SPI_0, 17},
{PD11, SPI_0, 18},
{PD12, SPI_0, 19},
{PD13, SPI_0, 20},
{PD14, SPI_0, 21},
{PD15, SPI_0, 22},
#endif
#ifdef USART1_BASE
/* USART1 */
{PC6, SPI_1, 10},
{PC7, SPI_1, 11},
{PC8, SPI_1, 12},
{PC9, SPI_1, 13},
{PC10, SPI_1, 14},
{PC11, SPI_1, 15},
{PF0, SPI_1, 23},
{PF1, SPI_1, 24},
{PF2, SPI_1, 25},
{PF3, SPI_1, 26},
{PF4, SPI_1, 27},
{PF5, SPI_1, 28},
{PF6, SPI_1, 29},
{PF7, SPI_1, 30},
{PA0, SPI_1, 31},
#endif
{NC , NC , NC}
};
MBED_WEAK const PinMap PinMap_SPI_CLK[] = {
#ifdef USART0_BASE
/* USART0 */
{PA0, SPI_0, 30},
{PA1, SPI_0, 31},
{PA2, SPI_0, 0},
{PA3, SPI_0, 1},
{PA4, SPI_0, 2},
{PA5, SPI_0, 3},
{PB11, SPI_0, 4},
{PB12, SPI_0, 5},
{PB13, SPI_0, 6},
{PB14, SPI_0, 7},
{PB15, SPI_0, 8},
{PD9, SPI_0, 15},
{PD10, SPI_0, 16},
{PD11, SPI_0, 17},
{PD12, SPI_0, 18},
{PD13, SPI_0, 19},
{PD14, SPI_0, 20},
{PD15, SPI_0, 21},
#endif
#ifdef USART1_BASE
/* USART1 */
{PC6, SPI_1, 9},
{PC7, SPI_1, 10},
{PC8, SPI_1, 11},
{PC9, SPI_1, 12},
{PC10, SPI_1, 13},
{PC11, SPI_1, 14},
{PF0, SPI_1, 22},
{PF1, SPI_1, 23},
{PF2, SPI_1, 24},
{PF3, SPI_1, 25},
{PF4, SPI_1, 26},
{PF5, SPI_1, 27},
{PF6, SPI_1, 28},
{PF7, SPI_1, 29},
{PA0, SPI_1, 30},
{PA1, SPI_1, 31},
#endif
{NC , NC , NC}
};
MBED_WEAK const PinMap PinMap_SPI_CS[] = {
#ifdef USART0_BASE
/* USART0 */
{PA0, SPI_0, 29},
{PA1, SPI_0, 30},
{PA2, SPI_0, 31},
{PA3, SPI_0, 0},
{PA4, SPI_0, 1},
{PA5, SPI_0, 2},
{PB11, SPI_0, 3},
{PB12, SPI_0, 4},
{PB13, SPI_0, 5},
{PB14, SPI_0, 6},
{PB15, SPI_0, 7},
{PD9, SPI_0, 14},
{PD10, SPI_0, 15},
{PD11, SPI_0, 16},
{PD12, SPI_0, 17},
{PD13, SPI_0, 18},
{PD14, SPI_0, 19},
{PD15, SPI_0, 20},
#endif
#ifdef USART1_BASE
/* USART1 */
{PC6, SPI_1, 8},
{PC7, SPI_1, 9},
{PC8, SPI_1, 10},
{PC9, SPI_1, 11},
{PC10, SPI_1, 12},
{PC11, SPI_1, 13},
{PF0, SPI_1, 21},
{PF1, SPI_1, 22},
{PF2, SPI_1, 23},
{PF3, SPI_1, 24},
{PF4, SPI_1, 25},
{PF5, SPI_1, 26},
{PF6, SPI_1, 27},
{PF7, SPI_1, 28},
#endif
{NC , NC , NC}
};
/************UART**************/
MBED_WEAK const PinMap PinMap_UART_TX[] = {
#ifdef USART0_BASE
/* USART0 */
{PA0, USART_0, 0},
{PA1, USART_0, 1},
{PA2, USART_0, 2},
{PA3, USART_0, 3},
{PA4, USART_0, 4},
{PA5, USART_0, 5},
{PB11, USART_0, 6},
{PB12, USART_0, 7},
{PB13, USART_0, 8},
{PB14, USART_0, 9},
{PB15, USART_0, 10},
#endif
#ifdef LEUART0_BASE
/* LEUART0 */
{PD9, LEUART_0, 17},
{PD10, LEUART_0, 18},
{PD11, LEUART_0, 19},
{PD12, LEUART_0, 20},
{PD13, LEUART_0, 21},
{PD14, LEUART_0, 22},
{PD15, LEUART_0, 23},
#endif
#ifdef USART1_BASE
/* USART1 */
{PC6, USART_1, 11},
{PC7, USART_1, 12},
{PC8, USART_1, 13},
{PC9, USART_1, 14},
{PC10, USART_1, 15},
{PC11, USART_1, 16},
{PF0, USART_1, 24},
{PF1, USART_1, 25},
{PF2, USART_1, 26},
{PF3, USART_1, 27},
{PF4, USART_1, 28},
{PF5, USART_1, 29},
{PF6, USART_1, 30},
{PF7, USART_1, 31},
#endif
{NC , NC , NC}
};
MBED_WEAK const PinMap PinMap_UART_RX[] = {
#ifdef USART0_BASE
/* USART0 */
{PA0, USART_0, 31},
{PA1, USART_0, 0},
{PA2, USART_0, 1},
{PA3, USART_0, 2},
{PA4, USART_0, 3},
{PA5, USART_0, 4},
{PB11, USART_0, 5},
{PB12, USART_0, 6},
{PB13, USART_0, 7},
{PB14, USART_0, 8},
{PB15, USART_0, 9},
#endif
#ifdef LEUART0_BASE
/* LEUART0 */
{PD9, LEUART_0, 16},
{PD10, LEUART_0, 17},
{PD11, LEUART_0, 18},
{PD12, LEUART_0, 19},
{PD13, LEUART_0, 20},
{PD14, LEUART_0, 21},
{PD15, LEUART_0, 22},
#endif
#ifdef USART1_BASE
/* USART1 */
{PC6, USART_1, 10},
{PC7, USART_1, 11},
{PC8, USART_1, 12},
{PC9, USART_1, 13},
{PC10, USART_1, 14},
{PC11, USART_1, 15},
{PF0, USART_1, 23},
{PF1, USART_1, 24},
{PF2, USART_1, 25},
{PF3, USART_1, 26},
{PF4, USART_1, 27},
{PF5, USART_1, 28},
{PF6, USART_1, 29},
{PF7, USART_1, 30},
#endif
{NC , NC , NC}
};