329 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			329 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
|   | /**********************************************************************
 | ||
|  | * $Id$      lpc17xx_spi.h               2010-05-21 | ||
|  | *//**
 | ||
|  | * @file     lpc17xx_spi.h | ||
|  | * @brief    Contains all macro definitions and function prototypes | ||
|  | *           support for SPI 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 ----------------------------------------------------------- */ | ||
|  | /** @defgroup SPI SPI (Serial Peripheral Interface)
 | ||
|  |  * @ingroup LPC1700CMSIS_FwLib_Drivers | ||
|  |  * @{ | ||
|  |  */ | ||
|  | 
 | ||
|  | #ifndef LPC17XX_SPI_H_
 | ||
|  | #define LPC17XX_SPI_H_
 | ||
|  | 
 | ||
|  | /* Includes ------------------------------------------------------------------- */ | ||
|  | #include "LPC17xx.h"
 | ||
|  | #include "lpc_types.h"
 | ||
|  | 
 | ||
|  | 
 | ||
|  | #ifdef __cplusplus
 | ||
|  | extern "C" | ||
|  | { | ||
|  | #endif
 | ||
|  | 
 | ||
|  | /* Public Macros -------------------------------------------------------------- */ | ||
|  | /** @defgroup SPI_Public_Macros SPI Public Macros
 | ||
|  |  * @{ | ||
|  |  */ | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * SPI configuration parameter defines | ||
|  |  **********************************************************************/ | ||
|  | /** Clock phase control bit */ | ||
|  | #define SPI_CPHA_FIRST          ((uint32_t)(0))
 | ||
|  | #define SPI_CPHA_SECOND         ((uint32_t)(1<<3))
 | ||
|  | 
 | ||
|  | /** Clock polarity control bit */ | ||
|  | #define SPI_CPOL_HI             ((uint32_t)(0))
 | ||
|  | #define SPI_CPOL_LO             ((uint32_t)(1<<4))
 | ||
|  | 
 | ||
|  | /** SPI master mode enable */ | ||
|  | #define SPI_SLAVE_MODE          ((uint32_t)(0))
 | ||
|  | #define SPI_MASTER_MODE         ((uint32_t)(1<<5))
 | ||
|  | 
 | ||
|  | /** LSB enable bit */ | ||
|  | #define SPI_DATA_MSB_FIRST      ((uint32_t)(0))
 | ||
|  | #define SPI_DATA_LSB_FIRST      ((uint32_t)(1<<6))
 | ||
|  | 
 | ||
|  | /** SPI data bit number defines */ | ||
|  | #define SPI_DATABIT_16      SPI_SPCR_BITS(0)        /*!< Databit number = 16 */
 | ||
|  | #define SPI_DATABIT_8       SPI_SPCR_BITS(0x08)     /*!< Databit number = 8 */
 | ||
|  | #define SPI_DATABIT_9       SPI_SPCR_BITS(0x09)     /*!< Databit number = 9 */
 | ||
|  | #define SPI_DATABIT_10      SPI_SPCR_BITS(0x0A)     /*!< Databit number = 10 */
 | ||
|  | #define SPI_DATABIT_11      SPI_SPCR_BITS(0x0B)     /*!< Databit number = 11 */
 | ||
|  | #define SPI_DATABIT_12      SPI_SPCR_BITS(0x0C)     /*!< Databit number = 12 */
 | ||
|  | #define SPI_DATABIT_13      SPI_SPCR_BITS(0x0D)     /*!< Databit number = 13 */
 | ||
|  | #define SPI_DATABIT_14      SPI_SPCR_BITS(0x0E)     /*!< Databit number = 14 */
 | ||
|  | #define SPI_DATABIT_15      SPI_SPCR_BITS(0x0F)     /*!< Databit number = 15 */
 | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * SPI Status Flag defines | ||
|  |  **********************************************************************/ | ||
|  | /** Slave abort */ | ||
|  | #define SPI_STAT_ABRT       SPI_SPSR_ABRT
 | ||
|  | /** Mode fault */ | ||
|  | #define SPI_STAT_MODF       SPI_SPSR_MODF
 | ||
|  | /** Read overrun */ | ||
|  | #define SPI_STAT_ROVR       SPI_SPSR_ROVR
 | ||
|  | /** Write collision */ | ||
|  | #define SPI_STAT_WCOL       SPI_SPSR_WCOL
 | ||
|  | /** SPI transfer complete flag */ | ||
|  | #define SPI_STAT_SPIF       SPI_SPSR_SPIF
 | ||
|  | 
 | ||
|  | /* SPI Status Implementation definitions */ | ||
|  | #define SPI_STAT_DONE       (1UL<<8)        /**< Done */
 | ||
|  | #define SPI_STAT_ERROR      (1UL<<9)        /**< Error */
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @} | ||
|  |  */ | ||
|  | 
 | ||
