123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199 |
- /**********************************************************************
- * $Id$ lpc_pinsel.h 2011-06-02
- *//**
- * @file lpc_pinsel.h
- * @brief Contains all macro definitions and function prototypes
- * 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 ----------------------------------------------------------- */
- /** @defgroup PINSEL PINSEL (Pin Selection)
- * @ingroup LPC_CMSIS_FwLib_Drivers
- * @{
- */
- #ifndef __LPC_PINSEL_H
- #define __LPC_PINSEL_H
- /* Includes ------------------------------------------------------------------- */
- #include "LPC407x_8x_177x_8x.h"
- #include "lpc_types.h"
- /* Public Macros -------------------------------------------------------------- */
- /** @defgroup PINSEL_Public_Macros PINSEL Public Macros
- * @{
- */
- /* Macros define IOCON bits*/
- /** Selects pin functions */
- #define IOCON_FUNC_POS (0)
- #define IOCON_FUNC_MASK (0x07<<IOCON_FUNC_POS)
- /** Selects output function mode (on-chip pull-up/pull-down resistor control */
- #define IOCON_MODE_POS (3)
- #define IOCON_MODE_MASK (0x03<<IOCON_MODE_POS)
- #define IOCON_MODE_PLAIN ((0<<IOCON_MODE_POS))
- #define IOCON_MODE_PULLDOWN ((1<<IOCON_MODE_POS))
- #define IOCON_MODE_PULLUP ((2<<IOCON_MODE_POS))
- #define IOCON_MODE_REPEATER ((3<<IOCON_MODE_POS))
- /** Hysteresis */
- #define IOCON_HYS_POS (5)
- #define IOCON_HYS_MASK (0x01<<IOCON_HYS_POS)
- #define IOCON_HYS_ENABLE ((1<<IOCON_HYS_POS))
- /** Input polarity */
- #define IOCON_INVERT_POS (6)
- #define IOCON_INVERT_MASK (0x01<<IOCON_INVERT_POS)
- #define IOCON_INVERT_INPUT (1<<IOCON_INVERT_POS)
- /** Selects Analog/Digital mode */
- #define IOCON_ADMODE_POS (7)
- #define IOCON_ADMODE_MASK (0x01<<IOCON_ADMODE_POS)
- #define IOCON_ANALOG_MODE (0<<IOCON_ADMODE_POS)
- #define IOCON_DIGITIAL_MODE (1<<IOCON_ADMODE_POS)
- /* Controls Glitch Filter */
- #define IOCON_FILTER_POS (8)
- #define IOCON_FILTER_MASK (0x01<<IOCON_FILTER_POS)
- #define IOCON_10ns_FILTER_ENABLE (0<<IOCON_FILTER_POS)
- #define IOCON_10ns_FILTER_DISABLE (1<<IOCON_FILTER_POS)
- /** I2C 50ns glitch filter and slew rate control */
- #define IOCON_HS_POS (8)
- #define IOCON_HS_MASK (0x01<<IOCON_HS_POS)
- #define IOCON_I2C_FILTER_ENABLE (0<<IOCON_HS_POS)
- #define IOCON_I2C_FILTER_DISABLE (1<<IOCON_HS_POS)
- /** Driver Output Slew Rate Control*/
- #define IOCON_SLEW_POS (9)
- #define IOCON_SLEW_MASK (0x01<<IOCON_SLEW_POS)
- #define IOCON_SLEW_ENABLE ((1<<IOCON_SLEW_POS))
- /** Controls sink current capability of the pin*/
- #define IOCON_HIDRIVE_POS (9)
- #define IOCON_HIDRIVE_MASK (0x01<<IOCON_HIDRIVE_POS)
- #define IOCON_I2CMODE_FASTPLUS (1<<IOCON_HIDRIVE_POS)
- /** Controls open-drain mode */
- #define IOCON_OD_POS (10)
- #define IOCON_OD_MASK (0x01<<IOCON_OD_POS)
- #define IOCON_OPENDRAIN_MODE (1<<IOCON_OD_POS)
- /** DAC enable control */
- #define IOCON_DACEN_POS (16)
- #define IOCON_DACEN_MASK (0x01<<IOCON_DACEN_POS)
- #define IOCON_DAC_ENABLE (1<<IOCON_DACEN_POS)
- /* Macros define for Return Code */
- typedef int32_t PINSEL_RET_CODE;
- #define PINSEL_RET_OK (0)
- #define PINSEL_RET_INVALID_PIN (0x10000001)
- #define PINSEL_RET_NOT_SUPPORT (0x10000002)
- #define PINSEL_RET_ERR (-1)
- /**
- * @}
- */
- /** @defgroup PINSEL_Public_Types PINSEL Public Types
- * @{
- */
-
- typedef enum
- {
- PINSEL_BASICMODE_PLAINOUT = 0, /**< Plain output */
- PINSEL_BASICMODE_PULLDOWN, /**< Pull-down enabled */
- PINSEL_BASICMODE_PULLUP, /**< Pull-up enabled (default) */
- PINSEL_BASICMODE_REPEATER /**< Repeater mode */
- }PinSel_BasicMode;
- typedef enum
- {
- /** Fast mode (400 kHz clock rate) and standard (100 kHz clock rate) */
- PINSEL_I2CMODE_FAST_STANDARD = 0,
- /** Open drain I/O (not I2C). No glitch filter, 3 mA typical output drive */
- PINSEL_I2CMODE_OPENDRAINIO,
- /** Fast Mode Plus I2C. This includes a filter for <50 ns glitches */
- PINSEL_I2CMODE_FASTMODEPLUS,
- }PinSel_I2cMode;
- typedef enum
- {
- /** Type D IOCON registers */
- PINSEL_PIN_TYPE_D,
- /** Type A IOCON registers */
- PINSEL_PIN_TYPE_A,
- /** Type U IOCON registers */
- PINSEL_PIN_TYPE_U,
- /** Type I IOCON registers */
- PINSEL_PIN_TYPE_I,
- /** Type W IOCON registers */
- PINSEL_PIN_TYPE_W,
- /** Unknown type */
- PINSEL_PIN_TYPE_UNKNOWN,
- }PinSel_PinType;
- /**
- * @}
- */
-
- /* Public Functions ----------------------------------------------------------- */
- /** @defgroup PINSEL_Public_Functions PINSEL Public Functions
- * @{
- */
- PinSel_PinType PINSEL_GetPinType(uint8_t portnum, uint8_t pinnum);
- PINSEL_RET_CODE PINSEL_ConfigPin(uint8_t portnum, uint8_t pinnum, uint8_t funcnum);
- PINSEL_RET_CODE PINSEL_SetPinMode(uint8_t portnum, uint8_t pinnum, PinSel_BasicMode modenum);
- PINSEL_RET_CODE PINSEL_SetHysMode(uint8_t portnum, uint8_t pinnum, FunctionalState NewState);
- PINSEL_RET_CODE PINSEL_SetInvertInput(uint8_t portnum, uint8_t pinnum, FunctionalState NewState);
- PINSEL_RET_CODE PINSEL_SetSlewMode(uint8_t portnum, uint8_t pinnum, FunctionalState NewState);
- PINSEL_RET_CODE PINSEL_SetI2CMode(uint8_t portnum, uint8_t pinnum, PinSel_I2cMode I2CMode);
- PINSEL_RET_CODE PINSEL_SetOpenDrainMode(uint8_t portnum, uint8_t pinnum, FunctionalState NewState);
- PINSEL_RET_CODE PINSEL_SetAnalogPinMode (uint8_t portnum, uint8_t pinnum, uint8_t enable);
- PINSEL_RET_CODE PINSEL_DacEnable (uint8_t portnum, uint8_t pinnum, uint8_t enable);
- PINSEL_RET_CODE PINSEL_SetFilter (uint8_t portnum, uint8_t pinnum, uint8_t enable);
- PINSEL_RET_CODE PINSEL_SetI2CFilter (uint8_t portnum, uint8_t pinnum, uint8_t enable);
- /**
- * @}
- */
- #endif /* LPC_PINSEL_H */
- /**
- * @}
- */
- /* --------------------------------- End Of File ------------------------------ */
|