twi.h 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. /*
  2. * TWI Masks
  3. */
  4. #ifndef __BFIN_PERIPHERAL_TWI__
  5. #define __BFIN_PERIPHERAL_TWI__
  6. /* TWI_CLKDIV Macros (Use: *pTWI_CLKDIV = CLKLOW(x)|CLKHI(y); ) */
  7. #define CLKLOW(x) ((x) & 0xFF) /* Periods Clock Is Held Low */
  8. #define CLKHI(y) (((y)&0xFF)<<0x8) /* Periods Before New Clock Low */
  9. /* TWI_PRESCALE Masks */
  10. #define PRESCALE 0x007F /* SCLKs Per Internal Time Reference (10MHz) */
  11. #define TWI_ENA 0x0080 /* TWI Enable */
  12. #define SCCB 0x0200 /* SCCB Compatibility Enable */
  13. /* TWI_SLAVE_CTL Masks */
  14. #define SEN 0x0001 /* Slave Enable */
  15. #define SADD_LEN 0x0002 /* Slave Address Length */
  16. #define STDVAL 0x0004 /* Slave Transmit Data Valid */
  17. #define TSC_NAK 0x0008 /* NAK/ACK* Generated At Conclusion Of Transfer */
  18. #define GEN 0x0010 /* General Call Adrress Matching Enabled */
  19. /* TWI_SLAVE_STAT Masks */
  20. #define SDIR 0x0001 /* Slave Transfer Direction (Transmit/Receive*) */
  21. #define GCALL 0x0002 /* General Call Indicator */
  22. /* TWI_MASTER_CTRL Masks */
  23. #define MEN 0x0001 /* Master Mode Enable */
  24. #define MADD_LEN 0x0002 /* Master Address Length */
  25. #define MDIR 0x0004 /* Master Transmit Direction (RX/TX*) */
  26. #define FAST 0x0008 /* Use Fast Mode Timing Specs */
  27. #define STOP 0x0010 /* Issue Stop Condition */
  28. #define RSTART 0x0020 /* Repeat Start or Stop* At End Of Transfer */
  29. #define DCNT 0x3FC0 /* Data Bytes To Transfer */
  30. #define SDAOVR 0x4000 /* Serial Data Override */
  31. #define SCLOVR 0x8000 /* Serial Clock Override */
  32. /* TWI_MASTER_STAT Masks */
  33. #define MPROG 0x0001 /* Master Transfer In Progress */
  34. #define LOSTARB 0x0002 /* Lost Arbitration Indicator (Xfer Aborted) */
  35. #define ANAK 0x0004 /* Address Not Acknowledged */
  36. #define DNAK 0x0008 /* Data Not Acknowledged */
  37. #define BUFRDERR 0x0010 /* Buffer Read Error */
  38. #define BUFWRERR 0x0020 /* Buffer Write Error */
  39. #define SDASEN 0x0040 /* Serial Data Sense */
  40. #define SCLSEN 0x0080 /* Serial Clock Sense */
  41. #define BUSBUSY 0x0100 /* Bus Busy Indicator */
  42. /* TWI_INT_SRC and TWI_INT_ENABLE Masks */
  43. #define SINIT 0x0001 /* Slave Transfer Initiated */
  44. #define SCOMP 0x0002 /* Slave Transfer Complete */
  45. #define SERR 0x0004 /* Slave Transfer Error */
  46. #define SOVF 0x0008 /* Slave Overflow */
  47. #define MCOMP 0x0010 /* Master Transfer Complete */
  48. #define MERR 0x0020 /* Master Transfer Error */
  49. #define XMTSERV 0x0040 /* Transmit FIFO Service */
  50. #define RCVSERV 0x0080 /* Receive FIFO Service */
  51. /* TWI_FIFO_CTRL Masks */
  52. #define XMTFLUSH 0x0001 /* Transmit Buffer Flush */
  53. #define RCVFLUSH 0x0002 /* Receive Buffer Flush */
  54. #define XMTINTLEN 0x0004 /* Transmit Buffer Interrupt Length */
  55. #define RCVINTLEN 0x0008 /* Receive Buffer Interrupt Length */
  56. /* TWI_FIFO_STAT Masks */
  57. #define XMTSTAT 0x0003 /* Transmit FIFO Status */
  58. #define XMT_EMPTY 0x0000 /* Transmit FIFO Empty */
  59. #define XMT_HALF 0x0001 /* Transmit FIFO Has 1 Byte To Write */
  60. #define XMT_FULL 0x0003 /* Transmit FIFO Full (2 Bytes To Write) */
  61. #define RCVSTAT 0x000C /* Receive FIFO Status */
  62. #define RCV_EMPTY 0x0000 /* Receive FIFO Empty */
  63. #define RCV_HALF 0x0004 /* Receive FIFO Has 1 Byte To Read */
  64. #define RCV_FULL 0x000C /* Receive FIFO Full (2 Bytes To Read) */
  65. #endif