亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ehci-fsl.c

?? host usb 主設備程序 支持sd卡 mouse keyboard 的最單單的驅動程序 gcc編譯
?? C
字號:
/* * (C) Copyright David Brownell 2000-2002 * Copyright (c) 2005 MontaVista Software * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the * Free Software Foundation; either version 2 of the License, or (at your * option) any later version. * * 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. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software Foundation, * Inc., 675 Mass Ave, Cambridge, MA 02139, USA. * * Ported to 834x by Randy Vinson <rvinson@mvista.com> using code provided * by Hunter Wu. */#include <linux/platform_device.h>#include <linux/fsl_devices.h>#include "ehci-fsl.h"/* FIXME: Power Managment is un-ported so temporarily disable it */#undef CONFIG_PM/* PCI-based HCs are common, but plenty of non-PCI HCs are used too *//* configure so an HC device and id are always provided *//* always called with process context; sleeping is OK *//** * usb_hcd_fsl_probe - initialize FSL-based HCDs * @drvier: Driver to be used for this HCD * @pdev: USB Host Controller being probed * Context: !in_interrupt() * * Allocates basic resources for this USB host controller. * */int usb_hcd_fsl_probe(const struct hc_driver *driver,		      struct platform_device *pdev){	struct fsl_usb2_platform_data *pdata;	struct usb_hcd *hcd;	struct resource *res;	int irq;	int retval;	unsigned int temp;	pr_debug("initializing FSL-SOC USB Controller\n");	/* Need platform data for setup */	pdata = (struct fsl_usb2_platform_data *)pdev->dev.platform_data;	if (!pdata) {		dev_err(&pdev->dev,			"No platform data for %s.\n", pdev->dev.bus_id);		return -ENODEV;	}	/*	 * This is a host mode driver, verify that we're supposed to be	 * in host mode.	 */	if (!((pdata->operating_mode == FSL_USB2_DR_HOST) ||	      (pdata->operating_mode == FSL_USB2_MPH_HOST))) {		dev_err(&pdev->dev,			"Non Host Mode configured for %s. Wrong driver linked.\n",			pdev->dev.bus_id);		return -ENODEV;	}	res = platform_get_resource(pdev, IORESOURCE_IRQ, 0);	if (!res) {		dev_err(&pdev->dev,			"Found HC with no IRQ. Check %s setup!\n",			pdev->dev.bus_id);		return -ENODEV;	}	irq = res->start;	hcd = usb_create_hcd(driver, &pdev->dev, pdev->dev.bus_id);	if (!hcd) {		retval = -ENOMEM;		goto err1;	}	res = platform_get_resource(pdev, IORESOURCE_MEM, 0);	if (!res) {		dev_err(&pdev->dev,			"Found HC with no register addr. Check %s setup!\n",			pdev->dev.bus_id);		retval = -ENODEV;		goto err2;	}	hcd->rsrc_start = res->start;	hcd->rsrc_len = res->end - res->start + 1;	if (!request_mem_region(hcd->rsrc_start, hcd->rsrc_len,				driver->description)) {		dev_dbg(&pdev->dev, "controller already in use\n");		retval = -EBUSY;		goto err2;	}	hcd->regs = ioremap(hcd->rsrc_start, hcd->rsrc_len);	if (hcd->regs == NULL) {		dev_dbg(&pdev->dev, "error mapping memory\n");		retval = -EFAULT;		goto err3;	}	/* Enable USB controller */	temp = in_be32(hcd->regs + 0x500);	out_be32(hcd->regs + 0x500, temp | 0x4);	/* Set to Host mode */	temp = in_le32(hcd->regs + 0x1a8);	out_le32(hcd->regs + 0x1a8, temp | 0x3);	retval = usb_add_hcd(hcd, irq, IRQF_SHARED);	if (retval != 0)		goto err4;	return retval;      err4:	iounmap(hcd->regs);      err3:	release_mem_region(hcd->rsrc_start, hcd->rsrc_len);      err2:	usb_put_hcd(hcd);      err1:	dev_err(&pdev->dev, "init %s fail, %d\n", pdev->dev.bus_id, retval);	return retval;}/* may be called without controller electrically present *//* may be called with controller, bus, and devices active *//** * usb_hcd_fsl_remove - shutdown processing for FSL-based HCDs * @dev: USB Host Controller being removed * Context: !in_interrupt() * * Reverses the effect of usb_hcd_fsl_probe(). * */void usb_hcd_fsl_remove(struct usb_hcd *hcd, struct platform_device *pdev){	usb_remove_hcd(hcd);	iounmap(hcd->regs);	release_mem_region(hcd->rsrc_start, hcd->rsrc_len);	usb_put_hcd(hcd);}static void mpc83xx_setup_phy(struct ehci_hcd *ehci,			      enum fsl_usb2_phy_modes phy_mode,			      unsigned int port_offset){	u32 portsc = 0;	switch (phy_mode) {	case FSL_USB2_PHY_ULPI:		portsc |= PORT_PTS_ULPI;		break;	case FSL_USB2_PHY_SERIAL:		portsc |= PORT_PTS_SERIAL;		break;	case FSL_USB2_PHY_UTMI_WIDE:		portsc |= PORT_PTS_PTW;		/* fall through */	case FSL_USB2_PHY_UTMI:		portsc |= PORT_PTS_UTMI;		break;	case FSL_USB2_PHY_NONE:		break;	}	ehci_writel(ehci, portsc, &ehci->regs->port_status[port_offset]);}static void mpc83xx_usb_setup(struct usb_hcd *hcd){	struct ehci_hcd *ehci = hcd_to_ehci(hcd);	struct fsl_usb2_platform_data *pdata;	void __iomem *non_ehci = hcd->regs;	pdata =	    (struct fsl_usb2_platform_data *)hcd->self.controller->	    platform_data;	/* Enable PHY interface in the control reg. */	out_be32(non_ehci + FSL_SOC_USB_CTRL, 0x00000004);	out_be32(non_ehci + FSL_SOC_USB_SNOOP1, 0x0000001b);	if (pdata->operating_mode == FSL_USB2_DR_HOST)		mpc83xx_setup_phy(ehci, pdata->phy_mode, 0);	if (pdata->operating_mode == FSL_USB2_MPH_HOST) {		unsigned int chip, rev, svr;		svr = mfspr(SPRN_SVR);		chip = svr >> 16;		rev = (svr >> 4) & 0xf;		/* Deal with USB Erratum #14 on MPC834x Rev 1.0 & 1.1 chips */		if ((rev == 1) && (chip >= 0x8050) && (chip <= 0x8055))			ehci->has_fsl_port_bug = 1;		if (pdata->port_enables & FSL_USB2_PORT0_ENABLED)			mpc83xx_setup_phy(ehci, pdata->phy_mode, 0);		if (pdata->port_enables & FSL_USB2_PORT1_ENABLED)			mpc83xx_setup_phy(ehci, pdata->phy_mode, 1);	}	/* put controller in host mode. */	ehci_writel(ehci, 0x00000003, non_ehci + FSL_SOC_USB_USBMODE);	out_be32(non_ehci + FSL_SOC_USB_PRICTRL, 0x0000000c);	out_be32(non_ehci + FSL_SOC_USB_AGECNTTHRSH, 0x00000040);	out_be32(non_ehci + FSL_SOC_USB_SICTRL, 0x00000001);}/* called after powerup, by probe or system-pm "wakeup" */static int ehci_fsl_reinit(struct ehci_hcd *ehci){	mpc83xx_usb_setup(ehci_to_hcd(ehci));	ehci_port_power(ehci, 0);	return 0;}/* called during probe() after chip reset completes */static int ehci_fsl_setup(struct usb_hcd *hcd){	struct ehci_hcd *ehci = hcd_to_ehci(hcd);	int retval;	/* EHCI registers start at offset 0x100 */	ehci->caps = hcd->regs + 0x100;	ehci->regs = hcd->regs + 0x100 +	    HC_LENGTH(ehci_readl(ehci, &ehci->caps->hc_capbase));	dbg_hcs_params(ehci, "reset");	dbg_hcc_params(ehci, "reset");	/* cache this readonly data; minimize chip reads */	ehci->hcs_params = ehci_readl(ehci, &ehci->caps->hcs_params);	retval = ehci_halt(ehci);	if (retval)		return retval;	/* data structure init */	retval = ehci_init(hcd);	if (retval)		return retval;	ehci->is_tdi_rh_tt = 1;	ehci->sbrn = 0x20;	ehci_reset(ehci);	retval = ehci_fsl_reinit(ehci);	return retval;}static const struct hc_driver ehci_fsl_hc_driver = {	.description = hcd_name,	.product_desc = "Freescale On-Chip EHCI Host Controller",	.hcd_priv_size = sizeof(struct ehci_hcd),	/*	 * generic hardware linkage	 */	.irq = ehci_irq,	.flags = HCD_USB2,	/*	 * basic lifecycle operations	 */	.reset = ehci_fsl_setup,	.start = ehci_run,#ifdef	CONFIG_PM	.suspend = ehci_bus_suspend,	.resume = ehci_bus_resume,#endif	.stop = ehci_stop,	.shutdown = ehci_shutdown,	/*	 * managing i/o requests and associated device resources	 */	.urb_enqueue = ehci_urb_enqueue,	.urb_dequeue = ehci_urb_dequeue,	.endpoint_disable = ehci_endpoint_disable,	/*	 * scheduling support	 */	.get_frame_number = ehci_get_frame,	/*	 * root hub support	 */	.hub_status_data = ehci_hub_status_data,	.hub_control = ehci_hub_control,	.bus_suspend = ehci_bus_suspend,	.bus_resume = ehci_bus_resume,};static int ehci_fsl_drv_probe(struct platform_device *pdev){	if (usb_disabled())		return -ENODEV;	return usb_hcd_fsl_probe(&ehci_fsl_hc_driver, pdev);}static int ehci_fsl_drv_remove(struct platform_device *pdev){	struct usb_hcd *hcd = platform_get_drvdata(pdev);	usb_hcd_fsl_remove(hcd, pdev);	return 0;}MODULE_ALIAS("fsl-ehci");static struct platform_driver ehci_fsl_driver = {	.probe = ehci_fsl_drv_probe,	.remove = ehci_fsl_drv_remove,	.shutdown = usb_hcd_platform_shutdown,	.driver = {		   .name = "fsl-ehci",		   },};

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
韩国v欧美v日本v亚洲v| 亚洲成人在线观看视频| 欧美另类z0zxhd电影| 99re8在线精品视频免费播放| 国产一区二区毛片| 国产精品1024| 成人av影院在线| eeuss鲁片一区二区三区 | 欧美一区二区视频在线观看2020| 欧美主播一区二区三区| 在线观看日韩国产| 欧美人牲a欧美精品| 国产成人免费在线视频| 91色乱码一区二区三区| 一本一道久久a久久精品| 欧美三级在线播放| 欧美午夜视频网站| 欧美xxxx老人做受| 国产精品污www在线观看| 中文字幕中文字幕一区二区| 综合色中文字幕| 亚洲国产视频一区二区| 久久国产精品第一页| 欧美三片在线视频观看| 91精品一区二区三区久久久久久| 欧美一区二区视频在线观看| 久久九九99视频| 日韩一区在线免费观看| 石原莉奈在线亚洲二区| 国产一区二区福利视频| 99久久精品99国产精品| 91精品国产91久久久久久最新毛片| 欧美不卡激情三级在线观看| 中文字幕一区二区三区四区不卡| 天天免费综合色| 国产一区二区三区电影在线观看 | 欧美撒尿777hd撒尿| 日韩精品一区二区三区在线 | 九九久久精品视频| 国产高清久久久久| 欧美丝袜第三区| 欧美国产一区在线| 亚洲一区二区免费视频| 国产乱码字幕精品高清av| 91蜜桃免费观看视频| 日韩欧美国产高清| 国产精品传媒入口麻豆| 裸体在线国模精品偷拍| 91视频.com| 久久久久亚洲蜜桃| 五月天亚洲婷婷| 99久久精品国产麻豆演员表| 久久综合色天天久久综合图片| 一区二区三区av电影 | 欧美在线免费视屏| 国产日韩av一区二区| 日韩av中文在线观看| 一本大道久久精品懂色aⅴ| 337p日本欧洲亚洲大胆色噜噜| 亚洲综合在线观看视频| 成人av影院在线| 国产色婷婷亚洲99精品小说| 日韩黄色小视频| 91国内精品野花午夜精品| 中文字幕一区二区三区四区不卡 | 日本一区二区三区高清不卡| 美女在线一区二区| 91精品久久久久久蜜臀| 亚洲第一精品在线| 欧美在线不卡视频| 亚洲免费在线看| 91免费视频大全| 日韩一区日韩二区| 97久久精品人人澡人人爽| 中文字幕一区二区三区不卡在线| 国产成人精品午夜视频免费| 国产视频在线观看一区二区三区| 国产又黄又大久久| 久久久久久久久久美女| 国产福利一区在线| 国产欧美日韩精品在线| 成人免费毛片片v| 国产精品三级久久久久三级| 不卡免费追剧大全电视剧网站| 欧美国产激情一区二区三区蜜月| 国产91在线观看| 国产精品久久久久影院老司| 91免费视频大全| 亚洲一区二区三区激情| 在线成人av影院| 激情av综合网| 久久久精品免费观看| av影院午夜一区| 一区av在线播放| 日韩欧美中文一区二区| 久久国产欧美日韩精品| 国产精品你懂的在线欣赏| 色综合色综合色综合色综合色综合 | 不卡一区二区中文字幕| 亚洲欧美另类小说| 欧美日韩aaaaaa| 国产精品中文有码| 亚洲乱码国产乱码精品精可以看 | 一本到不卡免费一区二区| 亚洲成人黄色影院| 久久久亚洲综合| 99国产精品久久久久久久久久| 丝袜亚洲另类欧美综合| 中文一区在线播放| 精品福利视频一区二区三区| 宅男在线国产精品| 天天综合色天天综合| 一区二区不卡在线视频 午夜欧美不卡在| 国产日韩欧美激情| 国产成人精品在线看| 午夜欧美电影在线观看| 色综合天天在线| 久久婷婷国产综合精品青草| 精品亚洲国产成人av制服丝袜| 日日摸夜夜添夜夜添国产精品| 亚洲欧美日韩一区二区三区在线观看 | 欧美成人vr18sexvr| 国产精品二三区| 亚洲国产日韩综合久久精品| 精品一区二区免费在线观看| jiyouzz国产精品久久| 亚洲黄色片在线观看| 久久99国产精品免费网站| 欧美刺激脚交jootjob| 欧洲av在线精品| 成人高清免费观看| 欧美日本在线播放| 欧美蜜桃一区二区三区| 日韩二区在线观看| 一区二区三区四区中文字幕| 日韩免费看的电影| 欧美精品aⅴ在线视频| 欧美tk丨vk视频| 国产一区二区三区黄视频 | 国产夫妻精品视频| 亚洲欧美一区二区三区孕妇| 亚洲va在线va天堂| 欧美日韩亚洲丝袜制服| 欧美一级专区免费大片| 欧美tickling挠脚心丨vk| 久久女同性恋中文字幕| 成人免费看的视频| 亚洲成人自拍偷拍| 精品国产99国产精品| 国产精品一二三| 欧美亚洲自拍偷拍| 91精品国产欧美一区二区成人| 在线电影院国产精品| 欧美一区二区国产| 成人久久视频在线观看| 亚洲高清久久久| 26uuu欧美| 亚洲天堂成人在线观看| 欧美高清一级片在线| 国产永久精品大片wwwapp| 亚洲精品久久久蜜桃| 在线不卡免费av| 亚洲同性同志一二三专区| 青青青伊人色综合久久| 国产精品拍天天在线| 国产精品动漫网站| 精品免费视频.| 色呦呦日韩精品| 极品瑜伽女神91| 欧美亚男人的天堂| 久久免费美女视频| 日韩成人精品在线| 日本一区二区三区四区在线视频 | 国产欧美日韩中文久久| 色婷婷狠狠综合| 成人综合婷婷国产精品久久蜜臀| 国产精品影视网| 99久久精品国产一区二区三区| 欧美午夜影院一区| 精品毛片乱码1区2区3区| 国产日韩欧美综合在线| 亚洲综合自拍偷拍| 久久成人羞羞网站| 97精品视频在线观看自产线路二| 欧美精品一二三区| 久久久综合激的五月天| 亚洲美腿欧美偷拍| 免费一级片91| 91免费版在线| 日韩欧美国产系列| 亚洲男人的天堂一区二区| 青青草国产成人av片免费| 波波电影院一区二区三区| 欧美精品粉嫩高潮一区二区| 国产欧美精品一区二区三区四区 | 国产三级精品三级在线专区| 亚洲欧美日韩国产综合在线| 精品一区二区影视| 欧美日韩中文另类| 国产欧美一区二区精品仙草咪|