|  | 
 | ||
|  | /* Private Macros ------------------------------------------------------------- */ | ||
|  | /** @defgroup SPI_Private_Macros SPI Private Macros
 | ||
|  |  * @{ | ||
|  |  */ | ||
|  | 
 | ||
|  | /* --------------------- BIT DEFINITIONS -------------------------------------- */ | ||
|  | /*********************************************************************//**
 | ||
|  |  * Macro defines for SPI Control Register | ||
|  |  **********************************************************************/ | ||
|  | /** Bit enable, the SPI controller sends and receives the number
 | ||
|  |  * of bits selected by bits 11:8 */ | ||
|  | #define SPI_SPCR_BIT_EN         ((uint32_t)(1<<2))
 | ||
|  | /** Clock phase control bit */ | ||
|  | #define SPI_SPCR_CPHA_SECOND    ((uint32_t)(1<<3))
 | ||
|  | /** Clock polarity control bit */ | ||
|  | #define SPI_SPCR_CPOL_LOW       ((uint32_t)(1<<4))
 | ||
|  | /** SPI master mode enable */ | ||
|  | #define SPI_SPCR_MSTR           ((uint32_t)(1<<5))
 | ||
|  | /** LSB enable bit */ | ||
|  | #define SPI_SPCR_LSBF           ((uint32_t)(1<<6))
 | ||
|  | /** SPI interrupt enable bit */ | ||
|  | #define SPI_SPCR_SPIE           ((uint32_t)(1<<7))
 | ||
|  | /**  When bit 2 of this register is 1, this field controls the
 | ||
|  | number of bits per transfer */ | ||
|  | #define SPI_SPCR_BITS(n)        ((n==0) ? ((uint32_t)0) : ((uint32_t)((n&0x0F)<<8)))
 | ||
|  | /** SPI Control bit mask */ | ||
|  | #define SPI_SPCR_BITMASK        ((uint32_t)(0xFFC))
 | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * Macro defines for  SPI Status Register | ||
|  |  **********************************************************************/ | ||
|  | /** Slave abort */ | ||
|  | #define SPI_SPSR_ABRT       ((uint32_t)(1<<3))
 | ||
|  | /** Mode fault */ | ||
|  | #define SPI_SPSR_MODF       ((uint32_t)(1<<4))
 | ||
|  | /** Read overrun */ | ||
|  | #define SPI_SPSR_ROVR       ((uint32_t)(1<<5))
 | ||
|  | /** Write collision */ | ||
|  | #define SPI_SPSR_WCOL       ((uint32_t)(1<<6))
 | ||
|  | /** SPI transfer complete flag */ | ||
|  | #define SPI_SPSR_SPIF       ((uint32_t)(1<<7))
 | ||
|  | /** SPI Status bit mask */ | ||
|  | #define SPI_SPSR_BITMASK    ((uint32_t)(0xF8))
 | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * Macro defines for SPI Data Register | ||
|  |  **********************************************************************/ | ||
|  | /** SPI Data low bit-mask */ | ||
|  | #define SPI_SPDR_LO_MASK    ((uint32_t)(0xFF))
 | ||
|  | /** SPI Data high bit-mask */ | ||
|  | #define SPI_SPDR_HI_MASK    ((uint32_t)(0xFF00))
 | ||
|  | /** SPI Data bit-mask */ | ||
|  | #define SPI_SPDR_BITMASK    ((uint32_t)(0xFFFF))
 | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * Macro defines for SPI Clock Counter Register | ||
|  |  **********************************************************************/ | ||
|  | /** SPI clock counter setting */ | ||
|  | #define SPI_SPCCR_COUNTER(n)    ((uint32_t)(n&0xFF))
 | ||
|  | /** SPI clock counter bit-mask */ | ||
|  | #define SPI_SPCCR_BITMASK       ((uint32_t)(0xFF))
 | ||
|  | 
 | ||
|  | /***********************************************************************
 | ||
|  |  * Macro defines for SPI Test Control Register | ||
|  |  **********************************************************************/ | ||
|  | /** SPI Test bit */ | ||
|  | #define SPI_SPTCR_TEST_MASK ((uint32_t)(0xFE))
 | ||
