i2c.h 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. #ifndef __NVKM_I2C_H__
  2. #define __NVKM_I2C_H__
  3. #include <core/subdev.h>
  4. #include <core/event.h>
  5. #include <subdev/bios.h>
  6. #include <subdev/bios/i2c.h>
  7. struct nvkm_i2c_ntfy_req {
  8. #define NVKM_I2C_PLUG 0x01
  9. #define NVKM_I2C_UNPLUG 0x02
  10. #define NVKM_I2C_IRQ 0x04
  11. #define NVKM_I2C_DONE 0x08
  12. #define NVKM_I2C_ANY 0x0f
  13. u8 mask;
  14. u8 port;
  15. };
  16. struct nvkm_i2c_ntfy_rep {
  17. u8 mask;
  18. };
  19. struct nvkm_i2c_bus_probe {
  20. struct i2c_board_info dev;
  21. u8 udelay; /* set to 0 to use the standard delay */
  22. };
  23. struct nvkm_i2c_bus {
  24. const struct nvkm_i2c_bus_func *func;
  25. struct nvkm_i2c_pad *pad;
  26. #define NVKM_I2C_BUS_CCB(n) /* 'n' is ccb index */ (n)
  27. #define NVKM_I2C_BUS_EXT(n) /* 'n' is dcb external encoder type */ ((n) + 0x100)
  28. #define NVKM_I2C_BUS_PRI /* ccb primary comm. port */ -1
  29. #define NVKM_I2C_BUS_SEC /* ccb secondary comm. port */ -2
  30. int id;
  31. struct mutex mutex;
  32. struct list_head head;
  33. struct i2c_adapter i2c;
  34. };
  35. int nvkm_i2c_bus_acquire(struct nvkm_i2c_bus *);
  36. void nvkm_i2c_bus_release(struct nvkm_i2c_bus *);
  37. int nvkm_i2c_bus_probe(struct nvkm_i2c_bus *, const char *,
  38. struct nvkm_i2c_bus_probe *,
  39. bool (*)(struct nvkm_i2c_bus *,
  40. struct i2c_board_info *, void *), void *);
  41. struct nvkm_i2c_aux {
  42. const struct nvkm_i2c_aux_func *func;
  43. struct nvkm_i2c_pad *pad;
  44. #define NVKM_I2C_AUX_CCB(n) /* 'n' is ccb index */ (n)
  45. #define NVKM_I2C_AUX_EXT(n) /* 'n' is dcb external encoder type */ ((n) + 0x100)
  46. int id;
  47. struct mutex mutex;
  48. struct list_head head;
  49. struct i2c_adapter i2c;
  50. u32 intr;
  51. };
  52. void nvkm_i2c_aux_monitor(struct nvkm_i2c_aux *, bool monitor);
  53. int nvkm_i2c_aux_acquire(struct nvkm_i2c_aux *);
  54. void nvkm_i2c_aux_release(struct nvkm_i2c_aux *);
  55. int nvkm_i2c_aux_xfer(struct nvkm_i2c_aux *, bool retry, u8 type,
  56. u32 addr, u8 *data, u8 *size);
  57. int nvkm_i2c_aux_lnk_ctl(struct nvkm_i2c_aux *, int link_nr, int link_bw,
  58. bool enhanced_framing);
  59. struct nvkm_i2c {
  60. const struct nvkm_i2c_func *func;
  61. struct nvkm_subdev subdev;
  62. struct list_head pad;
  63. struct list_head bus;
  64. struct list_head aux;
  65. struct nvkm_event event;
  66. };
  67. struct nvkm_i2c_bus *nvkm_i2c_bus_find(struct nvkm_i2c *, int);
  68. struct nvkm_i2c_aux *nvkm_i2c_aux_find(struct nvkm_i2c *, int);
  69. int nv04_i2c_new(struct nvkm_device *, int, struct nvkm_i2c **);
  70. int nv4e_i2c_new(struct nvkm_device *, int, struct nvkm_i2c **);
  71. int nv50_i2c_new(struct nvkm_device *, int, struct nvkm_i2c **);
  72. int g94_i2c_new(struct nvkm_device *, int, struct nvkm_i2c **);
  73. int gf117_i2c_new(struct nvkm_device *, int, struct nvkm_i2c **);
  74. int gf119_i2c_new(struct nvkm_device *, int, struct nvkm_i2c **);
  75. int gk104_i2c_new(struct nvkm_device *, int, struct nvkm_i2c **);
  76. int gm200_i2c_new(struct nvkm_device *, int, struct nvkm_i2c **);
  77. static inline int
  78. nvkm_rdi2cr(struct i2c_adapter *adap, u8 addr, u8 reg)
  79. {
  80. u8 val;
  81. struct i2c_msg msgs[] = {
  82. { .addr = addr, .flags = 0, .len = 1, .buf = &reg },
  83. { .addr = addr, .flags = I2C_M_RD, .len = 1, .buf = &val },
  84. };
  85. int ret = i2c_transfer(adap, msgs, ARRAY_SIZE(msgs));
  86. if (ret != 2)
  87. return -EIO;
  88. return val;
  89. }
  90. static inline int
  91. nv_rd16i2cr(struct i2c_adapter *adap, u8 addr, u8 reg)
  92. {
  93. u8 val[2];
  94. struct i2c_msg msgs[] = {
  95. { .addr = addr, .flags = 0, .len = 1, .buf = &reg },
  96. { .addr = addr, .flags = I2C_M_RD, .len = 2, .buf = val },
  97. };
  98. int ret = i2c_transfer(adap, msgs, ARRAY_SIZE(msgs));
  99. if (ret != 2)
  100. return -EIO;
  101. return val[0] << 8 | val[1];
  102. }
  103. static inline int
  104. nvkm_wri2cr(struct i2c_adapter *adap, u8 addr, u8 reg, u8 val)
  105. {
  106. u8 buf[2] = { reg, val };
  107. struct i2c_msg msgs[] = {
  108. { .addr = addr, .flags = 0, .len = 2, .buf = buf },
  109. };
  110. int ret = i2c_transfer(adap, msgs, ARRAY_SIZE(msgs));
  111. if (ret != 1)
  112. return -EIO;
  113. return 0;
  114. }
  115. static inline int
  116. nv_wr16i2cr(struct i2c_adapter *adap, u8 addr, u8 reg, u16 val)
  117. {
  118. u8 buf[3] = { reg, val >> 8, val & 0xff};
  119. struct i2c_msg msgs[] = {
  120. { .addr = addr, .flags = 0, .len = 3, .buf = buf },
  121. };
  122. int ret = i2c_transfer(adap, msgs, ARRAY_SIZE(msgs));
  123. if (ret != 1)
  124. return -EIO;
  125. return 0;
  126. }
  127. static inline bool
  128. nvkm_probe_i2c(struct i2c_adapter *adap, u8 addr)
  129. {
  130. return nvkm_rdi2cr(adap, addr, 0) >= 0;
  131. }
  132. static inline int
  133. nvkm_rdaux(struct nvkm_i2c_aux *aux, u32 addr, u8 *data, u8 size)
  134. {
  135. const u8 xfer = size;
  136. int ret = nvkm_i2c_aux_acquire(aux);
  137. if (ret == 0) {
  138. ret = nvkm_i2c_aux_xfer(aux, true, 9, addr, data, &size);
  139. WARN_ON(!ret && size != xfer);
  140. nvkm_i2c_aux_release(aux);
  141. }
  142. return ret;
  143. }
  144. static inline int
  145. nvkm_wraux(struct nvkm_i2c_aux *aux, u32 addr, u8 *data, u8 size)
  146. {
  147. int ret = nvkm_i2c_aux_acquire(aux);
  148. if (ret == 0) {
  149. ret = nvkm_i2c_aux_xfer(aux, true, 8, addr, data, &size);
  150. nvkm_i2c_aux_release(aux);
  151. }
  152. return ret;
  153. }
  154. #endif