319 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			319 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /**********************************************************************
 | |
| * $Id$      lpc17xx_pinsel.c                2010-05-21
 | |
| *//**
 | |
| * @file     lpc17xx_pinsel.c
 | |
| * @brief    Contains all functions support for Pin connect block firmware
 | |
| *           library on LPC17xx
 | |
| * @version  2.0
 | |
| * @date     21. May. 2010
 | |
| * @author   NXP MCU SW Application Team
 | |
| *
 | |
| * Copyright(C) 2010, NXP Semiconductor
 | |
| * All rights reserved.
 | |
| *
 | |
| ***********************************************************************
 | |
| * Software that is described herein is for illustrative purposes only
 | |
| * which provides customers with programming information regarding the
 | |
| * products. This software is supplied "AS IS" without any warranties.
 | |
| * NXP Semiconductors assumes no responsibility or liability for the
 | |
| * use of the software, conveys no license or title under any patent,
 | |
| * copyright, or mask work right to the product. NXP Semiconductors
 | |
| * reserves the right to make changes in the software without
 | |
| * notification. NXP Semiconductors also make no representation or
 | |
| * warranty that such application will be suitable for the specified
 | |
| * use without further testing or modification.
 | |
| * Permission to use, copy, modify, and distribute this software and its
 | |
| * documentation is hereby granted, under NXP Semiconductors'
 | |
| * relevant copyright in the software, without fee, provided that it
 | |
| * is used in conjunction with NXP Semiconductors microcontrollers.  This
 | |
| * copyright, permission, and disclaimer notice must appear in all copies of
 | |
| * this code.
 | |
| **********************************************************************/
 | |
| 
 | |
| /* Peripheral group ----------------------------------------------------------- */
 | |
| /** @addtogroup PINSEL
 | |
|  * @{
 | |
|  */
 | |
| 
 | |
| /* Includes ------------------------------------------------------------------- */
 | |
| #include "lpc17xx_pinsel.h"
 | |
| 
 | |
| /* Public Functions ----------------------------------------------------------- */
 | |
| 
 | |
| static void set_PinFunc ( uint8_t portnum, uint8_t pinnum, uint8_t funcnum);
 | |
| static void set_ResistorMode ( uint8_t portnum, uint8_t pinnum, uint8_t modenum);
 | |
| static void set_OpenDrainMode( uint8_t portnum, uint8_t pinnum, uint8_t modenum);
 | |
| 
 | |
| /*********************************************************************//**
 | |
|  * @brief       Setup the pin selection function
 | |
|  * @param[in]   portnum PORT number,
 | |
|  *              should be one of the following:
 | |
|  *              - PINSEL_PORT_0 : Port 0
 | |
|  *              - PINSEL_PORT_1 : Port 1
 | |
|  *              - PINSEL_PORT_2 : Port 2
 | |
|  *              - PINSEL_PORT_3 : Port 3
 | |
|  *
 | |
|  * @param[in]   pinnum  Pin number,
 | |
|  *              should be one of the following:
 | |
|                 - PINSEL_PIN_0 : Pin 0
 | |
|                 - PINSEL_PIN_1 : Pin 1
 | |
|                 - PINSEL_PIN_2 : Pin 2
 | |
|                 - PINSEL_PIN_3 : Pin 3
 | |
|                 - PINSEL_PIN_4 : Pin 4
 | |
|                 - PINSEL_PIN_5 : Pin 5
 | |
|                 - PINSEL_PIN_6 : Pin 6
 | |
|                 - PINSEL_PIN_7 : Pin 7
 | |
|                 - PINSEL_PIN_8 : Pin 8
 | |
|                 - PINSEL_PIN_9 : Pin 9
 | |
|                 - PINSEL_PIN_10 : Pin 10
 | |
|                 - PINSEL_PIN_11 : Pin 11
 | |
|                 - PINSEL_PIN_12 : Pin 12
 | |
|                 - PINSEL_PIN_13 : Pin 13
 | |
|                 - PINSEL_PIN_14 : Pin 14
 | |
|                 - PINSEL_PIN_15 : Pin 15
 | |
|                 - PINSEL_PIN_16 : Pin 16
 | |
|                 - PINSEL_PIN_17 : Pin 17
 | |
|                 - PINSEL_PIN_18 : Pin 18
 | |
|                 - PINSEL_PIN_19 : Pin 19
 | |
|                 - PINSEL_PIN_20 : Pin 20
 | |
|                 - PINSEL_PIN_21 : Pin 21
 | |
|                 - PINSEL_PIN_22 : Pin 22
 | |
|                 - PINSEL_PIN_23 : Pin 23
 | |
|                 - PINSEL_PIN_24 : Pin 24
 | |
|                 - PINSEL_PIN_25 : Pin 25
 | |
|                 - PINSEL_PIN_26 : Pin 26
 | |
|                 - PINSEL_PIN_27 : Pin 27
 | |
|                 - PINSEL_PIN_28 : Pin 28
 | |
|                 - PINSEL_PIN_29 : Pin 29
 | |
|                 - PINSEL_PIN_30 : Pin 30
 | |
|                 - PINSEL_PIN_31 : Pin 31
 | |
| 
 | |
|  * @param[in]   funcnum Function number,
 | |
|  *              should be one of the following:
 | |
|  *              - PINSEL_FUNC_0 : default function
 | |
|  *              - PINSEL_FUNC_1 : first alternate function
 | |
|  *              - PINSEL_FUNC_2 : second alternate function
 | |
|  *              - PINSEL_FUNC_3 : third alternate function
 | |
|  *
 | |
|  * @return      None
 | |
|  **********************************************************************/
 | |
