mv_i2c.h 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. /*
  2. * (C) Copyright 2011
  3. * Marvell Inc, <www.marvell.com>
  4. *
  5. * SPDX-License-Identifier: GPL-2.0+
  6. */
  7. #ifndef _MV_I2C_H_
  8. #define _MV_I2C_H_
  9. extern void i2c_clk_enable(void);
  10. /* Shall the current transfer have a start/stop condition? */
  11. #define I2C_COND_NORMAL 0
  12. #define I2C_COND_START 1
  13. #define I2C_COND_STOP 2
  14. /* Shall the current transfer be ack/nacked or being waited for it? */
  15. #define I2C_ACKNAK_WAITACK 1
  16. #define I2C_ACKNAK_SENDACK 2
  17. #define I2C_ACKNAK_SENDNAK 4
  18. /* Specify who shall transfer the data (master or slave) */
  19. #define I2C_READ 0
  20. #define I2C_WRITE 1
  21. #define I2C_ICR_INIT (ICR_BEIE | ICR_IRFIE | ICR_ITEIE | ICR_GCD | ICR_SCLE)
  22. #define I2C_ISR_INIT 0x7FF
  23. /* ----- Control register bits ---------------------------------------- */
  24. #define ICR_START 0x1 /* start bit */
  25. #define ICR_STOP 0x2 /* stop bit */
  26. #define ICR_ACKNAK 0x4 /* send ACK(0) or NAK(1) */
  27. #define ICR_TB 0x8 /* transfer byte bit */
  28. #define ICR_MA 0x10 /* master abort */
  29. #define ICR_SCLE 0x20 /* master clock enable, mona SCLEA */
  30. #define ICR_IUE 0x40 /* unit enable */
  31. #define ICR_GCD 0x80 /* general call disable */
  32. #define ICR_ITEIE 0x100 /* enable tx interrupts */
  33. #define ICR_IRFIE 0x200 /* enable rx interrupts, mona: DRFIE */
  34. #define ICR_BEIE 0x400 /* enable bus error ints */
  35. #define ICR_SSDIE 0x800 /* slave STOP detected int enable */
  36. #define ICR_ALDIE 0x1000 /* enable arbitration interrupt */
  37. #define ICR_SADIE 0x2000 /* slave address detected int enable */
  38. #define ICR_UR 0x4000 /* unit reset */
  39. #ifdef CONFIG_ARMADA_3700
  40. #define ICR_SM 0x00000 /* Standard Mode */
  41. #define ICR_FM 0x10000 /* Fast Mode */
  42. #define ICR_MODE_MASK 0x30000 /* Mode mask */
  43. #else
  44. #define ICR_SM 0x00000 /* Standard Mode */
  45. #define ICR_FM 0x08000 /* Fast Mode */
  46. #define ICR_MODE_MASK 0x18000 /* Mode mask */
  47. #endif
  48. /* ----- Status register bits ----------------------------------------- */
  49. #define ISR_RWM 0x1 /* read/write mode */
  50. #define ISR_ACKNAK 0x2 /* ack/nak status */
  51. #define ISR_UB 0x4 /* unit busy */
  52. #define ISR_IBB 0x8 /* bus busy */
  53. #define ISR_SSD 0x10 /* slave stop detected */
  54. #define ISR_ALD 0x20 /* arbitration loss detected */
  55. #define ISR_ITE 0x40 /* tx buffer empty */
  56. #define ISR_IRF 0x80 /* rx buffer full */
  57. #define ISR_GCAD 0x100 /* general call address detected */
  58. #define ISR_SAD 0x200 /* slave address detected */
  59. #define ISR_BED 0x400 /* bus error no ACK/NAK */
  60. #endif