logo

oasis-root

Compiled tree of Oasis Linux based on own branch at <https://hacktivis.me/git/oasis/> git clone https://anongit.hacktivis.me/git/oasis-root.git

spi.h (1989B)


  1. /* SPDX-License-Identifier: GPL-2.0+ WITH Linux-syscall-note */
  2. #ifndef _SPI_H
  3. #define _SPI_H
  4. #include <linux/const.h>
  5. #define SPI_CPHA _BITUL(0) /* clock phase */
  6. #define SPI_CPOL _BITUL(1) /* clock polarity */
  7. #define SPI_MODE_0 (0|0) /* (original MicroWire) */
  8. #define SPI_MODE_1 (0|SPI_CPHA)
  9. #define SPI_MODE_2 (SPI_CPOL|0)
  10. #define SPI_MODE_3 (SPI_CPOL|SPI_CPHA)
  11. #define SPI_MODE_X_MASK (SPI_CPOL|SPI_CPHA)
  12. #define SPI_CS_HIGH _BITUL(2) /* chipselect active high? */
  13. #define SPI_LSB_FIRST _BITUL(3) /* per-word bits-on-wire */
  14. #define SPI_3WIRE _BITUL(4) /* SI/SO signals shared */
  15. #define SPI_LOOP _BITUL(5) /* loopback mode */
  16. #define SPI_NO_CS _BITUL(6) /* 1 dev/bus, no chipselect */
  17. #define SPI_READY _BITUL(7) /* slave pulls low to pause */
  18. #define SPI_TX_DUAL _BITUL(8) /* transmit with 2 wires */
  19. #define SPI_TX_QUAD _BITUL(9) /* transmit with 4 wires */
  20. #define SPI_RX_DUAL _BITUL(10) /* receive with 2 wires */
  21. #define SPI_RX_QUAD _BITUL(11) /* receive with 4 wires */
  22. #define SPI_CS_WORD _BITUL(12) /* toggle cs after each word */
  23. #define SPI_TX_OCTAL _BITUL(13) /* transmit with 8 wires */
  24. #define SPI_RX_OCTAL _BITUL(14) /* receive with 8 wires */
  25. #define SPI_3WIRE_HIZ _BITUL(15) /* high impedance turnaround */
  26. #define SPI_RX_CPHA_FLIP _BITUL(16) /* flip CPHA on Rx only xfer */
  27. #define SPI_MOSI_IDLE_LOW _BITUL(17) /* leave MOSI line low when idle */
  28. #define SPI_MOSI_IDLE_HIGH _BITUL(18) /* leave MOSI line high when idle */
  29. /*
  30. * All the bits defined above should be covered by SPI_MODE_USER_MASK.
  31. * The SPI_MODE_USER_MASK has the SPI_MODE_KERNEL_MASK counterpart in
  32. * 'include/linux/spi/spi.h'. The bits defined here are from bit 0 upwards
  33. * while in SPI_MODE_KERNEL_MASK they are from the other end downwards.
  34. * These bits must not overlap. A static assert check should make sure of that.
  35. * If adding extra bits, make sure to increase the bit index below as well.
  36. */
  37. #define SPI_MODE_USER_MASK (_BITUL(19) - 1)
  38. #endif /* _SPI_H */