mirror of
https://github.com/felis/USB_Host_Shield_2.0.git
synced 2024-03-22 11:31:26 +01:00
parent
50b6ce4c9c
commit
0ef5fa5357
1 changed files with 26 additions and 26 deletions
52
usbhost.h
52
usbhost.h
|
@ -30,11 +30,7 @@ e-mail : support@circuitsathome.com
|
||||||
/* SPI initialization */
|
/* SPI initialization */
|
||||||
template< typename SPI_CLK, typename SPI_MOSI, typename SPI_MISO, typename SPI_SS > class SPi {
|
template< typename SPI_CLK, typename SPI_MOSI, typename SPI_MISO, typename SPI_SS > class SPi {
|
||||||
public:
|
public:
|
||||||
#if SPI_HAS_TRANSACTION
|
#if USING_SPI4TEENSY3
|
||||||
static void init() {
|
|
||||||
SPI.begin(); // The SPI library with transaction will take care of setting up the pins - settings is set in beginTransaction()
|
|
||||||
}
|
|
||||||
#elif USING_SPI4TEENSY3
|
|
||||||
static void init() {
|
static void init() {
|
||||||
// spi4teensy3 inits everything for us, except /SS
|
// spi4teensy3 inits everything for us, except /SS
|
||||||
// CLK, MOSI and MISO are hard coded for now.
|
// CLK, MOSI and MISO are hard coded for now.
|
||||||
|
@ -43,6 +39,10 @@ public:
|
||||||
SPI_SS::SetDirWrite();
|
SPI_SS::SetDirWrite();
|
||||||
SPI_SS::Set();
|
SPI_SS::Set();
|
||||||
}
|
}
|
||||||
|
#elif SPI_HAS_TRANSACTION
|
||||||
|
static void init() {
|
||||||
|
SPI.begin(); // The SPI library with transaction will take care of setting up the pins - settings is set in beginTransaction()
|
||||||
|
}
|
||||||
#elif !defined(SPDR)
|
#elif !defined(SPDR)
|
||||||
static void init() {
|
static void init() {
|
||||||
SPI_SS::SetDirWrite();
|
SPI_SS::SetDirWrite();
|
||||||
|
@ -157,16 +157,16 @@ void MAX3421e< SPI_SS, INTR >::regWr(uint8_t reg, uint8_t data) {
|
||||||
#endif
|
#endif
|
||||||
SPI_SS::Clear();
|
SPI_SS::Clear();
|
||||||
|
|
||||||
#if SPI_HAS_TRANSACTION
|
#if USING_SPI4TEENSY3
|
||||||
uint8_t c[2];
|
|
||||||
c[0] = reg | 0x02;
|
|
||||||
c[1] = data;
|
|
||||||
SPI.transfer(c, 2);
|
|
||||||
#elif USING_SPI4TEENSY3
|
|
||||||
uint8_t c[2];
|
uint8_t c[2];
|
||||||
c[0] = reg | 0x02;
|
c[0] = reg | 0x02;
|
||||||
c[1] = data;
|
c[1] = data;
|
||||||
spi4teensy3::send(c, 2);
|
spi4teensy3::send(c, 2);
|
||||||
|
#elif SPI_HAS_TRANSACTION
|
||||||
|
uint8_t c[2];
|
||||||
|
c[0] = reg | 0x02;
|
||||||
|
c[1] = data;
|
||||||
|
SPI.transfer(c, 2);
|
||||||
#elif !defined(SPDR)
|
#elif !defined(SPDR)
|
||||||
SPI.transfer(reg | 0x02);
|
SPI.transfer(reg | 0x02);
|
||||||
SPI.transfer(data);
|
SPI.transfer(data);
|
||||||
|
@ -195,14 +195,14 @@ uint8_t* MAX3421e< SPI_SS, INTR >::bytesWr(uint8_t reg, uint8_t nbytes, uint8_t*
|
||||||
#endif
|
#endif
|
||||||
SPI_SS::Clear();
|
SPI_SS::Clear();
|
||||||
|
|
||||||
#if SPI_HAS_TRANSACTION
|
#if USING_SPI4TEENSY3
|
||||||
SPI.transfer(reg | 0x02);
|
|
||||||
SPI.transfer(data_p, nbytes);
|
|
||||||
data_p += nbytes;
|
|
||||||
#elif USING_SPI4TEENSY3
|
|
||||||
spi4teensy3::send(reg | 0x02);
|
spi4teensy3::send(reg | 0x02);
|
||||||
spi4teensy3::send(data_p, nbytes);
|
spi4teensy3::send(data_p, nbytes);
|
||||||
data_p += nbytes;
|
data_p += nbytes;
|
||||||
|
#elif SPI_HAS_TRANSACTION
|
||||||
|
SPI.transfer(reg | 0x02);
|
||||||
|
SPI.transfer(data_p, nbytes);
|
||||||
|
data_p += nbytes;
|
||||||
#elif defined(__ARDUINO_X86__)
|
#elif defined(__ARDUINO_X86__)
|
||||||
SPI.transfer(reg | 0x02);
|
SPI.transfer(reg | 0x02);
|
||||||
SPI.transferBuffer(data_p, NULL, nbytes);
|
SPI.transferBuffer(data_p, NULL, nbytes);
|
||||||
|
@ -253,14 +253,14 @@ uint8_t MAX3421e< SPI_SS, INTR >::regRd(uint8_t reg) {
|
||||||
#endif
|
#endif
|
||||||
SPI_SS::Clear();
|
SPI_SS::Clear();
|
||||||
|
|
||||||
#if !defined(SPDR) || SPI_HAS_TRANSACTION
|
#if USING_SPI4TEENSY3
|
||||||
SPI.transfer(reg);
|
|
||||||
uint8_t rv = SPI.transfer(0); // Send empty byte
|
|
||||||
SPI_SS::Set();
|
|
||||||
#elif USING_SPI4TEENSY3
|
|
||||||
spi4teensy3::send(reg);
|
spi4teensy3::send(reg);
|
||||||
uint8_t rv = spi4teensy3::receive();
|
uint8_t rv = spi4teensy3::receive();
|
||||||
SPI_SS::Set();
|
SPI_SS::Set();
|
||||||
|
#elif !defined(SPDR) || SPI_HAS_TRANSACTION
|
||||||
|
SPI.transfer(reg);
|
||||||
|
uint8_t rv = SPI.transfer(0); // Send empty byte
|
||||||
|
SPI_SS::Set();
|
||||||
#else
|
#else
|
||||||
SPDR = reg;
|
SPDR = reg;
|
||||||
while(!(SPSR & (1 << SPIF)));
|
while(!(SPSR & (1 << SPIF)));
|
||||||
|
@ -287,15 +287,15 @@ uint8_t* MAX3421e< SPI_SS, INTR >::bytesRd(uint8_t reg, uint8_t nbytes, uint8_t*
|
||||||
#endif
|
#endif
|
||||||
SPI_SS::Clear();
|
SPI_SS::Clear();
|
||||||
|
|
||||||
#if SPI_HAS_TRANSACTION
|
#if USING_SPI4TEENSY3
|
||||||
|
spi4teensy3::send(reg);
|
||||||
|
spi4teensy3::receive(data_p, nbytes);
|
||||||
|
data_p += nbytes;
|
||||||
|
#elif SPI_HAS_TRANSACTION
|
||||||
SPI.transfer(reg);
|
SPI.transfer(reg);
|
||||||
memset(data_p, 0, nbytes); // Make sure we send out empty bytes
|
memset(data_p, 0, nbytes); // Make sure we send out empty bytes
|
||||||
SPI.transfer(data_p, nbytes);
|
SPI.transfer(data_p, nbytes);
|
||||||
data_p += nbytes;
|
data_p += nbytes;
|
||||||
#elif USING_SPI4TEENSY3
|
|
||||||
spi4teensy3::send(reg);
|
|
||||||
spi4teensy3::receive(data_p, nbytes);
|
|
||||||
data_p += nbytes;
|
|
||||||
#elif defined(__ARDUINO_X86__)
|
#elif defined(__ARDUINO_X86__)
|
||||||
SPI.transfer(reg);
|
SPI.transfer(reg);
|
||||||
SPI.transferBuffer(NULL, data_p, nbytes);
|
SPI.transferBuffer(NULL, data_p, nbytes);
|
||||||
|
|
Loading…
Reference in a new issue