i2c.h 5.0 KB

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