dragonboard410c.c 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. /*
  2. * Board init file for Dragonboard 410C
  3. *
  4. * (C) Copyright 2015 Mateusz Kulikowski <mateusz.kulikowski@gmail.com>
  5. *
  6. * SPDX-License-Identifier: GPL-2.0+
  7. */
  8. #include <common.h>
  9. #include <dm.h>
  10. #include <usb.h>
  11. #include <asm/gpio.h>
  12. DECLARE_GLOBAL_DATA_PTR;
  13. int dram_init(void)
  14. {
  15. gd->ram_size = PHYS_SDRAM_1_SIZE;
  16. return 0;
  17. }
  18. void dram_init_banksize(void)
  19. {
  20. gd->bd->bi_dram[0].start = PHYS_SDRAM_1;
  21. gd->bd->bi_dram[0].size = PHYS_SDRAM_1_SIZE;
  22. }
  23. int board_prepare_usb(enum usb_init_type type)
  24. {
  25. static struct udevice *pmic_gpio;
  26. static struct gpio_desc hub_reset, usb_sel;
  27. int ret = 0, node;
  28. if (!pmic_gpio) {
  29. ret = uclass_get_device_by_name(UCLASS_GPIO,
  30. "pm8916_gpios@c000",
  31. &pmic_gpio);
  32. if (ret < 0) {
  33. printf("Failed to find pm8916_gpios@c000 node.\n");
  34. return ret;
  35. }
  36. }
  37. /* Try to request gpios needed to start usb host on dragonboard */
  38. if (!dm_gpio_is_valid(&hub_reset)) {
  39. node = fdt_subnode_offset(gd->fdt_blob, pmic_gpio->of_offset,
  40. "usb_hub_reset_pm");
  41. if (node < 0) {
  42. printf("Failed to find usb_hub_reset_pm dt node.\n");
  43. return node;
  44. }
  45. ret = gpio_request_by_name_nodev(gd->fdt_blob, node, "gpios", 0,
  46. &hub_reset, 0);
  47. if (ret < 0) {
  48. printf("Failed to request usb_hub_reset_pm gpio.\n");
  49. return ret;
  50. }
  51. }
  52. if (!dm_gpio_is_valid(&usb_sel)) {
  53. node = fdt_subnode_offset(gd->fdt_blob, pmic_gpio->of_offset,
  54. "usb_sw_sel_pm");
  55. if (node < 0) {
  56. printf("Failed to find usb_sw_sel_pm dt node.\n");
  57. return 0;
  58. }
  59. ret = gpio_request_by_name_nodev(gd->fdt_blob, node, "gpios", 0,
  60. &usb_sel, 0);
  61. if (ret < 0) {
  62. printf("Failed to request usb_sw_sel_pm gpio.\n");
  63. return ret;
  64. }
  65. }
  66. if (type == USB_INIT_HOST) {
  67. /* Start USB Hub */
  68. dm_gpio_set_dir_flags(&hub_reset,
  69. GPIOD_IS_OUT | GPIOD_IS_OUT_ACTIVE);
  70. mdelay(100);
  71. /* Switch usb to host connectors */
  72. dm_gpio_set_dir_flags(&usb_sel,
  73. GPIOD_IS_OUT | GPIOD_IS_OUT_ACTIVE);
  74. mdelay(100);
  75. } else { /* Device */
  76. /* Disable hub */
  77. dm_gpio_set_dir_flags(&hub_reset, GPIOD_IS_OUT);
  78. /* Switch back to device connector */
  79. dm_gpio_set_dir_flags(&usb_sel, GPIOD_IS_OUT);
  80. }
  81. return 0;
  82. }
  83. int board_init(void)
  84. {
  85. return 0;
  86. }
  87. /* Check for vol- button - if pressed - stop autoboot */
  88. int misc_init_r(void)
  89. {
  90. struct udevice *pon;
  91. struct gpio_desc resin;
  92. int node, ret;
  93. ret = uclass_get_device_by_name(UCLASS_GPIO, "pm8916_pon@800", &pon);
  94. if (ret < 0) {
  95. printf("Failed to find PMIC pon node. Check device tree\n");
  96. return 0;
  97. }
  98. node = fdt_subnode_offset(gd->fdt_blob, pon->of_offset, "key_vol_down");
  99. if (node < 0) {
  100. printf("Failed to find key_vol_down node. Check device tree\n");
  101. return 0;
  102. }
  103. if (gpio_request_by_name_nodev(gd->fdt_blob, node, "gpios", 0, &resin,
  104. 0)) {
  105. printf("Failed to request key_vol_down button.\n");
  106. return 0;
  107. }
  108. if (dm_gpio_get_value(&resin)) {
  109. setenv("bootdelay", "-1");
  110. printf("Power button pressed - dropping to console.\n");
  111. }
  112. return 0;
  113. }