| static void set_PinFunc ( uint8_t portnum, uint8_t pinnum, uint8_t funcnum)
 | |
| {
 | |
|     uint32_t pinnum_t = pinnum;
 | |
|     uint32_t pinselreg_idx = 2 * portnum;
 | |
|     uint32_t *pPinCon = (uint32_t *)&LPC_PINCON->PINSEL0;
 | |
| 
 | |
|     if (pinnum_t >= 16) {
 | |
|         pinnum_t -= 16;
 | |
|         pinselreg_idx++;
 | |
|     }
 | |
|     *(uint32_t *)(pPinCon + pinselreg_idx) &= ~(0x03UL << (pinnum_t * 2));
 | |
|     *(uint32_t *)(pPinCon + pinselreg_idx) |= ((uint32_t)funcnum) << (pinnum_t * 2);
 | |
| }
 | |
| 
 | |
| /*********************************************************************//**
 | |
|  * @brief       Setup resistor mode for each pin
 | |
|  * @param[in]   portnum PORT number,
 | |
|  *              should be one of the following:
 | |
|  *              - PINSEL_PORT_0 : Port 0
 | |
|  *              - PINSEL_PORT_1 : Port 1
 | |
|  *              - PINSEL_PORT_2 : Port 2
 | |
|  *              - PINSEL_PORT_3 : Port 3
 | |
|  * @param[in]   pinnum  Pin number,
 | |
|  *              should be one of the following:
 | |
|                 - PINSEL_PIN_0 : Pin 0
 | |
|                 - PINSEL_PIN_1 : Pin 1
 | |
|                 - PINSEL_PIN_2 : Pin 2
 | |
|                 - PINSEL_PIN_3 : Pin 3
 | |
|                 - PINSEL_PIN_4 : Pin 4
 | |
|                 - PINSEL_PIN_5 : Pin 5
 | |
|                 - PINSEL_PIN_6 : Pin 6
 | |
|                 - PINSEL_PIN_7 : Pin 7
 | |
|                 - PINSEL_PIN_8 : Pin 8
 | |
|                 - PINSEL_PIN_9 : Pin 9
 | |
|                 - PINSEL_PIN_10 : Pin 10
 | |
|                 - PINSEL_PIN_11 : Pin 11
 | |
|                 - PINSEL_PIN_12 : Pin 12
 | |
|                 - PINSEL_PIN_13 : Pin 13
 | |
|                 - PINSEL_PIN_14 : Pin 14
 | |
|                 - PINSEL_PIN_15 : Pin 15
 | |
|                 - PINSEL_PIN_16 : Pin 16
 | |
|                 - PINSEL_PIN_17 : Pin 17
 | |
|                 - PINSEL_PIN_18 : Pin 18
 | |
|                 - PINSEL_PIN_19 : Pin 19
 | |
|                 - PINSEL_PIN_20 : Pin 20
 | |
|                 - PINSEL_PIN_21 : Pin 21
 | |
|                 - PINSEL_PIN_22 : Pin 22
 | |
|                 - PINSEL_PIN_23 : Pin 23
 | |
|                 - PINSEL_PIN_24 : Pin 24
 | |
|                 - PINSEL_PIN_25 : Pin 25
 | |
|                 - PINSEL_PIN_26 : Pin 26
 | |
|                 - PINSEL_PIN_27 : Pin 27
 | |
|                 - PINSEL_PIN_28 : Pin 28
 | |
|                 - PINSEL_PIN_29 : Pin 29
 | |
|                 - PINSEL_PIN_30 : Pin 30
 | |
|                 - PINSEL_PIN_31 : Pin 31
 | |
| 
 | |
|  * @param[in]   modenum: Mode number,
 | |
|  *              should be one of the following:
 | |
|                 - PINSEL_PINMODE_PULLUP : Internal pull-up resistor
 | |
|                 - PINSEL_PINMODE_TRISTATE : Tri-state
 | |
|                 - PINSEL_PINMODE_PULLDOWN : Internal pull-down resistor
 | |
| 
 | |
|  * @return      None
 | |
|  **********************************************************************/
 | |
