2011-09-06 21:05:41 +02:00
|
|
|
/*
|
|
|
|
%atmel_license%
|
|
|
|
*/
|
2011-05-31 23:09:42 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \file
|
|
|
|
*
|
|
|
|
* Interface for Serial Peripheral Interface (SPI) controller.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _SPI_
|
|
|
|
#define _SPI_
|
|
|
|
|
|
|
|
/*----------------------------------------------------------------------------
|
|
|
|
* Headers
|
|
|
|
*----------------------------------------------------------------------------*/
|
|
|
|
|
2011-07-17 09:50:36 -04:00
|
|
|
#include "../chip.h"
|
2011-05-31 23:09:42 +02:00
|
|
|
|
|
|
|
/*----------------------------------------------------------------------------
|
|
|
|
* Macros
|
|
|
|
*----------------------------------------------------------------------------*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* Here are several macros which should be used when configuring a SPI
|
|
|
|
* peripheral.
|
|
|
|
*
|
|
|
|
* \section spi_configuration_macros SPI Configuration Macros
|
|
|
|
* - \ref SPI_PCS
|
|
|
|
* - \ref SPI_SCBR
|
|
|
|
* - \ref SPI_DLYBS
|
|
|
|
* - \ref SPI_DLYBCT
|
|
|
|
*/
|
|
|
|
|
|
|
|
/** Calculate the PCS field value given the chip select NPCS value */
|
2011-09-06 21:05:41 +02:00
|
|
|
#define SPI_PCS(npcs) ((~(1 << (npcs)) & 0xF) << 16)
|
2011-05-31 23:09:42 +02:00
|
|
|
|
|
|
|
/** Calculates the value of the CSR SCBR field given the baudrate and MCK. */
|
2011-09-06 21:05:41 +02:00
|
|
|
#define SPI_SCBR(baudrate, masterClock) ((uint32_t) ((masterClock) / (baudrate)) << 8)
|
2011-05-31 23:09:42 +02:00
|
|
|
|
|
|
|
/** Calculates the value of the CSR DLYBS field given the desired delay (in ns) */
|
2011-09-06 21:05:41 +02:00
|
|
|
#define SPI_DLYBS(delay, masterClock) ((uint32_t) ((((masterClock) / 1000000) * (delay)) / 1000) << 16)
|
2011-05-31 23:09:42 +02:00
|
|
|
|
|
|
|
/** Calculates the value of the CSR DLYBCT field given the desired delay (in ns) */
|
2011-09-06 21:05:41 +02:00
|
|
|
#define SPI_DLYBCT(delay, masterClock) ((uint32_t) ((((masterClock) / 1000000) * (delay)) / 32000) << 24)
|
2011-05-31 23:09:42 +02:00
|
|
|
|
|
|
|
/*------------------------------------------------------------------------------ */
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/*----------------------------------------------------------------------------
|
|
|
|
* Exported functions
|
|
|
|
*----------------------------------------------------------------------------*/
|
|
|
|
|
|
|
|
extern void SPI_Enable( Spi* spi ) ;
|
|
|
|
extern void SPI_Disable( Spi* spi ) ;
|
|
|
|
extern void SPI_EnableIt( Spi* spi, uint32_t dwSources ) ;
|
|
|
|
extern void SPI_DisableIt( Spi* spi, uint32_t dwSources ) ;
|
|
|
|
|
|
|
|
extern void SPI_Configure( Spi* spi, uint32_t dwId, uint32_t dwConfiguration ) ;
|
|
|
|
extern void SPI_ConfigureNPCS( Spi* spi, uint32_t dwNpcs, uint32_t dwConfiguration ) ;
|
|
|
|
|
|
|
|
extern uint32_t SPI_Read( Spi* spi ) ;
|
|
|
|
extern void SPI_Write( Spi* spi, uint32_t dwNpcs, uint16_t wData ) ;
|
|
|
|
|
|
|
|
extern uint32_t SPI_GetStatus( Spi* spi ) ;
|
|
|
|
extern uint32_t SPI_IsFinished( Spi* pSpi ) ;
|
|
|
|
|
|
|
|
extern void SPI_PdcEnableTx( Spi* spi ) ;
|
|
|
|
extern void SPI_PdcDisableTx( Spi* spi ) ;
|
|
|
|
extern void SPI_PdcEnableRx( Spi* spi ) ;
|
|
|
|
extern void SPI_PdcDisableRx( Spi* spi ) ;
|
|
|
|
|
|
|
|
extern void SPI_PdcSetTx( Spi* spi, void* pvTxBuf, uint32_t dwTxCount, void* pvTxNextBuf, uint32_t dwTxNextCount ) ;
|
|
|
|
extern void SPI_PdcSetRx( Spi* spi, void* pvRxBuf, uint32_t dwRxCount, void* pvRxNextBuf, uint32_t dwRxNextCount ) ;
|
|
|
|
|
|
|
|
extern uint32_t SPI_WriteBuffer( Spi* spi, void* pvBuffer, uint32_t dwLength ) ;
|
|
|
|
|
|
|
|
extern uint32_t SPI_ReadBuffer( Spi* spi, void* pvBuffer, uint32_t dwLength ) ;
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* #ifndef _SPI_ */
|
|
|
|
|