mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-11-04 05:50:17 +00:00 
			
		
		
		
	These support the flat device tree. We want to use the dev_read_..() prefix for functions that support both flat tree and live tree. So rename the existing functions to avoid confusion. In the end we will have: 1. dev_read_addr...() - works on devices, supports flat/live tree 2. devfdt_get_addr...() - current functions, flat tree only 3. of_get_address() etc. - new functions, live tree only All drivers will be written to use 1. That function will in turn call either 2 or 3 depending on whether the flat or live tree is in use. Note this involves changing some dead code - the imx_lpi2c.c file. Signed-off-by: Simon Glass <sjg@chromium.org>
		
			
				
	
	
		
			93 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			93 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 * (C) Copyright 2014, Xilinx, Inc
 | 
						|
 *
 | 
						|
 * USB Low level initialization(Specific to zynq)
 | 
						|
 *
 | 
						|
 * SPDX-License-Identifier:	GPL-2.0+
 | 
						|
 */
 | 
						|
 | 
						|
#include <common.h>
 | 
						|
#include <dm.h>
 | 
						|
#include <usb.h>
 | 
						|
#include <asm/arch/hardware.h>
 | 
						|
#include <asm/arch/sys_proto.h>
 | 
						|
#include <asm/io.h>
 | 
						|
#include <usb/ehci-ci.h>
 | 
						|
#include <usb/ulpi.h>
 | 
						|
 | 
						|
#include "ehci.h"
 | 
						|
 | 
						|
struct zynq_ehci_priv {
 | 
						|
	struct ehci_ctrl ehcictrl;
 | 
						|
	struct usb_ehci *ehci;
 | 
						|
};
 | 
						|
 | 
						|
static int ehci_zynq_ofdata_to_platdata(struct udevice *dev)
 | 
						|
{
 | 
						|
	struct zynq_ehci_priv *priv = dev_get_priv(dev);
 | 
						|
 | 
						|
	priv->ehci = (struct usb_ehci *)devfdt_get_addr_ptr(dev);
 | 
						|
	if (!priv->ehci)
 | 
						|
		return -EINVAL;
 | 
						|
 | 
						|
	return 0;
 | 
						|
}
 | 
						|
 | 
						|
static int ehci_zynq_probe(struct udevice *dev)
 | 
						|
{
 | 
						|
	struct usb_platdata *plat = dev_get_platdata(dev);
 | 
						|
	struct zynq_ehci_priv *priv = dev_get_priv(dev);
 | 
						|
	struct ehci_hccr *hccr;
 | 
						|
	struct ehci_hcor *hcor;
 | 
						|
	struct ulpi_viewport ulpi_vp;
 | 
						|
	/* Used for writing the ULPI data address */
 | 
						|
	struct ulpi_regs *ulpi = (struct ulpi_regs *)0;
 | 
						|
	int ret;
 | 
						|
 | 
						|
	hccr = (struct ehci_hccr *)((uint32_t)&priv->ehci->caplength);
 | 
						|
	hcor = (struct ehci_hcor *)((uint32_t) hccr +
 | 
						|
			HC_LENGTH(ehci_readl(&hccr->cr_capbase)));
 | 
						|
 | 
						|
	ulpi_vp.viewport_addr = (u32)&priv->ehci->ulpi_viewpoint;
 | 
						|
	ulpi_vp.port_num = 0;
 | 
						|
 | 
						|
	ret = ulpi_init(&ulpi_vp);
 | 
						|
	if (ret) {
 | 
						|
		puts("zynq ULPI viewport init failed\n");
 | 
						|
		return -1;
 | 
						|
	}
 | 
						|
 | 
						|
	/* ULPI set flags */
 | 
						|
	ulpi_write(&ulpi_vp, &ulpi->otg_ctrl,
 | 
						|
		   ULPI_OTG_DP_PULLDOWN | ULPI_OTG_DM_PULLDOWN |
 | 
						|
		   ULPI_OTG_EXTVBUSIND);
 | 
						|
	ulpi_write(&ulpi_vp, &ulpi->function_ctrl,
 | 
						|
		   ULPI_FC_FULL_SPEED | ULPI_FC_OPMODE_NORMAL |
 | 
						|
		   ULPI_FC_SUSPENDM);
 | 
						|
	ulpi_write(&ulpi_vp, &ulpi->iface_ctrl, 0);
 | 
						|
 | 
						|
	/* Set VBus */
 | 
						|
	ulpi_write(&ulpi_vp, &ulpi->otg_ctrl_set,
 | 
						|
		   ULPI_OTG_DRVVBUS | ULPI_OTG_DRVVBUS_EXT);
 | 
						|
 | 
						|
	return ehci_register(dev, hccr, hcor, NULL, 0, plat->init_type);
 | 
						|
}
 | 
						|
 | 
						|
static const struct udevice_id ehci_zynq_ids[] = {
 | 
						|
	{ .compatible = "xlnx,zynq-usb-2.20a" },
 | 
						|
	{ }
 | 
						|
};
 | 
						|
 | 
						|
U_BOOT_DRIVER(ehci_zynq) = {
 | 
						|
	.name	= "ehci_zynq",
 | 
						|
	.id	= UCLASS_USB,
 | 
						|
	.of_match = ehci_zynq_ids,
 | 
						|
	.ofdata_to_platdata = ehci_zynq_ofdata_to_platdata,
 | 
						|
	.probe = ehci_zynq_probe,
 | 
						|
	.remove = ehci_deregister,
 | 
						|
	.ops	= &ehci_usb_ops,
 | 
						|
	.platdata_auto_alloc_size = sizeof(struct usb_platdata),
 | 
						|
	.priv_auto_alloc_size = sizeof(struct zynq_ehci_priv),
 | 
						|
	.flags	= DM_FLAG_ALLOC_PRIV_DMA,
 | 
						|
};
 |