aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorFergus Noble2011-10-04 16:06:01 -0700
committerFergus Noble2011-10-04 16:06:01 -0700
commit4809f7dacf70253f894460683be5c08d76a800a7 (patch)
tree3f0d85db06ce6f20f7d750355170eef069011141 /lib
parent71909482de63e9f34570df1635aefb48a0a730ec (diff)
Added alternative function for doing an SPI transfer.
Diffstat (limited to 'lib')
-rw-r--r--lib/stm32_common/spi.c16
1 files changed, 15 insertions, 1 deletions
diff --git a/lib/stm32_common/spi.c b/lib/stm32_common/spi.c
index 7fb8711..71bb846 100644
--- a/lib/stm32_common/spi.c
+++ b/lib/stm32_common/spi.c
@@ -77,7 +77,7 @@ void spi_write(u32 spi, u16 data)
void spi_send(u32 spi, u16 data)
{
/* wait for transfer finished */
- while (SPI_SR(spi) & SPI_SR_BSY );
+ while (!(SPI_SR(spi) & SPI_SR_TXE ));
/* Write data (8 or 16 bits, depending on DFF) into DR. */
SPI_DR(spi) = data;
@@ -85,6 +85,20 @@ void spi_send(u32 spi, u16 data)
u16 spi_read(u32 spi)
{
+ /* wait for transfer finished */
+ while (!(SPI_SR(spi) & SPI_SR_RXNE ));
+
+ /* Read the data (8 or 16 bits, depending on DFF bit) from DR. */
+ return SPI_DR(spi);
+}
+
+u16 spi_xfer(u32 spi, u16 data)
+{
+ spi_write(spi, data);
+
+ /* wait for transfer finished */
+ while (!(SPI_SR(spi) & SPI_SR_RXNE ));
+
/* Read the data (8 or 16 bits, depending on DFF bit) from DR. */
return SPI_DR(spi);
}