kona_gpio.c 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright 2013 Broadcom Corporation.
  4. */
  5. #include <common.h>
  6. #include <asm/io.h>
  7. #include <asm/arch/sysmap.h>
  8. #define GPIO_BASE (void *)GPIO2_BASE_ADDR
  9. #define GPIO_PASSWD 0x00a5a501
  10. #define GPIO_PER_BANK 32
  11. #define GPIO_MAX_BANK_NUM 8
  12. #define GPIO_BANK(gpio) ((gpio) >> 5)
  13. #define GPIO_BITMASK(gpio) \
  14. (1UL << ((gpio) & (GPIO_PER_BANK - 1)))
  15. #define GPIO_OUT_STATUS(bank) (0x00000000 + ((bank) << 2))
  16. #define GPIO_IN_STATUS(bank) (0x00000020 + ((bank) << 2))
  17. #define GPIO_OUT_SET(bank) (0x00000040 + ((bank) << 2))
  18. #define GPIO_OUT_CLEAR(bank) (0x00000060 + ((bank) << 2))
  19. #define GPIO_INT_STATUS(bank) (0x00000080 + ((bank) << 2))
  20. #define GPIO_INT_MASK(bank) (0x000000a0 + ((bank) << 2))
  21. #define GPIO_INT_MSKCLR(bank) (0x000000c0 + ((bank) << 2))
  22. #define GPIO_CONTROL(bank) (0x00000100 + ((bank) << 2))
  23. #define GPIO_PWD_STATUS(bank) (0x00000500 + ((bank) << 2))
  24. #define GPIO_GPPWR_OFFSET 0x00000520
  25. #define GPIO_GPCTR0_DBR_SHIFT 5
  26. #define GPIO_GPCTR0_DBR_MASK 0x000001e0
  27. #define GPIO_GPCTR0_ITR_SHIFT 3
  28. #define GPIO_GPCTR0_ITR_MASK 0x00000018
  29. #define GPIO_GPCTR0_ITR_CMD_RISING_EDGE 0x00000001
  30. #define GPIO_GPCTR0_ITR_CMD_FALLING_EDGE 0x00000002
  31. #define GPIO_GPCTR0_ITR_CMD_BOTH_EDGE 0x00000003
  32. #define GPIO_GPCTR0_IOTR_MASK 0x00000001
  33. #define GPIO_GPCTR0_IOTR_CMD_0UTPUT 0x00000000
  34. #define GPIO_GPCTR0_IOTR_CMD_INPUT 0x00000001
  35. int gpio_request(unsigned gpio, const char *label)
  36. {
  37. unsigned int value, off;
  38. writel(GPIO_PASSWD, GPIO_BASE + GPIO_GPPWR_OFFSET);
  39. off = GPIO_PWD_STATUS(GPIO_BANK(gpio));
  40. value = readl(GPIO_BASE + off) & ~GPIO_BITMASK(gpio);
  41. writel(value, GPIO_BASE + off);
  42. return 0;
  43. }
  44. int gpio_free(unsigned gpio)
  45. {
  46. unsigned int value, off;
  47. writel(GPIO_PASSWD, GPIO_BASE + GPIO_GPPWR_OFFSET);
  48. off = GPIO_PWD_STATUS(GPIO_BANK(gpio));
  49. value = readl(GPIO_BASE + off) | GPIO_BITMASK(gpio);
  50. writel(value, GPIO_BASE + off);
  51. return 0;
  52. }
  53. int gpio_direction_input(unsigned gpio)
  54. {
  55. u32 val;
  56. val = readl(GPIO_BASE + GPIO_CONTROL(gpio));
  57. val &= ~GPIO_GPCTR0_IOTR_MASK;
  58. val |= GPIO_GPCTR0_IOTR_CMD_INPUT;
  59. writel(val, GPIO_BASE + GPIO_CONTROL(gpio));
  60. return 0;
  61. }
  62. int gpio_direction_output(unsigned gpio, int value)
  63. {
  64. int bank_id = GPIO_BANK(gpio);
  65. int bitmask = GPIO_BITMASK(gpio);
  66. u32 val, off;
  67. val = readl(GPIO_BASE + GPIO_CONTROL(gpio));
  68. val &= ~GPIO_GPCTR0_IOTR_MASK;
  69. val |= GPIO_GPCTR0_IOTR_CMD_0UTPUT;
  70. writel(val, GPIO_BASE + GPIO_CONTROL(gpio));
  71. off = value ? GPIO_OUT_SET(bank_id) : GPIO_OUT_CLEAR(bank_id);
  72. val = readl(GPIO_BASE + off);
  73. val |= bitmask;
  74. writel(val, GPIO_BASE + off);
  75. return 0;
  76. }
  77. int gpio_get_value(unsigned gpio)
  78. {
  79. int bank_id = GPIO_BANK(gpio);
  80. int bitmask = GPIO_BITMASK(gpio);
  81. u32 val, off;
  82. /* determine the GPIO pin direction */
  83. val = readl(GPIO_BASE + GPIO_CONTROL(gpio));
  84. val &= GPIO_GPCTR0_IOTR_MASK;
  85. /* read the GPIO bank status */
  86. off = (GPIO_GPCTR0_IOTR_CMD_INPUT == val) ?
  87. GPIO_IN_STATUS(bank_id) : GPIO_OUT_STATUS(bank_id);
  88. val = readl(GPIO_BASE + off);
  89. /* return the specified bit status */
  90. return !!(val & bitmask);
  91. }
  92. void gpio_set_value(unsigned gpio, int value)
  93. {
  94. int bank_id = GPIO_BANK(gpio);
  95. int bitmask = GPIO_BITMASK(gpio);
  96. u32 val, off;
  97. /* determine the GPIO pin direction */
  98. val = readl(GPIO_BASE + GPIO_CONTROL(gpio));
  99. val &= GPIO_GPCTR0_IOTR_MASK;
  100. /* this function only applies to output pin */
  101. if (GPIO_GPCTR0_IOTR_CMD_INPUT == val) {
  102. printf("%s: Cannot set an input pin %d\n", __func__, gpio);
  103. return;
  104. }
  105. off = value ? GPIO_OUT_SET(bank_id) : GPIO_OUT_CLEAR(bank_id);
  106. val = readl(GPIO_BASE + off);
  107. val |= bitmask;
  108. writel(val, GPIO_BASE + off);
  109. }