pinctrl-equilibrium.h 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /*
  3. * Copyright(c) 2019 Intel Corporation.
  4. */
  5. #ifndef __PINCTRL_EQUILIBRIUM_H
  6. #define __PINCTRL_EQUILIBRIUM_H
  7. /* PINPAD register offset */
  8. #define REG_PMX_BASE 0x0 /* Port Multiplexer Control Register */
  9. #define REG_PUEN 0x80 /* PULL UP Enable Register */
  10. #define REG_PDEN 0x84 /* PULL DOWN Enable Register */
  11. #define REG_SRC 0x88 /* Slew Rate Control Register */
  12. #define REG_DCC0 0x8C /* Drive Current Control Register 0 */
  13. #define REG_DCC1 0x90 /* Drive Current Control Register 1 */
  14. #define REG_OD 0x94 /* Open Drain Enable Register */
  15. #define REG_AVAIL 0x98 /* Pad Control Availability Register */
  16. #define DRV_CUR_PINS 16 /* Drive Current pin number per register */
  17. #define REG_DRCC(x) (REG_DCC0 + (x) * 4) /* Driver current macro */
  18. /* GPIO register offset */
  19. #define GPIO_OUT 0x0 /* Data Output Register */
  20. #define GPIO_IN 0x4 /* Data Input Register */
  21. #define GPIO_DIR 0x8 /* Direction Register */
  22. #define GPIO_EXINTCR0 0x18 /* External Interrupt Control Register 0 */
  23. #define GPIO_EXINTCR1 0x1C /* External Interrupt Control Register 1 */
  24. #define GPIO_IRNCR 0x20 /* IRN Capture Register */
  25. #define GPIO_IRNICR 0x24 /* IRN Interrupt Control Register */
  26. #define GPIO_IRNEN 0x28 /* IRN Interrupt Enable Register */
  27. #define GPIO_IRNCFG 0x2C /* IRN Interrupt Configuration Register */
  28. #define GPIO_IRNRNSET 0x30 /* IRN Interrupt Enable Set Register */
  29. #define GPIO_IRNENCLR 0x34 /* IRN Interrupt Enable Clear Register */
  30. #define GPIO_OUTSET 0x40 /* Output Set Register */
  31. #define GPIO_OUTCLR 0x44 /* Output Clear Register */
  32. #define GPIO_DIRSET 0x48 /* Direction Set Register */
  33. #define GPIO_DIRCLR 0x4C /* Direction Clear Register */
  34. /* parse given pin's driver current value */
  35. #define PARSE_DRV_CURRENT(val, pin) (((val) >> ((pin) * 2)) & 0x3)
  36. #define GPIO_EDGE_TRIG 0
  37. #define GPIO_LEVEL_TRIG 1
  38. #define GPIO_SINGLE_EDGE 0
  39. #define GPIO_BOTH_EDGE 1
  40. #define GPIO_POSITIVE_TRIG 0
  41. #define GPIO_NEGATIVE_TRIG 1
  42. #define EQBR_GPIO_MODE 0
  43. typedef enum {
  44. OP_COUNT_NR_FUNCS,
  45. OP_ADD_FUNCS,
  46. OP_COUNT_NR_FUNC_GRPS,
  47. OP_ADD_FUNC_GRPS,
  48. OP_NONE,
  49. } funcs_util_ops;
  50. /**
  51. * struct gpio_irq_type: gpio irq configuration
  52. * @trig_type: level trigger or edge trigger
  53. * @edge_type: sigle edge or both edge
  54. * @logic_type: positive trigger or negative trigger
  55. */
  56. struct gpio_irq_type {
  57. unsigned int trig_type;
  58. unsigned int edge_type;
  59. unsigned int logic_type;
  60. };
  61. /**
  62. * struct eqbr_pin_bank: represent a pin bank.
  63. * @membase: base address of the pin bank register.
  64. * @id: bank id, to idenify the unique bank.
  65. * @pin_base: starting pin number of the pin bank.
  66. * @nr_pins: number of the pins of the pin bank.
  67. * @aval_pinmap: available pin bitmap of the pin bank.
  68. */
  69. struct eqbr_pin_bank {
  70. void __iomem *membase;
  71. unsigned int id;
  72. unsigned int pin_base;
  73. unsigned int nr_pins;
  74. u32 aval_pinmap;
  75. };
  76. struct fwnode_handle;
  77. /**
  78. * struct eqbr_gpio_ctrl: represent a gpio controller.
  79. * @chip: gpio chip.
  80. * @fwnode: firmware node of gpio controller.
  81. * @bank: pointer to corresponding pin bank.
  82. * @membase: base address of the gpio controller.
  83. * @name: gpio chip name.
  84. * @virq: irq number of the gpio chip to parent's irq domain.
  85. * @lock: spin lock to protect gpio register write.
  86. */
  87. struct eqbr_gpio_ctrl {
  88. struct gpio_chip chip;
  89. struct fwnode_handle *fwnode;
  90. struct eqbr_pin_bank *bank;
  91. void __iomem *membase;
  92. const char *name;
  93. unsigned int virq;
  94. raw_spinlock_t lock; /* protect gpio register */
  95. };
  96. /**
  97. * struct eqbr_pinctrl_drv_data:
  98. * @dev: device instance representing the controller.
  99. * @pctl_desc: pin controller descriptor.
  100. * @pctl_dev: pin control class device
  101. * @membase: base address of pin controller
  102. * @pin_banks: list of pin banks of the driver.
  103. * @nr_banks: number of pin banks.
  104. * @gpio_ctrls: list of gpio controllers.
  105. * @nr_gpio_ctrls: number of gpio controllers.
  106. * @lock: protect pinctrl register write
  107. */
  108. struct eqbr_pinctrl_drv_data {
  109. struct device *dev;
  110. struct pinctrl_desc pctl_desc;
  111. struct pinctrl_dev *pctl_dev;
  112. void __iomem *membase;
  113. struct eqbr_pin_bank *pin_banks;
  114. unsigned int nr_banks;
  115. struct eqbr_gpio_ctrl *gpio_ctrls;
  116. unsigned int nr_gpio_ctrls;
  117. raw_spinlock_t lock; /* protect pinpad register */
  118. };
  119. #endif /* __PINCTRL_EQUILIBRIUM_H */