lp3943.h 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * TI/National Semiconductor LP3943 Device
  4. *
  5. * Copyright 2013 Texas Instruments
  6. *
  7. * Author: Milo Kim <[email protected]>
  8. */
  9. #ifndef __MFD_LP3943_H__
  10. #define __MFD_LP3943_H__
  11. #include <linux/gpio.h>
  12. #include <linux/pwm.h>
  13. #include <linux/regmap.h>
  14. /* Registers */
  15. #define LP3943_REG_GPIO_A 0x00
  16. #define LP3943_REG_GPIO_B 0x01
  17. #define LP3943_REG_PRESCALE0 0x02
  18. #define LP3943_REG_PWM0 0x03
  19. #define LP3943_REG_PRESCALE1 0x04
  20. #define LP3943_REG_PWM1 0x05
  21. #define LP3943_REG_MUX0 0x06
  22. #define LP3943_REG_MUX1 0x07
  23. #define LP3943_REG_MUX2 0x08
  24. #define LP3943_REG_MUX3 0x09
  25. /* Bit description for LP3943_REG_MUX0 ~ 3 */
  26. #define LP3943_GPIO_IN 0x00
  27. #define LP3943_GPIO_OUT_HIGH 0x00
  28. #define LP3943_GPIO_OUT_LOW 0x01
  29. #define LP3943_DIM_PWM0 0x02
  30. #define LP3943_DIM_PWM1 0x03
  31. #define LP3943_NUM_PWMS 2
  32. enum lp3943_pwm_output {
  33. LP3943_PWM_OUT0,
  34. LP3943_PWM_OUT1,
  35. LP3943_PWM_OUT2,
  36. LP3943_PWM_OUT3,
  37. LP3943_PWM_OUT4,
  38. LP3943_PWM_OUT5,
  39. LP3943_PWM_OUT6,
  40. LP3943_PWM_OUT7,
  41. LP3943_PWM_OUT8,
  42. LP3943_PWM_OUT9,
  43. LP3943_PWM_OUT10,
  44. LP3943_PWM_OUT11,
  45. LP3943_PWM_OUT12,
  46. LP3943_PWM_OUT13,
  47. LP3943_PWM_OUT14,
  48. LP3943_PWM_OUT15,
  49. };
  50. /*
  51. * struct lp3943_pwm_map
  52. * @output: Output pins which are mapped to each PWM channel
  53. * @num_outputs: Number of outputs
  54. */
  55. struct lp3943_pwm_map {
  56. enum lp3943_pwm_output *output;
  57. int num_outputs;
  58. };
  59. /*
  60. * struct lp3943_platform_data
  61. * @pwms: Output channel definitions for PWM channel 0 and 1
  62. */
  63. struct lp3943_platform_data {
  64. struct lp3943_pwm_map *pwms[LP3943_NUM_PWMS];
  65. };
  66. /*
  67. * struct lp3943_reg_cfg
  68. * @reg: Register address
  69. * @mask: Register bit mask to be updated
  70. * @shift: Register bit shift
  71. */
  72. struct lp3943_reg_cfg {
  73. u8 reg;
  74. u8 mask;
  75. u8 shift;
  76. };
  77. /*
  78. * struct lp3943
  79. * @dev: Parent device pointer
  80. * @regmap: Used for I2C communication on accessing registers
  81. * @pdata: LP3943 platform specific data
  82. * @mux_cfg: Register configuration for pin MUX
  83. * @pin_used: Bit mask for output pin used.
  84. * This bitmask is used for pin assignment management.
  85. * 1 = pin used, 0 = available.
  86. * Only LSB 16 bits are used, but it is unsigned long type
  87. * for atomic bitwise operations.
  88. */
  89. struct lp3943 {
  90. struct device *dev;
  91. struct regmap *regmap;
  92. struct lp3943_platform_data *pdata;
  93. const struct lp3943_reg_cfg *mux_cfg;
  94. unsigned long pin_used;
  95. };
  96. int lp3943_read_byte(struct lp3943 *lp3943, u8 reg, u8 *read);
  97. int lp3943_write_byte(struct lp3943 *lp3943, u8 reg, u8 data);
  98. int lp3943_update_bits(struct lp3943 *lp3943, u8 reg, u8 mask, u8 data);
  99. #endif