7 #ifndef __MSP430WARE_USCI_B_SPI_H__
8 #define __MSP430WARE_USCI_B_SPI_H__
10 #include "inc/hw_memmap.h"
12 #ifdef __MSP430_HAS_USCI_Bx__
25 #include "inc/hw_memmap.h"
79 #define USCI_B_SPI_PHASE_DATA_CHANGED_ONFIRST_CAPTURED_ON_NEXT 0x00
80 #define USCI_B_SPI_PHASE_DATA_CAPTURED_ONFIRST_CHANGED_ON_NEXT UCCKPH
89 #define USCI_B_SPI_MSB_FIRST UCMSB
90 #define USCI_B_SPI_LSB_FIRST 0x00
100 #define USCI_B_SPI_CLOCKPOLARITY_INACTIVITY_HIGH UCCKPL
101 #define USCI_B_SPI_CLOCKPOLARITY_INACTIVITY_LOW 0x00
109 #define USCI_B_SPI_CLOCKSOURCE_ACLK UCSSEL__ACLK
110 #define USCI_B_SPI_CLOCKSOURCE_SMCLK UCSSEL__SMCLK
120 #define USCI_B_SPI_TRANSMIT_INTERRUPT UCTXIE
121 #define USCI_B_SPI_RECEIVE_INTERRUPT UCRXIE
129 #define USCI_B_SPI_BUSY UCBUSY
130 #define USCI_B_SPI_NOT_BUSY 0x00
208 uint8_t clockPolarity);
233 uint8_t clockPolarity);
249 uint8_t transmitData);
437 #endif // __MSP430WARE_USCI_B_SPI_H__
uint32_t USCI_B_SPI_getTransmitBufferAddressForDMA(uint16_t baseAddress)
Returns the address of the TX Buffer of the SPI for the DMA module.
Definition: usci_b_spi.c:176
void USCI_B_SPI_changeClockPhasePolarity(uint16_t baseAddress, uint8_t clockPhase, uint8_t clockPolarity)
Changes the SPI clock phase and polarity.At the end of this function call, SPI module is left enabled...
Definition: usci_b_spi.c:99
void USCI_B_SPI_changeMasterClock(uint16_t baseAddress, USCI_B_SPI_changeMasterClockParam *param)
Initializes the SPI Master clock.At the end of this function call, SPI module is left enabled...
Definition: usci_b_spi.c:58
bool USCI_B_SPI_initMaster(uint16_t baseAddress, USCI_B_SPI_initMasterParam *param)
Initializes the SPI Master block.
Definition: usci_b_spi.c:21
void USCI_B_SPI_transmitData(uint16_t baseAddress, uint8_t transmitData)
Transmits a byte from the SPI Module.
Definition: usci_b_spi.c:119
uint8_t msbFirst
Definition: usci_b_spi.h:45
void USCI_B_SPI_enable(uint16_t baseAddress)
Enables the SPI block.
Definition: usci_b_spi.c:159
uint8_t USCI_B_SPI_isBusy(uint16_t baseAddress)
Indicates whether or not the SPI bus is busy.
Definition: usci_b_spi.c:181
uint8_t clockPhase
Definition: usci_b_spi.h:50
uint32_t USCI_B_SPI_getReceiveBufferAddressForDMA(uint16_t baseAddress)
Returns the address of the RX Buffer of the SPI for the DMA module.
Definition: usci_b_spi.c:171
void USCI_B_SPI_disableInterrupt(uint16_t baseAddress, uint8_t mask)
Disables individual SPI interrupt sources.
Definition: usci_b_spi.c:138
uint8_t clockPolarity
Definition: usci_b_spi.h:54
void USCI_B_SPI_clearInterrupt(uint16_t baseAddress, uint8_t mask)
Clears the selected SPI interrupt status flag.
Definition: usci_b_spi.c:152
uint32_t clockSourceFrequency
Is the frequency of the selected clock source.
Definition: usci_b_spi.h:65
uint32_t desiredSpiClock
Is the desired clock rate for SPI communication.
Definition: usci_b_spi.h:67
bool USCI_B_SPI_initSlave(uint16_t baseAddress, uint8_t msbFirst, uint8_t clockPhase, uint8_t clockPolarity)
Initializes the SPI Slave block.
Definition: usci_b_spi.c:70
void USCI_B_SPI_disable(uint16_t baseAddress)
Disables the SPI block.
Definition: usci_b_spi.c:165
uint32_t desiredSpiClock
Is the desired clock rate for SPI communication.
Definition: usci_b_spi.h:40
uint8_t USCI_B_SPI_receiveData(uint16_t baseAddress)
Receives a byte that has been sent to the SPI Module.
Definition: usci_b_spi.c:126
uint32_t clockSourceFrequency
Is the frequency of the selected clock source.
Definition: usci_b_spi.h:38
uint8_t USCI_B_SPI_getInterruptStatus(uint16_t baseAddress, uint8_t mask)
Gets the current SPI interrupt status.
Definition: usci_b_spi.c:145
Used in the USCI_B_SPI_initMaster() function as the param parameter.
Definition: usci_b_spi.h:31
void USCI_B_SPI_enableInterrupt(uint16_t baseAddress, uint8_t mask)
Enables individual SPI interrupt sources.
Definition: usci_b_spi.c:131
uint8_t selectClockSource
Definition: usci_b_spi.h:36
Used in the USCI_B_SPI_changeMasterClock() function as the param parameter.
Definition: usci_b_spi.h:63