| void set_ResistorMode ( uint8_t portnum, uint8_t pinnum, uint8_t modenum)
 | |
| {
 | |
|     uint32_t pinnum_t = pinnum;
 | |
|     uint32_t pinmodereg_idx = 2 * portnum;
 | |
|     uint32_t *pPinCon = (uint32_t *)&LPC_PINCON->PINMODE0;
 | |
| 
 | |
|     if (pinnum_t >= 16) {
 | |
|         pinnum_t -= 16;
 | |
|         pinmodereg_idx++ ;
 | |
|     }
 | |
| 
 | |
|     *(uint32_t *)(pPinCon + pinmodereg_idx) &= ~(0x03UL << (pinnum_t * 2));
 | |
|     *(uint32_t *)(pPinCon + pinmodereg_idx) |= ((uint32_t)modenum) << (pinnum_t * 2);
 | |
| }
 | |
| 
 | |
| /*********************************************************************//**
 | |
|  * @brief       Setup Open drain mode for each pin
 | |
|  * @param[in]   portnum PORT number,
 | |
|  *              should be one of the following:
 | |
|  *              - PINSEL_PORT_0 : Port 0
 | |
|  *              - PINSEL_PORT_1 : Port 1
 | |
|  *              - PINSEL_PORT_2 : Port 2
 | |
|  *              - PINSEL_PORT_3 : Port 3
 | |
|  *
 | |
|  * @param[in]   pinnum  Pin number,
 | |
|  *              should be one of the following:
 | |
|                 - PINSEL_PIN_0 : Pin 0
 | |
|                 - PINSEL_PIN_1 : Pin 1
 | |
|                 - PINSEL_PIN_2 : Pin 2
 | |
|                 - PINSEL_PIN_3 : Pin 3
 | |
|                 - PINSEL_PIN_4 : Pin 4
 | |
|                 - PINSEL_PIN_5 : Pin 5
 | |
|                 - PINSEL_PIN_6 : Pin 6
 | |
|                 - PINSEL_PIN_7 : Pin 7
 | |
|                 - PINSEL_PIN_8 : Pin 8
 | |
|                 - PINSEL_PIN_9 : Pin 9
 | |
|                 - PINSEL_PIN_10 : Pin 10
 | |
|                 - PINSEL_PIN_11 : Pin 11
 | |
|                 - PINSEL_PIN_12 : Pin 12
 | |
|                 - PINSEL_PIN_13 : Pin 13
 | |
|                 - PINSEL_PIN_14 : Pin 14
 | |
|                 - PINSEL_PIN_15 : Pin 15
 | |
|                 - PINSEL_PIN_16 : Pin 16
 | |
|                 - PINSEL_PIN_17 : Pin 17
 | |
|                 - PINSEL_PIN_18 : Pin 18
 | |
|                 - PINSEL_PIN_19 : Pin 19
 | |
|                 - PINSEL_PIN_20 : Pin 20
 | |
|                 - PINSEL_PIN_21 : Pin 21
 | |
|                 - PINSEL_PIN_22 : Pin 22
 | |
|                 - PINSEL_PIN_23 : Pin 23
 | |
|                 - PINSEL_PIN_24 : Pin 24
 | |
|                 - PINSEL_PIN_25 : Pin 25
 | |
|                 - PINSEL_PIN_26 : Pin 26
 | |
|                 - PINSEL_PIN_27 : Pin 27
 | |
|                 - PINSEL_PIN_28 : Pin 28
 | |
|                 - PINSEL_PIN_29 : Pin 29
 | |
|                 - PINSEL_PIN_30 : Pin 30
 | |
|                 - PINSEL_PIN_31 : Pin 31
 | |
| 
 | |
|  * @param[in]   modenum  Open drain mode number,
 | |
|  *              should be one of the following:
 | |
|  *              - PINSEL_PINMODE_NORMAL : Pin is in the normal (not open drain) mode
 | |
|  *              - PINSEL_PINMODE_OPENDRAIN : Pin is in the open drain mode
 | |
|  *
 | |
|  * @return      None
 | |
|  **********************************************************************/
 | |
