ds90ub953.h 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. #ifndef __MEDIA_I2C_DS90UB953_H__
  3. #define __MEDIA_I2C_DS90UB953_H__
  4. #include <linux/types.h>
  5. #define UB953_REG_RESET_CTL 0x01
  6. #define UB953_REG_RESET_CTL_DIGITAL_RESET_1 BIT(1)
  7. #define UB953_REG_RESET_CTL_DIGITAL_RESET_0 BIT(0)
  8. #define UB953_REG_GENERAL_CFG 0x02
  9. #define UB953_REG_GENERAL_CFG_CONT_CLK BIT(6)
  10. #define UB953_REG_GENERAL_CFG_CSI_LANE_SEL_SHIFT 4
  11. #define UB953_REG_GENERAL_CFG_CSI_LANE_SEL_MASK GENMASK(5, 4)
  12. #define UB953_REG_GENERAL_CFG_CRC_TX_GEN_ENABLE BIT(1)
  13. #define UB953_REG_GENERAL_CFG_I2C_STRAP_MODE BIT(0)
  14. #define UB953_REG_MODE_SEL 0x03
  15. #define UB953_REG_MODE_SEL_MODE_DONE BIT(3)
  16. #define UB953_REG_MODE_SEL_MODE_OVERRIDE BIT(4)
  17. #define UB953_REG_MODE_SEL_MODE_MASK GENMASK(2, 0)
  18. #define UB953_REG_CLKOUT_CTRL0 0x06
  19. #define UB953_REG_CLKOUT_CTRL1 0x07
  20. #define UB953_REG_I2C_CONTROL2 0x0a
  21. #define UB953_REG_I2C_CONTROL2_SDA_OUTPUT_SETUP_SHIFT 4
  22. #define UB953_REG_I2C_CONTROL2_BUS_SPEEDUP BIT(1)
  23. #define UB953_REG_SCL_HIGH_TIME 0x0b
  24. #define UB953_REG_SCL_LOW_TIME 0x0c
  25. #define UB953_REG_LOCAL_GPIO_DATA 0x0d
  26. #define UB953_REG_LOCAL_GPIO_DATA_GPIO_RMTEN(n) BIT(4 + (n))
  27. #define UB953_REG_LOCAL_GPIO_DATA_GPIO_OUT_SRC(n) BIT(0 + (n))
  28. #define UB953_REG_GPIO_INPUT_CTRL 0x0e
  29. #define UB953_REG_GPIO_INPUT_CTRL_OUT_EN(n) BIT(4 + (n))
  30. #define UB953_REG_GPIO_INPUT_CTRL_INPUT_EN(n) BIT(0 + (n))
  31. #define UB953_REG_BC_CTRL 0x49
  32. #define UB953_REG_BC_CTRL_CRC_ERR_CLR BIT(3)
  33. #define UB953_REG_REV_MASK_ID 0x50
  34. #define UB953_REG_GENERAL_STATUS 0x52
  35. #define UB953_REG_GPIO_PIN_STS 0x53
  36. #define UB953_REG_GPIO_PIN_STS_GPIO_STS(n) BIT(0 + (n))
  37. #define UB953_REG_BIST_ERR_CNT 0x54
  38. #define UB953_REG_CRC_ERR_CNT1 0x55
  39. #define UB953_REG_CRC_ERR_CNT2 0x56
  40. #define UB953_REG_CSI_ERR_CNT 0x5c
  41. #define UB953_REG_CSI_ERR_STATUS 0x5d
  42. #define UB953_REG_CSI_ERR_DLANE01 0x5e
  43. #define UB953_REG_CSI_ERR_DLANE23 0x5f
  44. #define UB953_REG_CSI_ERR_CLK_LANE 0x60
  45. #define UB953_REG_CSI_PKT_HDR_VC_ID 0x61
  46. #define UB953_REG_PKT_HDR_WC_LSB 0x62
  47. #define UB953_REG_PKT_HDR_WC_MSB 0x63
  48. #define UB953_REG_CSI_ECC 0x64
  49. #define UB953_REG_IND_ACC_CTL 0xb0
  50. #define UB953_REG_IND_ACC_ADDR 0xb1
  51. #define UB953_REG_IND_ACC_DATA 0xb2
  52. #define UB953_REG_FPD3_RX_ID(n) (0xf0 + (n))
  53. #define UB953_REG_FPD3_RX_ID_LEN 6
  54. /* Indirect register blocks */
  55. #define UB953_IND_TARGET_PAT_GEN 0x00
  56. #define UB953_IND_TARGET_ANALOG 0x01
  57. #define UB953_IND_TARGET_DIE_ID 0x02
  58. #define UB953_IND_PGEN_CTL 0x01
  59. #define UB953_IND_PGEN_CTL_PGEN_ENABLE BIT(0)
  60. #define UB953_IND_PGEN_CFG 0x02
  61. #define UB953_IND_PGEN_CSI_DI 0x03
  62. #define UB953_IND_PGEN_LINE_SIZE1 0x04
  63. #define UB953_IND_PGEN_LINE_SIZE0 0x05
  64. #define UB953_IND_PGEN_BAR_SIZE1 0x06
  65. #define UB953_IND_PGEN_BAR_SIZE0 0x07
  66. #define UB953_IND_PGEN_ACT_LPF1 0x08
  67. #define UB953_IND_PGEN_ACT_LPF0 0x09
  68. #define UB953_IND_PGEN_TOT_LPF1 0x0a
  69. #define UB953_IND_PGEN_TOT_LPF0 0x0b
  70. #define UB953_IND_PGEN_LINE_PD1 0x0c
  71. #define UB953_IND_PGEN_LINE_PD0 0x0d
  72. #define UB953_IND_PGEN_VBP 0x0e
  73. #define UB953_IND_PGEN_VFP 0x0f
  74. #define UB953_IND_PGEN_COLOR(n) (0x10 + (n)) /* n <= 15 */
  75. #define UB953_IND_ANA_TEMP_DYNAMIC_CFG 0x4b
  76. #define UB953_IND_ANA_TEMP_DYNAMIC_CFG_OV BIT(5)
  77. #define UB953_IND_ANA_TEMP_STATIC_CFG 0x4c
  78. #define UB953_IND_ANA_TEMP_STATIC_CFG_MASK GENMASK(6, 4)
  79. /* UB971 Registers */
  80. #define UB971_ENH_BC_CHK 0x4b
  81. #endif /* __MEDIA_I2C_DS90UB953_H__ */