|  | /** SPI Test register bit mask */ | ||
|  | #define SPI_SPTCR_BITMASK   ((uint32_t)(0xFE))
 | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * Macro defines for SPI Test Status Register | ||
|  |  **********************************************************************/ | ||
|  | /** Slave abort */ | ||
|  | #define SPI_SPTSR_ABRT      ((uint32_t)(1<<3))
 | ||
|  | /** Mode fault */ | ||
|  | #define SPI_SPTSR_MODF      ((uint32_t)(1<<4))
 | ||
|  | /** Read overrun */ | ||
|  | #define SPI_SPTSR_ROVR      ((uint32_t)(1<<5))
 | ||
|  | /** Write collision */ | ||
|  | #define SPI_SPTSR_WCOL      ((uint32_t)(1<<6))
 | ||
|  | /** SPI transfer complete flag */ | ||
|  | #define SPI_SPTSR_SPIF      ((uint32_t)(1<<7))
 | ||
|  | /** SPI Status bit mask */ | ||
|  | #define SPI_SPTSR_MASKBIT   ((uint32_t)(0xF8))
 | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * Macro defines for SPI Interrupt Register | ||
|  |  **********************************************************************/ | ||
|  | /** SPI interrupt flag */ | ||
|  | #define SPI_SPINT_INTFLAG   ((uint32_t)(1<<0))
 | ||
|  | /** SPI interrupt register bit mask */ | ||
|  | #define SPI_SPINT_BITMASK   ((uint32_t)(0x01))
 | ||
|  | 
 | ||
|  | 
 | ||
|  | /* ---------------- CHECK PARAMETER DEFINITIONS ---------------------------- */ | ||
|  | /** Macro to determine if it is valid SPI port number */ | ||
|  | #define PARAM_SPIx(n)   (((uint32_t *)n)==((uint32_t *)LPC_SPI))
 | ||
|  | 
 | ||
|  | /** Macro check Clock phase control mode */ | ||
|  | #define PARAM_SPI_CPHA(n)   ((n==SPI_CPHA_FIRST) || (n==SPI_CPHA_SECOND))
 | ||
|  | 
 | ||
|  | /** Macro check Clock polarity control mode */ | ||
|  | #define PARAM_SPI_CPOL(n)   ((n==SPI_CPOL_HI) || (n==SPI_CPOL_LO))
 | ||
|  | 
 | ||
|  | /** Macro check master/slave mode */ | ||
|  | #define PARAM_SPI_MODE(n)   ((n==SPI_SLAVE_MODE) || (n==SPI_MASTER_MODE))
 | ||
|  | 
 | ||
|  | /** Macro check LSB/MSB mode */ | ||
|  | #define PARAM_SPI_DATA_ORDER(n) ((n==SPI_DATA_MSB_FIRST) || (n==SPI_DATA_LSB_FIRST))
 | ||
|  | 
 | ||
|  | /** Macro check databit value */ | ||
|  | #define PARAM_SPI_DATABIT(n)    ((n==SPI_DATABIT_16) || (n==SPI_DATABIT_8) \
 | ||
|  | || (n==SPI_DATABIT_9) || (n==SPI_DATABIT_10) \ | ||
|  | || (n==SPI_DATABIT_11) || (n==SPI_DATABIT_12) \ | ||
|  | || (n==SPI_DATABIT_13) || (n==SPI_DATABIT_14) \ | ||
|  | || (n==SPI_DATABIT_15)) | ||
|  | 
 | ||
|  | /** Macro check status flag */ | ||
|  | #define PARAM_SPI_STAT(n)   ((n==SPI_STAT_ABRT) || (n==SPI_STAT_MODF) \
 | ||
|  | || (n==SPI_STAT_ROVR) || (n==SPI_STAT_WCOL) \ | ||
|  | || (n==SPI_STAT_SPIF)) | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @} | ||
|  |  */ | ||
|  | 
 | ||
|  | 
 | ||
|  | /* Public Types --------------------------------------------------------------- */ | ||
|  | /** @defgroup SPI_Public_Types SPI Public Types
 | ||
|  |  * @{ | ||
|  |  */ | ||
|  | 
 | ||