| void set_OpenDrainMode( uint8_t portnum, uint8_t pinnum, uint8_t modenum)
 | |
| {
 | |
|     uint32_t *pPinCon = (uint32_t *)&LPC_PINCON->PINMODE_OD0;
 | |
| 
 | |
|     if (modenum == PINSEL_PINMODE_OPENDRAIN){
 | |
|         *(uint32_t *)(pPinCon + portnum) |= (0x01UL << pinnum);
 | |
|     } else {
 | |
|         *(uint32_t *)(pPinCon + portnum) &= ~(0x01UL << pinnum);
 | |
|     }
 | |
| }
 | |
| 
 | |
| /* End of Public Functions ---------------------------------------------------- */
 | |
| 
 | |
| /* Public Functions ----------------------------------------------------------- */
 | |
| /** @addtogroup PINSEL_Public_Functions
 | |
|  * @{
 | |
|  */
 | |
| /*********************************************************************//**
 | |
|  * @brief       Configure trace function
 | |
|  * @param[in]   NewState State of the Trace function configuration,
 | |
|  *              should be one of the following:
 | |
|  *              - ENABLE : Enable Trace Function
 | |
|  *              - DISABLE : Disable Trace Function
 | |
|  *
 | |
|  * @return      None
 | |
|  **********************************************************************/
 | |
| void PINSEL_ConfigTraceFunc(FunctionalState NewState)
 | |
| {
 | |
|     if (NewState == ENABLE) {
 | |
|         LPC_PINCON->PINSEL10 |= (0x01UL << 3);
 | |
|     } else if (NewState == DISABLE) {
 | |
|         LPC_PINCON->PINSEL10 &= ~(0x01UL << 3);
 | |
|     }
 | |
| }
 | |
| 
 | |
| /*********************************************************************//**
 | |
|  * @brief       Setup I2C0 pins
 | |
|  * @param[in]   i2cPinMode I2C pin mode,
 | |
|  *              should be one of the following:
 | |
|  *              - PINSEL_I2C_Normal_Mode : The standard drive mode
 | |
|  *              - PINSEL_I2C_Fast_Mode : Fast Mode Plus drive mode
 | |
|  *
 | |
|  * @param[in]   filterSlewRateEnable  should be:
 | |
|  *              - ENABLE: Enable filter and slew rate.
 | |
|  *              - DISABLE: Disable filter and slew rate.
 | |
|  *
 | |
|  * @return      None
 | |
|  **********************************************************************/
 | |
| void PINSEL_SetI2C0Pins(uint8_t i2cPinMode, FunctionalState filterSlewRateEnable)
 | |
| {
 | |
|     uint32_t regVal;
 | |
| 
 | |
|     if (i2cPinMode == PINSEL_I2C_Fast_Mode){
 | |
|         regVal = PINSEL_I2CPADCFG_SCLDRV0 | PINSEL_I2CPADCFG_SDADRV0;
 | |
|     }
 | |
| 
 | |
|     if (filterSlewRateEnable == DISABLE){
 | |
|         regVal = PINSEL_I2CPADCFG_SCLI2C0 | PINSEL_I2CPADCFG_SDAI2C0;
 | |
|     }
 | |
|     LPC_PINCON->I2CPADCFG = regVal;
 | |
| }
 | |
| 
 | |
| 
 | |
| /*********************************************************************//**
 | |
|  * @brief       Configure Pin corresponding to specified parameters passed
 | |
|  *              in the PinCfg
 | |
|  * @param[in]   PinCfg  Pointer to a PINSEL_CFG_Type structure
 | |
|  *                    that contains the configuration information for the
 | |
|  *                    specified pin.
 | |
|  * @return      None
 | |
|  **********************************************************************/
 | |
| void PINSEL_ConfigPin(PINSEL_CFG_Type *PinCfg)
 | |
| {
 | |
|     set_PinFunc(PinCfg->Portnum, PinCfg->Pinnum, PinCfg->Funcnum);
 | |
|     set_ResistorMode(PinCfg->Portnum, PinCfg->Pinnum, PinCfg->Pinmode);
 | |
|     set_OpenDrainMode(PinCfg->Portnum, PinCfg->Pinnum, PinCfg->OpenDrain);
 | |
| }
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * @}
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * @}
 | |
|  */
 | |
| 
 | |
| /* --------------------------------- End Of File ------------------------------ */
 | 
