All dwc3 based xhci host controller supports USB3.0 LPM functionality. Therefore enable it in platform data for all dwc3 based xhci device if DWC3_HOST_USB3_LPM_ENABLE is selected in Kconfig. Signed-off-by: Pratyush Anand <pratyush.anand@st.com> Signed-off-by: Mathias Nyman <mathias.nyman@linux.intel.com> Signed-of-by: Felipe Balbi <balbi@ti.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
		
			
				
	
	
		
			81 lines
		
	
	
	
		
			1.9 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			81 lines
		
	
	
	
		
			1.9 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
/**
 | 
						|
 * host.c - DesignWare USB3 DRD Controller Host Glue
 | 
						|
 *
 | 
						|
 * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com
 | 
						|
 *
 | 
						|
 * Authors: Felipe Balbi <balbi@ti.com>,
 | 
						|
 *
 | 
						|
 * This program is free software: you can redistribute it and/or modify
 | 
						|
 * it under the terms of the GNU General Public License version 2  of
 | 
						|
 * the License as published by the Free Software Foundation.
 | 
						|
 *
 | 
						|
 * This program is distributed in the hope that it will be useful,
 | 
						|
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
						|
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
						|
 * GNU General Public License for more details.
 | 
						|
 */
 | 
						|
 | 
						|
#include <linux/platform_device.h>
 | 
						|
#include <linux/usb/xhci_pdriver.h>
 | 
						|
 | 
						|
#include "core.h"
 | 
						|
 | 
						|
int dwc3_host_init(struct dwc3 *dwc)
 | 
						|
{
 | 
						|
	struct platform_device	*xhci;
 | 
						|
	struct usb_xhci_pdata	pdata;
 | 
						|
	int			ret;
 | 
						|
 | 
						|
	xhci = platform_device_alloc("xhci-hcd", PLATFORM_DEVID_AUTO);
 | 
						|
	if (!xhci) {
 | 
						|
		dev_err(dwc->dev, "couldn't allocate xHCI device\n");
 | 
						|
		ret = -ENOMEM;
 | 
						|
		goto err0;
 | 
						|
	}
 | 
						|
 | 
						|
	dma_set_coherent_mask(&xhci->dev, dwc->dev->coherent_dma_mask);
 | 
						|
 | 
						|
	xhci->dev.parent	= dwc->dev;
 | 
						|
	xhci->dev.dma_mask	= dwc->dev->dma_mask;
 | 
						|
	xhci->dev.dma_parms	= dwc->dev->dma_parms;
 | 
						|
 | 
						|
	dwc->xhci = xhci;
 | 
						|
 | 
						|
	ret = platform_device_add_resources(xhci, dwc->xhci_resources,
 | 
						|
						DWC3_XHCI_RESOURCES_NUM);
 | 
						|
	if (ret) {
 | 
						|
		dev_err(dwc->dev, "couldn't add resources to xHCI device\n");
 | 
						|
		goto err1;
 | 
						|
	}
 | 
						|
 | 
						|
	memset(&pdata, 0, sizeof(pdata));
 | 
						|
 | 
						|
#ifdef CONFIG_DWC3_HOST_USB3_LPM_ENABLE
 | 
						|
	pdata.usb3_lpm_capable = 1;
 | 
						|
#endif
 | 
						|
 | 
						|
	ret = platform_device_add_data(xhci, &pdata, sizeof(pdata));
 | 
						|
	if (ret) {
 | 
						|
		dev_err(dwc->dev, "couldn't add platform data to xHCI device\n");
 | 
						|
		goto err1;
 | 
						|
	}
 | 
						|
 | 
						|
	ret = platform_device_add(xhci);
 | 
						|
	if (ret) {
 | 
						|
		dev_err(dwc->dev, "failed to register xHCI device\n");
 | 
						|
		goto err1;
 | 
						|
	}
 | 
						|
 | 
						|
	return 0;
 | 
						|
 | 
						|
err1:
 | 
						|
	platform_device_put(xhci);
 | 
						|
 | 
						|
err0:
 | 
						|
	return ret;
 | 
						|
}
 | 
						|
 | 
						|
void dwc3_host_exit(struct dwc3 *dwc)
 | 
						|
{
 | 
						|
	platform_device_unregister(dwc->xhci);
 | 
						|
}
 |