blob: cdc2e0b75d811e0d01db56cfe00f07dca2b0bc05 [file] [log] [blame]
// SPDX-License-Identifier: GPL-2.0+
/*
* Copyright (C) 2015, Google, Inc
*/
#include <dm.h>
#include <init.h>
#include <log.h>
#include <asm/gpio.h>
#include <dm/device-internal.h>
#include <dm/uclass-internal.h>
#define GPIO_BANKE_NAME "gpioe"
int misc_init_r(void)
{
struct udevice *dev;
struct gpio_desc desc;
int ret;
/*
* Turn on USB VBUS for the two USB ports on the board.
* Each port's VBUS is controlled by a GPIO pin.
*/
ret = uclass_find_device_by_name(UCLASS_GPIO, GPIO_BANKE_NAME, &dev);
if (ret) {
debug("%s: GPIO %s device cannot be not found (ret=%d)\n",
__func__, GPIO_BANKE_NAME, ret);
return ret;
}
ret = device_probe(dev);
if (ret) {
debug("%s: GPIO %s device probe failed (ret=%d)\n",
__func__, GPIO_BANKE_NAME, ret);
return ret;
}
desc.dev = dev;
desc.flags = GPIOD_IS_OUT;
/* GPIO E8 controls the bottom port */
desc.offset = 8;
ret = dm_gpio_request(&desc, "usb_host_en0");
if (ret)
return ret;
dm_gpio_set_value(&desc, 1);
/* GPIO E9 controls the upper port */
desc.offset = 9;
ret = dm_gpio_request(&desc, "usb_host_en1");
if (ret)
return ret;
dm_gpio_set_value(&desc, 1);
return 0;
}