|  | /** @brief SPI configuration structure */ | ||
|  | typedef struct { | ||
|  |     uint32_t Databit;       /** Databit number, should be SPI_DATABIT_x,
 | ||
|  |                             where x is in range from 8 - 16 */ | ||
|  |     uint32_t CPHA;          /** Clock phase, should be:
 | ||
|  |                             - SPI_CPHA_FIRST: first clock edge | ||
|  |                             - SPI_CPHA_SECOND: second clock edge */ | ||
|  |     uint32_t CPOL;          /** Clock polarity, should be:
 | ||
|  |                             - SPI_CPOL_HI: high level | ||
|  |                             - SPI_CPOL_LO: low level */ | ||
|  |     uint32_t Mode;          /** SPI mode, should be:
 | ||
|  |                             - SPI_MASTER_MODE: Master mode | ||
|  |                             - SPI_SLAVE_MODE: Slave mode */ | ||
|  |     uint32_t DataOrder;     /** Data order, should be:
 | ||
|  |                             - SPI_DATA_MSB_FIRST: MSB first | ||
|  |                             - SPI_DATA_LSB_FIRST: LSB first */ | ||
|  |     uint32_t ClockRate;     /** Clock rate,in Hz, should not exceed
 | ||
|  |                             (SPI peripheral clock)/8 */ | ||
|  | } SPI_CFG_Type; | ||
|  | 
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief SPI Transfer Type definitions | ||
|  |  */ | ||
|  | typedef enum { | ||
|  |     SPI_TRANSFER_POLLING = 0,   /**< Polling transfer */ | ||
|  |     SPI_TRANSFER_INTERRUPT      /**< Interrupt transfer */ | ||
|  | } SPI_TRANSFER_Type; | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief SPI Data configuration structure definitions | ||
|  |  */ | ||
|  | typedef struct { | ||
|  |     void *tx_data;              /**< Pointer to transmit data */ | ||
|  |     void *rx_data;              /**< Pointer to transmit data */ | ||
|  |     uint32_t length;            /**< Length of transfer data */ | ||
|  |     uint32_t counter;           /**< Data counter index */ | ||
|  |     uint32_t status;            /**< Current status of SPI activity */ | ||
|  | } SPI_DATA_SETUP_Type; | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @} | ||
|  |  */ | ||
|  | 
 | ||
|  | 
 | ||
|  | /* Public Functions ----------------------------------------------------------- */ | ||
|  | /** @defgroup SPI_Public_Functions SPI Public Functions
 | ||
|  |  * @{ | ||
|  |  */ | ||
|  | 
 | ||
|  | /* SPI Init/DeInit functions ---------*/ | ||
|  | void SPI_Init(LPC_SPI_TypeDef *SPIx, SPI_CFG_Type *SPI_ConfigStruct); | ||
|  | void SPI_DeInit(LPC_SPI_TypeDef *SPIx); | ||
|  | void SPI_SetClock (LPC_SPI_TypeDef *SPIx, uint32_t target_clock); | ||
|  | void SPI_ConfigStructInit(SPI_CFG_Type *SPI_InitStruct); | ||
|  | 
 | ||
|  | /* SPI transfer functions ------------*/ | ||
|  | void SPI_SendData(LPC_SPI_TypeDef *SPIx, uint16_t Data); | ||
|  | uint16_t SPI_ReceiveData(LPC_SPI_TypeDef *SPIx); | ||
|  | int32_t SPI_ReadWrite (LPC_SPI_TypeDef *SPIx, SPI_DATA_SETUP_Type *dataCfg, SPI_TRANSFER_Type xfType); | ||
|  | 
 | ||
|  | /* SPI Interrupt functions ---------*/ | ||
|  | void SPI_IntCmd(LPC_SPI_TypeDef *SPIx, FunctionalState NewState); | ||
|  | IntStatus SPI_GetIntStatus (LPC_SPI_TypeDef *SPIx); | ||
|  | void SPI_ClearIntPending(LPC_SPI_TypeDef *SPIx); | ||
|  | 
 | ||
|  | /* SPI get information functions-----*/ | ||
|  | uint8_t SPI_GetDataSize (LPC_SPI_TypeDef *SPIx); | ||
|  | uint32_t SPI_GetStatus(LPC_SPI_TypeDef *SPIx); | ||
|  | FlagStatus SPI_CheckStatus (uint32_t inputSPIStatus,  uint8_t SPIStatus); | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @} | ||
|  |  */ | ||
|  | 
 | ||
|  | #ifdef __cplusplus
 | ||
|  | } | ||
|  | #endif
 | ||
|  | 
 | ||
|  | #endif /* LPC17XX_SPI_H_ */
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @} | ||
|  |  */ | ||
|  | 
 | ||
|  | /* --------------------------------- End Of File ------------------------------ */ |