123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540 |
- /**********************************************************************
- * $Id$ lpc_pinsel.c 2011-06-02
- *//**
- * @file lpc_pinsel.c
- * @brief Contains all functions support for Pin-connection block
- * firmware library on LPC
- * @version 1.0
- * @date 02. June. 2011
- * @author NXP MCU SW Application Team
- *
- * Copyright(C) 2011, 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
- * @{
- */
- #ifdef __BUILD_WITH_EXAMPLE__
- #include "lpc_libcfg.h"
- #else
- #include "lpc_libcfg_default.h"
- #endif /* __BUILD_WITH_EXAMPLE__ */
- #ifdef _PINSEL
- /* Includes ------------------------------------------------------------------- */
- #include "lpc_pinsel.h"
- /* Private Functions ---------------------------------------------------------- */
- /*********************************************************************//**
- * @brief Get pointer to GPIO peripheral due to GPIO port
- * @param[in] portnum Port Number value, should be in range from 0..3.
- * @param[in] pinnum Pin number value, should be in range from 0..31
- * @return Pointer to GPIO peripheral
- **********************************************************************/
- static uint32_t * PIN_GetPointer(uint8_t portnum, uint8_t pinnum)
- {
- uint32_t *pPIN = NULL;
- pPIN = (uint32_t *)(LPC_IOCON_BASE + ((portnum * 32 + pinnum)*sizeof(uint32_t)));
- return pPIN;
- }
- /* Public Functions ----------------------------------------------------------- */
- /** @addtogroup PINSEL_Public_Functions
- * @{
- */
- /*********************************************************************//**
- * @brief Get type of a pin.
- * @param[in] portnum PORT number, should be in range: 0..3
- * @param[in] pinnum Pin number, should be in range: 0..31
- * @return Port type:
- * - PINSEL_PIN_TYPE_D
- * - PINSEL_PIN_TYPE_A
- * - PINSEL_PIN_TYPE_I
- * - PINSEL_PIN_TYPE_W
- * - PINSEL_PIN_TYPE_U
- * - PINSEL_PIN_TYPE_UNKNOWN: Invalid pin
- **********************************************************************/
- PinSel_PinType PINSEL_GetPinType(uint8_t portnum, uint8_t pinnum)
- {
- PinSel_PinType Ret = PINSEL_PIN_TYPE_UNKNOWN;
- switch(portnum)
- {
- case 0:
- if((pinnum <=6)||
- ((pinnum >= 10)&&(pinnum <=11))||
- ((pinnum >= 14)&&(pinnum <=22)))
- Ret = PINSEL_PIN_TYPE_D;
- else if ((pinnum == 12)||(pinnum==13)||
- ((pinnum >= 23)&&(pinnum <=26)))
- Ret = PINSEL_PIN_TYPE_A;
- else if ((pinnum == 29) || (pinnum==30)|| (pinnum==31))
- Ret = PINSEL_PIN_TYPE_U;
- else if ((pinnum == 27) || (pinnum==28))
- Ret = PINSEL_PIN_TYPE_I;
- else if ((pinnum == 7) || (pinnum==8)|| (pinnum==9))
- Ret = PINSEL_PIN_TYPE_W;
- break;
- case 1:
- if(pinnum <=29)
- Ret = PINSEL_PIN_TYPE_D;
- else if ((pinnum == 30) || (pinnum==31))
- Ret = PINSEL_PIN_TYPE_A;
- break;
- case 2:
- case 3:
- case 4:
- Ret = PINSEL_PIN_TYPE_D;
- break;
- case 5:
- if((pinnum <=1)||
- (pinnum == 4))
- Ret = PINSEL_PIN_TYPE_D;
- else if ((pinnum == 2) || (pinnum==3))
- Ret = PINSEL_PIN_TYPE_I;
- break;
- default:
- break;
- }
- return Ret;
- }
- /*********************************************************************//**
- * @brief Setup the pin selection function
- * @param[in] portnum PORT number, should be in range: 0..3
- * @param[in] pinnum Pin number, should be in range: 0..31
- * @param[in] funcnum Function number, should be range: 0..7
- * - 0: Select GPIO (Default)
- * - 1: Selects the 1st alternate function
- * - 2: Selects the 2nd alternate function
- * ...
- * - 7: Selects the 7th alternate function
- * @return PINSEL Return Code
- * - PINSEL_RET_INVALID_PIN
- * - PINSEL_RET_OK
- **********************************************************************/
- PINSEL_RET_CODE PINSEL_ConfigPin ( uint8_t portnum, uint8_t pinnum, uint8_t funcnum)
- {
- uint32_t *pPIN = NULL;
- PinSel_PinType type = PINSEL_GetPinType(portnum,pinnum);
- if(type == PINSEL_PIN_TYPE_UNKNOWN)
- return PINSEL_RET_INVALID_PIN;
-
- pPIN = PIN_GetPointer(portnum, pinnum);
- *pPIN &= ~IOCON_FUNC_MASK;//Clear function bits
- *pPIN |= funcnum&IOCON_FUNC_MASK;
- return PINSEL_RET_OK;
- }
- /*********************************************************************//**
- * @brief Setup resistor mode for pin of type D,A,W
- * @param[in] portnum PORT number, should be in range: 0..3
- * @param[in] pinnum Pin number, should be in range: 0..31
- * @param[in] modenum: Mode number, should be in range: 0..3
- - PINSEL_BASICMODE_PLAINOUT: Plain output
- - PINSEL_BASICMODE_PULLDOWN: Pull-down enable
- - PINSEL_BASICMODE_PULLUP: Pull-up enable
- - PINSEL_BASICMODE_REPEATER: Repeater mode
- * @return PINSEL Return Code
- * - PINSEL_RET_INVALID_PIN
- * - PINSEL_RET_NOT_SUPPORT
- * - PINSEL_RET_OK
- **********************************************************************/
- PINSEL_RET_CODE PINSEL_SetPinMode ( uint8_t portnum, uint8_t pinnum, PinSel_BasicMode modenum)
- {
- uint32_t *pPIN = NULL;
- PinSel_PinType type = PINSEL_GetPinType(portnum,pinnum);
- if(type == PINSEL_PIN_TYPE_UNKNOWN)
- return PINSEL_RET_INVALID_PIN;
- if((type != PINSEL_PIN_TYPE_D )&&
- (type != PINSEL_PIN_TYPE_A )&&
- (type != PINSEL_PIN_TYPE_W))
- return PINSEL_RET_NOT_SUPPORT;
-
- pPIN = PIN_GetPointer(portnum, pinnum);
- *(uint32_t *)pPIN &= ~(IOCON_MODE_MASK);//Clear function bits
- *(uint32_t *)pPIN |= (modenum << IOCON_MODE_POS)&IOCON_MODE_MASK;
- return PINSEL_RET_OK;
- }
- /*********************************************************************//**
- * @brief Setup hysteresis for pin of type D, W
- * @param[in] portnum Port number, should be in range: 0..3
- * @param[in] pinnum Pin number, should be in range: 0..31
- * @param[in] NewState new state of Hysteresis mode, should be:
- * - ENABLE: Hysteresis enable
- * - DISABLE: Hysteresis disable
- * @return PINSEL Return Code
- * - PINSEL_RET_INVALID_PIN
- * - PINSEL_RET_NOT_SUPPORT
- * - PINSEL_RET_OK
- **********************************************************************/
- PINSEL_RET_CODE PINSEL_SetHysMode(uint8_t portnum, uint8_t pinnum, FunctionalState NewState)
- {
- uint32_t *pPIN = NULL;
- PinSel_PinType type = PINSEL_GetPinType(portnum,pinnum);
- if(type == PINSEL_PIN_TYPE_UNKNOWN)
- return PINSEL_RET_INVALID_PIN;
- if((type != PINSEL_PIN_TYPE_D )&&
- (type != PINSEL_PIN_TYPE_W))
- return PINSEL_RET_NOT_SUPPORT;
-
- pPIN = PIN_GetPointer(portnum, pinnum);
- if(NewState == DISABLE)
- {
- *(uint32_t *)pPIN &= ~IOCON_HYS_ENABLE;//Clear hys bits
- }
- else
- *(uint32_t *)pPIN |= IOCON_HYS_ENABLE;
- return PINSEL_RET_OK;
- }
- /*********************************************************************//**
- * @brief Setup input polarity for pin of type A,I,D,W
- * @param[in] portnum Port number, should be in range: 0..3
- * @param[in] pinnum Pin number, should be in range: 0..31
- * @param[in] NewState new state of Invert mode, should be:
- * - ENABLE: Input is inverted.
- * - DISABLE: Input isn't inverted.
- * @return PINSEL Return Code
- * - PINSEL_RET_INVALID_PIN
- * - PINSEL_RET_NOT_SUPPORT
- * - PINSEL_RET_OK
- **********************************************************************/
- PINSEL_RET_CODE PINSEL_SetInvertInput(uint8_t portnum, uint8_t pinnum, FunctionalState NewState)
- {
- uint32_t *pPIN = NULL;
- PinSel_PinType type = PINSEL_GetPinType(portnum,pinnum);
- if(type == PINSEL_PIN_TYPE_UNKNOWN)
- return PINSEL_RET_INVALID_PIN;
- if(type== PINSEL_PIN_TYPE_U)
- return PINSEL_RET_NOT_SUPPORT;
-
- pPIN = PIN_GetPointer(portnum, pinnum);
- if(NewState == DISABLE)
- {
- *(uint32_t *)pPIN &= ~IOCON_INVERT_INPUT;//Clear hys bits
- }
- else
- *(uint32_t *)pPIN |= IOCON_INVERT_INPUT;
- return PINSEL_RET_OK;
- }
- /*********************************************************************//**
- * @brief Setup Slew rate for pin of type D,W
- * @param[in] portnum Port number, should be in range: 0..3
- * @param[in] pinnum Pin number, should be in range: 0..31
- * @param[in] NewState new state of Slew rate control, should be:
- * - ENABLE: Output slew rate control is enable
- * - DISABLE: Output slew rate control is disable
- * @return PINSEL Return Code
- * - PINSEL_RET_INVALID_PIN
- * - PINSEL_RET_NOT_SUPPORT
- * - PINSEL_RET_OK
- **********************************************************************/
- PINSEL_RET_CODE PINSEL_SetSlewMode(uint8_t portnum, uint8_t pinnum, FunctionalState NewState)
- {
- uint32_t *pPIN = NULL;
- PinSel_PinType type = PINSEL_GetPinType(portnum,pinnum);
- if(type == PINSEL_PIN_TYPE_UNKNOWN)
- return PINSEL_RET_INVALID_PIN;
- if((type!= PINSEL_PIN_TYPE_D) &&
- (type!= PINSEL_PIN_TYPE_W))
- return PINSEL_RET_NOT_SUPPORT;
-
- pPIN = PIN_GetPointer(portnum, pinnum);
- if(NewState == DISABLE)
- {
- *(uint32_t *)pPIN &= ~IOCON_SLEW_ENABLE;//Clear hys bits
- }
- else
- *(uint32_t *)pPIN |= IOCON_SLEW_ENABLE;
- return PINSEL_RET_OK;
- }
- /*********************************************************************//**
- * @brief Setup I2CMode for only pins that provide special I2C functionality
- * @param[in] portnum Port number, should be in range: 0..3
- * @param[in] pinnum Pin number, should be in range: 0..31
- * @param[in] I2CMode I2C mode, should be:
- * - PINSEL_I2CMODE_FAST_STANDARD: Fast mode and standard I2C mode
- * - PINSEL_I2CMODE_OPENDRAINIO: Open drain I/O
- * - PINSEL_I2CMODE_FASTMODEPLUS: Fast Mode Plus I/O
- * @return PINSEL Return Code
- * - PINSEL_RET_INVALID_PIN
- * - PINSEL_RET_NOT_SUPPORT
- * - PINSEL_RET_OK
- **********************************************************************/
- PINSEL_RET_CODE PINSEL_SetI2CMode(uint8_t portnum, uint8_t pinnum, PinSel_I2cMode I2CMode)
- {
- uint32_t *pPIN = NULL;
- PinSel_PinType type = PINSEL_GetPinType(portnum,pinnum);
- if(type == PINSEL_PIN_TYPE_UNKNOWN)
- return PINSEL_RET_INVALID_PIN;
- if(type != PINSEL_PIN_TYPE_I )
- return PINSEL_RET_NOT_SUPPORT;
-
- pPIN = PIN_GetPointer(portnum, pinnum);
- switch(I2CMode)
- {
- // Standard/Fast Mode I2C: HS = HIDRIVE = 0
- case PINSEL_I2CMODE_FAST_STANDARD:
- PINSEL_SetI2CFilter(portnum,pinnum,ENABLE);
- *(uint32_t *)pPIN &= ~(IOCON_I2CMODE_FASTPLUS);
- break;
- // Non-I2C: HS = 1, HIDRIVE = 0
- case PINSEL_I2CMODE_OPENDRAINIO:
- PINSEL_SetI2CFilter(portnum,pinnum,DISABLE);
- *(uint32_t *)pPIN &= ~(IOCON_I2CMODE_FASTPLUS);
- break;
- // Fast Mode Plus I2C: HS = 0, HIDRIVE =1
- case PINSEL_I2CMODE_FASTMODEPLUS:
- PINSEL_SetI2CFilter(portnum,pinnum,ENABLE);
- *(uint32_t *)pPIN |= (IOCON_I2CMODE_FASTPLUS);
- break;
- default:
- return PINSEL_RET_ERR;
- }
- return PINSEL_RET_OK;
- }
- /*********************************************************************//**
- * @brief Setup Open-drain mode in pin of type D, A, W
- * @param[in] portnum Port number, should be in range: 0..3
- * @param[in] pinnum Pin number, should be in range: 0..31
- * @param[in] NewState new state of Open-drain mode:
- * - DISABLE: Normal pin I/O mode
- * - ENABLE: Open-drain enable
- * @return PINSEL Return Code
- * - PINSEL_RET_INVALID_PIN
- * - PINSEL_RET_NOT_SUPPORT
- * - PINSEL_RET_OK
- **********************************************************************/
- PINSEL_RET_CODE PINSEL_SetOpenDrainMode(uint8_t portnum, uint8_t pinnum, FunctionalState NewState)
- {
- uint32_t *pPIN = NULL;
- PinSel_PinType type = PINSEL_GetPinType(portnum,pinnum);
- if(type == PINSEL_PIN_TYPE_UNKNOWN)
- return PINSEL_RET_INVALID_PIN;
- if((type != PINSEL_PIN_TYPE_D ) &&
- (type != PINSEL_PIN_TYPE_A ) &&
- (type != PINSEL_PIN_TYPE_W ))
- return PINSEL_RET_NOT_SUPPORT;
-
- pPIN = PIN_GetPointer(portnum, pinnum);
- if(NewState == DISABLE)
- {
- *(uint32_t *)pPIN &= ~IOCON_OPENDRAIN_MODE;//Clear hys bits
- }
- else
- {
- *(uint32_t *)pPIN |= IOCON_OPENDRAIN_MODE;
- }
- return PINSEL_RET_OK;
- }
- /*********************************************************************//**
- * @brief Enable the Analog mode for each pin of Type A(default is as Digital pins)
- * @param[in] portnum PORT number, should be in range: 0..3
- * @param[in] pinnum Pin number, should be in range: 0..31
- * @param[in] enable: the state of the pin that is expected to run
- - ENABLE: Enable the DAC mode of the pin
- - DISABLE: Disable the DAC mode
- * @return PINSEL Return Code
- * - PINSEL_RET_INVALID_PIN
- * - PINSEL_RET_NOT_SUPPORT
- * - PINSEL_RET_OK
- **********************************************************************/
- PINSEL_RET_CODE PINSEL_SetAnalogPinMode (uint8_t portnum, uint8_t pinnum, uint8_t enable)
- {
- uint32_t *pPIN = NULL;
- PinSel_PinType type = PINSEL_GetPinType(portnum,pinnum);
- if(type == PINSEL_PIN_TYPE_UNKNOWN)
- return PINSEL_RET_INVALID_PIN;
- if(type != PINSEL_PIN_TYPE_A )
- return PINSEL_RET_NOT_SUPPORT;
- pPIN = PIN_GetPointer(portnum, pinnum);
- if(enable)
- {
- *(uint32_t *)pPIN &= ~(IOCON_DIGITIAL_MODE);
- }
- else
- {
- *(uint32_t *)pPIN |= IOCON_DIGITIAL_MODE;//Set 7th bit to one
- }
- return PINSEL_RET_OK;
- }
- /*********************************************************************//**
- * @brief Choose the DAC mode for pin P0.26
- * @param[in] portnum PORT number, should be in range: 0..3
- * @param[in] pinnum Pin number, should be in range: 0..31
- * @param[in] enable: the state of the pin that is expected to run
- - ENABLE: Enable the DAC mode of the pin
- - DISABLE: Disable the DAC mode
- * @return PINSEL Return Code
- * - PINSEL_RET_INVALID_PIN
- * - PINSEL_RET_NOT_SUPPORT
- * - PINSEL_RET_OK
- **********************************************************************/
- PINSEL_RET_CODE PINSEL_DacEnable (uint8_t portnum, uint8_t pinnum, uint8_t enable)
- {
- uint32_t *pPIN = NULL;
-
- PinSel_PinType type = PINSEL_GetPinType(portnum,pinnum);
-
- if(type == PINSEL_PIN_TYPE_UNKNOWN)
- return PINSEL_RET_INVALID_PIN;
- // This setting is only for DAC pin (output pin)
- if(!((portnum == 0) && (pinnum == 26)))
- {
- return PINSEL_RET_NOT_SUPPORT;
- }
- pPIN = PIN_GetPointer(portnum, pinnum);
- if(enable)
- {
- *(uint32_t *)pPIN |= IOCON_DAC_ENABLE;//Set 16th bit to one
- }
- else
- {
- *(uint32_t *)pPIN &= ~IOCON_DAC_ENABLE;//Set 16th bit to one
- }
- return PINSEL_RET_OK;
- }
- /*********************************************************************//**
- * @brief Control the 10ns glitch filter for pin of type A,W
- * @param[in] portnum PORT number, should be in range: 0..3
- * @param[in] pinnum Pin number, should be in range: 0..31
- * @param[in] enable: the state of the pin that is expected to run
- - ENABLE: The noise pulses below approximately 10ns are filtered out
- - DISABLE: No input filtering is done.
- * @return PINSEL Return Code
- * - PINSEL_RET_INVALID_PIN
- * - PINSEL_RET_NOT_SUPPORT
- * - PINSEL_RET_OK
- **********************************************************************/
- PINSEL_RET_CODE PINSEL_SetFilter (uint8_t portnum, uint8_t pinnum, uint8_t enable)
- {
- uint32_t *pPIN = NULL;
- PinSel_PinType type = PINSEL_GetPinType(portnum,pinnum);
-
- if(type == PINSEL_PIN_TYPE_UNKNOWN)
- return PINSEL_RET_INVALID_PIN;
- if((type != PINSEL_PIN_TYPE_A ) &&
- (type != PINSEL_PIN_TYPE_W ))
- return PINSEL_RET_NOT_SUPPORT;
- pPIN = PIN_GetPointer(portnum, pinnum);
- if(enable)
- {
- *(uint32_t *)pPIN &= ~(IOCON_10ns_FILTER_DISABLE);//Clear 8th bit to 0
- }
- else
- {
- *(uint32_t *)pPIN |= (IOCON_10ns_FILTER_DISABLE);//Set 8th bit to one
- }
- return PINSEL_RET_OK;
- }
- /*********************************************************************//**
- * @brief Control the 50ns glitch filter for I2C pins (type I)
- * @param[in] portnum PORT number, should be in range: 0..3
- * @param[in] pinnum Pin number, should be in range: 0..31
- * @param[in] enable: the state of the pin that is expected to run
- - ENABLE: The noise pulses below approximately 10ns are filtered out
- - DISABLE: No input filtering is done.
- * @return PINSEL Return Code
- * - PINSEL_RET_INVALID_PIN
- * - PINSEL_RET_NOT_SUPPORT
- * - PINSEL_RET_OK
- **********************************************************************/
- PINSEL_RET_CODE PINSEL_SetI2CFilter (uint8_t portnum, uint8_t pinnum, uint8_t enable)
- {
- uint32_t *pPIN = NULL;
- PinSel_PinType type = PINSEL_GetPinType(portnum,pinnum);
-
- if(type == PINSEL_PIN_TYPE_UNKNOWN)
- return PINSEL_RET_INVALID_PIN;
- if(type != PINSEL_PIN_TYPE_I)
- return PINSEL_RET_NOT_SUPPORT;
- pPIN = PIN_GetPointer(portnum, pinnum);
- if(enable)
- {
- *(uint32_t *)pPIN &= ~(IOCON_HS_MASK);//Clear 8th bit to 0
- }
- else
- {
- *(uint32_t *)pPIN |= (IOCON_I2C_FILTER_DISABLE);//Set 8th bit to one
- }
- return PINSEL_RET_OK;
- }
- /**
- * @}
- */
- #endif /*_PINSEL*/
- /**
- * @}
- */
- /* --------------------------------- End Of File ------------------------------ */
|