7 #ifndef __MSP430WARE_EUSCI_B_SPI_H__ 8 #define __MSP430WARE_EUSCI_B_SPI_H__ 10 #include "inc/hw_memmap.h" 12 #ifdef __MSP430_HAS_EUSCI_Bx__ 25 #include "inc/hw_memmap.h" 118 #define EUSCI_B_SPI_PHASE_DATA_CHANGED_ONFIRST_CAPTURED_ON_NEXT 0x00 119 #define EUSCI_B_SPI_PHASE_DATA_CAPTURED_ONFIRST_CHANGED_ON_NEXT UCCKPH 127 #define EUSCI_B_SPI_MSB_FIRST UCMSB 128 #define EUSCI_B_SPI_LSB_FIRST 0x00 138 #define EUSCI_B_SPI_CLOCKPOLARITY_INACTIVITY_HIGH UCCKPL 139 #define EUSCI_B_SPI_CLOCKPOLARITY_INACTIVITY_LOW 0x00 147 #define EUSCI_B_SPI_CLOCKSOURCE_UCLK UCSSEL__UCLK 148 #define EUSCI_B_SPI_CLOCKSOURCE_ACLK 0x40 149 #define EUSCI_B_SPI_CLOCKSOURCE_MODCLK 0x40 150 #define EUSCI_B_SPI_CLOCKSOURCE_SMCLK UCSSEL__SMCLK 158 #define EUSCI_B_SPI_3PIN UCMODE_0 159 #define EUSCI_B_SPI_4PIN_UCxSTE_ACTIVE_HIGH UCMODE_1 160 #define EUSCI_B_SPI_4PIN_UCxSTE_ACTIVE_LOW UCMODE_2 168 #define EUSCI_B_SPI_PREVENT_CONFLICTS_WITH_OTHER_MASTERS 0x0000 169 #define EUSCI_B_SPI_ENABLE_SIGNAL_FOR_4WIRE_SLAVE UCSTEM 179 #define EUSCI_B_SPI_TRANSMIT_INTERRUPT UCTXIE 180 #define EUSCI_B_SPI_RECEIVE_INTERRUPT UCRXIE 188 #define EUSCI_B_SPI_BUSY UCBUSY 189 #define EUSCI_B_SPI_NOT_BUSY 0x00 197 #define EUSCI_B_SPI_REMAP_PINS_FALSE (0x0000) 198 #define EUSCI_B_SPI_REMAP_PINS_TRUE (0x0001) 245 uint16_t select4PinFunctionality);
323 uint8_t transmitData);
526 #define EUSCI_B_SPI_REMAP_PINS_1 EUSCI_B_SPI_REMAP_PINS_FALSE 527 #define EUSCI_B_SPI_REMAP_PINS_2 EUSCI_B_SPI_REMAP_PINS_TRUE 539 #endif // __MSP430WARE_EUSCI_B_SPI_H__ uint16_t spiMode
Definition: eusci_b_spi.h:94
void EUSCI_B_SPI_disable(uint16_t baseAddress)
Disables the SPI block.
Definition: eusci_b_spi.c:166
uint16_t msbFirst
Definition: eusci_b_spi.h:78
void EUSCI_B_SPI_disableInterrupt(uint16_t baseAddress, uint16_t mask)
Disables individual SPI interrupt sources.
Definition: eusci_b_spi.c:139
void EUSCI_B_SPI_select4PinFunctionality(uint16_t baseAddress, uint16_t select4PinFunctionality)
Selects 4Pin Functionality.
Definition: eusci_b_spi.c:57
void EUSCI_B_SPI_enable(uint16_t baseAddress)
Enables the SPI block.
Definition: eusci_b_spi.c:160
uint8_t EUSCI_B_SPI_receiveData(uint16_t baseAddress)
Receives a byte that has been sent to the SPI Module.
Definition: eusci_b_spi.c:127
void EUSCI_B_SPI_clearInterrupt(uint16_t baseAddress, uint16_t mask)
Clears the selected SPI interrupt status flag.
Definition: eusci_b_spi.c:153
uint32_t clockSourceFrequency
Is the frequency of the selected clock source in Hz.
Definition: eusci_b_spi.h:42
uint16_t EUSCI_B_SPI_isBusy(uint16_t baseAddress)
Indicates whether or not the SPI bus is busy.
Definition: eusci_b_spi.c:182
void EUSCI_B_SPI_initSlave(uint16_t baseAddress, EUSCI_B_SPI_initSlaveParam *param)
Initializes the SPI Slave block.
Definition: eusci_b_spi.c:78
Used in the EUSCI_B_SPI_initMaster() function as the param parameter.
Definition: eusci_b_spi.h:32
Used in the EUSCI_B_SPI_changeMasterClock() function as the param parameter.
Definition: eusci_b_spi.h:103
uint32_t clockSourceFrequency
Is the frequency of the selected clock source in Hz.
Definition: eusci_b_spi.h:105
uint16_t clockPhase
Definition: eusci_b_spi.h:54
uint8_t selectClockSource
Definition: eusci_b_spi.h:40
void EUSCI_B_SPI_changeMasterClock(uint16_t baseAddress, EUSCI_B_SPI_changeMasterClockParam *param)
Initializes the SPI Master clock. At the end of this function call, SPI module is left enabled...
Definition: eusci_b_spi.c:65
void EUSCI_B_SPI_enableInterrupt(uint16_t baseAddress, uint16_t mask)
Enables individual SPI interrupt sources.
Definition: eusci_b_spi.c:132
uint32_t desiredSpiClock
Is the desired clock rate in Hz for SPI communication.
Definition: eusci_b_spi.h:107
uint16_t clockPolarity
Definition: eusci_b_spi.h:59
void EUSCI_B_SPI_initMaster(uint16_t baseAddress, EUSCI_B_SPI_initMasterParam *param)
Initializes the SPI Master block.
Definition: eusci_b_spi.c:21
void EUSCI_B_SPI_transmitData(uint16_t baseAddress, uint8_t transmitData)
Transmits a byte from the SPI Module.
Definition: eusci_b_spi.c:120
void EUSCI_B_SPI_changeClockPhasePolarity(uint16_t baseAddress, uint16_t clockPhase, uint16_t clockPolarity)
Changes the SPI clock phase and polarity. At the end of this function call, SPI module is left enable...
Definition: eusci_b_spi.c:101
Used in the EUSCI_B_SPI_initSlave() function as the param parameter.
Definition: eusci_b_spi.h:73
uint32_t EUSCI_B_SPI_getReceiveBufferAddress(uint16_t baseAddress)
Returns the address of the RX Buffer of the SPI for the DMA module.
Definition: eusci_b_spi.c:172
uint16_t msbFirst
Definition: eusci_b_spi.h:49
uint32_t desiredSpiClock
Is the desired clock rate in Hz for SPI communication.
Definition: eusci_b_spi.h:44
void EUSCI_B_SPI_remapPins(uint16_t baseAddress, uint8_t pinsSelect)
Remaps eUSCI_B GPIO pins.
Definition: eusci_b_spi.c:188
uint8_t EUSCI_B_SPI_getInterruptStatus(uint16_t baseAddress, uint8_t mask)
Gets the current SPI interrupt status.
Definition: eusci_b_spi.c:146
uint16_t spiMode
Definition: eusci_b_spi.h:65
uint16_t clockPhase
Definition: eusci_b_spi.h:83
uint32_t EUSCI_B_SPI_getTransmitBufferAddress(uint16_t baseAddress)
Returns the address of the TX Buffer of the SPI for the DMA module.
Definition: eusci_b_spi.c:177
uint16_t clockPolarity
Definition: eusci_b_spi.h:88