dragonboard410c.c 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  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,
  40. dev_of_offset(pmic_gpio),
  41. "usb_hub_reset_pm");
  42. if (node < 0) {
  43. printf("Failed to find usb_hub_reset_pm dt node.\n");
  44. return node;
  45. }
  46. ret = gpio_request_by_name_nodev(gd->fdt_blob, node, "gpios", 0,
  47. &hub_reset, 0);
  48. if (ret < 0) {
  49. printf("Failed to request usb_hub_reset_pm gpio.\n");
  50. return ret;
  51. }
  52. }
  53. if (!dm_gpio_is_valid(&usb_sel)) {
  54. node = fdt_subnode_offset(gd->fdt_blob,
  55. dev_of_offset(pmic_gpio),
  56. "usb_sw_sel_pm");
  57. if (node < 0) {
  58. printf("Failed to find usb_sw_sel_pm dt node.\n");
  59. return 0;
  60. }
  61. ret = gpio_request_by_name_nodev(gd->fdt_blob, node, "gpios", 0,
  62. &usb_sel, 0);
  63. if (ret < 0) {
  64. printf("Failed to request usb_sw_sel_pm gpio.\n");
  65. return ret;
  66. }
  67. }
  68. if (type == USB_INIT_HOST) {
  69. /* Start USB Hub */
  70. dm_gpio_set_dir_flags(&hub_reset,
  71. GPIOD_IS_OUT | GPIOD_IS_OUT_ACTIVE);
  72. mdelay(100);
  73. /* Switch usb to host connectors */
  74. dm_gpio_set_dir_flags(&usb_sel,
  75. GPIOD_IS_OUT | GPIOD_IS_OUT_ACTIVE);
  76. mdelay(100);
  77. } else { /* Device */
  78. /* Disable hub */
  79. dm_gpio_set_dir_flags(&hub_reset, GPIOD_IS_OUT);
  80. /* Switch back to device connector */
  81. dm_gpio_set_dir_flags(&usb_sel, GPIOD_IS_OUT);
  82. }
  83. return 0;
  84. }
  85. int board_init(void)
  86. {
  87. return 0;
  88. }
  89. /* Check for vol- button - if pressed - stop autoboot */
  90. int misc_init_r(void)
  91. {
  92. struct udevice *pon;
  93. struct gpio_desc resin;
  94. int node, ret;
  95. ret = uclass_get_device_by_name(UCLASS_GPIO, "pm8916_pon@800", &pon);
  96. if (ret < 0) {
  97. printf("Failed to find PMIC pon node. Check device tree\n");
  98. return 0;
  99. }
  100. node = fdt_subnode_offset(gd->fdt_blob, dev_of_offset(pon),
  101. "key_vol_down");
  102. if (node < 0) {
  103. printf("Failed to find key_vol_down node. Check device tree\n");
  104. return 0;
  105. }
  106. if (gpio_request_by_name_nodev(gd->fdt_blob, node, "gpios", 0, &resin,
  107. 0)) {
  108. printf("Failed to request key_vol_down button.\n");
  109. return 0;
  110. }
  111. if (dm_gpio_get_value(&resin)) {
  112. setenv("bootdelay", "-1");
  113. printf("Power button pressed - dropping to console.\n");
  114. }
  115. return 0;
  116. }