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

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

?? ehci-dbg.c

?? host usb 主設備程序 支持sd卡 mouse keyboard 的最單單的驅動程序 gcc編譯
?? C
?? 第 1 頁 / 共 2 頁
字號:
		}		temp = snprintf (next, size,				"\n\t%p%c%s len=%d %08x urb %p",				td, mark, ({ char *tmp;				 switch ((scratch>>8)&0x03) {				 case 0: tmp = "out"; break;				 case 1: tmp = "in"; break;				 case 2: tmp = "setup"; break;				 default: tmp = "?"; break;				 } tmp;}),				(scratch >> 16) & 0x7fff,				scratch,				td->urb);		if (temp < 0)			temp = 0;		else if (size < temp)			temp = size;		size -= temp;		next += temp;		if (temp == size)			goto done;	}	temp = snprintf (next, size, "\n");	if (temp < 0)		temp = 0;	else if (size < temp)		temp = size;	size -= temp;	next += temp;done:	*sizep = size;	*nextp = next;}static ssize_tshow_async (struct class_device *class_dev, char *buf){	struct usb_bus		*bus;	struct usb_hcd		*hcd;	struct ehci_hcd		*ehci;	unsigned long		flags;	unsigned		temp, size;	char			*next;	struct ehci_qh		*qh;	*buf = 0;	bus = class_get_devdata(class_dev);	hcd = bus_to_hcd(bus);	ehci = hcd_to_ehci (hcd);	next = buf;	size = PAGE_SIZE;	/* dumps a snapshot of the async schedule.	 * usually empty except for long-term bulk reads, or head.	 * one QH per line, and TDs we know about	 */	spin_lock_irqsave (&ehci->lock, flags);	for (qh = ehci->async->qh_next.qh; size > 0 && qh; qh = qh->qh_next.qh)		qh_lines (ehci, qh, &next, &size);	if (ehci->reclaim && size > 0) {		temp = scnprintf (next, size, "\nreclaim =\n");		size -= temp;		next += temp;		for (qh = ehci->reclaim; size > 0 && qh; qh = qh->reclaim)			qh_lines (ehci, qh, &next, &size);	}	spin_unlock_irqrestore (&ehci->lock, flags);	return strlen (buf);}static CLASS_DEVICE_ATTR (async, S_IRUGO, show_async, NULL);#define DBG_SCHED_LIMIT 64static ssize_tshow_periodic (struct class_device *class_dev, char *buf){	struct usb_bus		*bus;	struct usb_hcd		*hcd;	struct ehci_hcd		*ehci;	unsigned long		flags;	union ehci_shadow	p, *seen;	unsigned		temp, size, seen_count;	char			*next;	unsigned		i;	__le32			tag;	if (!(seen = kmalloc (DBG_SCHED_LIMIT * sizeof *seen, GFP_ATOMIC)))		return 0;	seen_count = 0;	bus = class_get_devdata(class_dev);	hcd = bus_to_hcd(bus);	ehci = hcd_to_ehci (hcd);	next = buf;	size = PAGE_SIZE;	temp = scnprintf (next, size, "size = %d\n", ehci->periodic_size);	size -= temp;	next += temp;	/* dump a snapshot of the periodic schedule.	 * iso changes, interrupt usually doesn't.	 */	spin_lock_irqsave (&ehci->lock, flags);	for (i = 0; i < ehci->periodic_size; i++) {		p = ehci->pshadow [i];		if (likely (!p.ptr))			continue;		tag = Q_NEXT_TYPE (ehci->periodic [i]);		temp = scnprintf (next, size, "%4d: ", i);		size -= temp;		next += temp;		do {			switch (tag) {			case Q_TYPE_QH:				temp = scnprintf (next, size, " qh%d-%04x/%p",						p.qh->period,						le32_to_cpup (&p.qh->hw_info2)							/* uframe masks */							& (QH_CMASK | QH_SMASK),						p.qh);				size -= temp;				next += temp;				/* don't repeat what follows this qh */				for (temp = 0; temp < seen_count; temp++) {					if (seen [temp].ptr != p.ptr)						continue;					if (p.qh->qh_next.ptr)						temp = scnprintf (next, size,							" ...");					p.ptr = NULL;					break;				}				/* show more info the first time around */				if (temp == seen_count && p.ptr) {					u32	scratch = le32_to_cpup (							&p.qh->hw_info1);					struct ehci_qtd	*qtd;					char		*type = "";					/* count tds, get ep direction */					temp = 0;					list_for_each_entry (qtd,							&p.qh->qtd_list,							qtd_list) {						temp++;						switch (0x03 & (le32_to_cpu (							qtd->hw_token) >> 8)) {						case 0: type = "out"; continue;						case 1: type = "in"; continue;						}					}					temp = scnprintf (next, size,						" (%c%d ep%d%s "						"[%d/%d] q%d p%d)",						speed_char (scratch),						scratch & 0x007f,						(scratch >> 8) & 0x000f, type,						p.qh->usecs, p.qh->c_usecs,						temp,						0x7ff & (scratch >> 16));					if (seen_count < DBG_SCHED_LIMIT)						seen [seen_count++].qh = p.qh;				} else					temp = 0;				if (p.qh) {					tag = Q_NEXT_TYPE (p.qh->hw_next);					p = p.qh->qh_next;				}				break;			case Q_TYPE_FSTN:				temp = scnprintf (next, size,					" fstn-%8x/%p", p.fstn->hw_prev,					p.fstn);				tag = Q_NEXT_TYPE (p.fstn->hw_next);				p = p.fstn->fstn_next;				break;			case Q_TYPE_ITD:				temp = scnprintf (next, size,					" itd/%p", p.itd);				tag = Q_NEXT_TYPE (p.itd->hw_next);				p = p.itd->itd_next;				break;			case Q_TYPE_SITD:				temp = scnprintf (next, size,					" sitd%d-%04x/%p",					p.sitd->stream->interval,					le32_to_cpup (&p.sitd->hw_uframe)						& 0x0000ffff,					p.sitd);				tag = Q_NEXT_TYPE (p.sitd->hw_next);				p = p.sitd->sitd_next;				break;			}			size -= temp;			next += temp;		} while (p.ptr);		temp = scnprintf (next, size, "\n");		size -= temp;		next += temp;	}	spin_unlock_irqrestore (&ehci->lock, flags);	kfree (seen);	return PAGE_SIZE - size;}static CLASS_DEVICE_ATTR (periodic, S_IRUGO, show_periodic, NULL);#undef DBG_SCHED_LIMITstatic ssize_tshow_registers (struct class_device *class_dev, char *buf){	struct usb_bus		*bus;	struct usb_hcd		*hcd;	struct ehci_hcd		*ehci;	unsigned long		flags;	unsigned		temp, size, i;	char			*next, scratch [80];	static char		fmt [] = "%*s\n";	static char		label [] = "";	bus = class_get_devdata(class_dev);	hcd = bus_to_hcd(bus);	ehci = hcd_to_ehci (hcd);	next = buf;	size = PAGE_SIZE;	spin_lock_irqsave (&ehci->lock, flags);	if (bus->controller->power.power_state.event) {		size = scnprintf (next, size,			"bus %s, device %s (driver " DRIVER_VERSION ")\n"			"%s\n"			"SUSPENDED (no register access)\n",			hcd->self.controller->bus->name,			hcd->self.controller->bus_id,			hcd->product_desc);		goto done;	}	/* Capability Registers */	i = HC_VERSION(ehci_readl(ehci, &ehci->caps->hc_capbase));	temp = scnprintf (next, size,		"bus %s, device %s (driver " DRIVER_VERSION ")\n"		"%s\n"		"EHCI %x.%02x, hcd state %d\n",		hcd->self.controller->bus->name,		hcd->self.controller->bus_id,		hcd->product_desc,		i >> 8, i & 0x0ff, hcd->state);	size -= temp;	next += temp;#ifdef	CONFIG_PCI	/* EHCI 0.96 and later may have "extended capabilities" */	if (hcd->self.controller->bus == &pci_bus_type) {		struct pci_dev	*pdev;		u32		offset, cap, cap2;		unsigned	count = 256/4;		pdev = to_pci_dev(ehci_to_hcd(ehci)->self.controller);		offset = HCC_EXT_CAPS (ehci_readl(ehci, &ehci->caps->hcc_params));		while (offset && count--) {			pci_read_config_dword (pdev, offset, &cap);			switch (cap & 0xff) {			case 1:				temp = scnprintf (next, size,					"ownership %08x%s%s\n", cap,					(cap & (1 << 24)) ? " linux" : "",					(cap & (1 << 16)) ? " firmware" : "");				size -= temp;				next += temp;				offset += 4;				pci_read_config_dword (pdev, offset, &cap2);				temp = scnprintf (next, size,					"SMI sts/enable 0x%08x\n", cap2);				size -= temp;				next += temp;				break;			case 0:		/* illegal reserved capability */				cap = 0;				/* FALLTHROUGH */			default:		/* unknown */				break;			}			temp = (cap >> 8) & 0xff;		}	}#endif	// FIXME interpret both types of params	i = ehci_readl(ehci, &ehci->caps->hcs_params);	temp = scnprintf (next, size, "structural params 0x%08x\n", i);	size -= temp;	next += temp;	i = ehci_readl(ehci, &ehci->caps->hcc_params);	temp = scnprintf (next, size, "capability params 0x%08x\n", i);	size -= temp;	next += temp;	/* Operational Registers */	temp = dbg_status_buf (scratch, sizeof scratch, label,			ehci_readl(ehci, &ehci->regs->status));	temp = scnprintf (next, size, fmt, temp, scratch);	size -= temp;	next += temp;	temp = dbg_command_buf (scratch, sizeof scratch, label,			ehci_readl(ehci, &ehci->regs->command));	temp = scnprintf (next, size, fmt, temp, scratch);	size -= temp;	next += temp;	temp = dbg_intr_buf (scratch, sizeof scratch, label,			ehci_readl(ehci, &ehci->regs->intr_enable));	temp = scnprintf (next, size, fmt, temp, scratch);	size -= temp;	next += temp;	temp = scnprintf (next, size, "uframe %04x\n",			ehci_readl(ehci, &ehci->regs->frame_index));	size -= temp;	next += temp;	for (i = 1; i <= HCS_N_PORTS (ehci->hcs_params); i++) {		temp = dbg_port_buf (scratch, sizeof scratch, label, i,				ehci_readl(ehci, &ehci->regs->port_status [i - 1]));		temp = scnprintf (next, size, fmt, temp, scratch);		size -= temp;		next += temp;		if (i == HCS_DEBUG_PORT(ehci->hcs_params) && ehci->debug) {			temp = scnprintf (next, size,					"    debug control %08x\n",					ehci_readl(ehci, &ehci->debug->control));			size -= temp;			next += temp;		}	}	if (ehci->reclaim) {		temp = scnprintf (next, size, "reclaim qh %p%s\n",				ehci->reclaim,				ehci->reclaim_ready ? " ready" : "");		size -= temp;		next += temp;	}#ifdef EHCI_STATS	temp = scnprintf (next, size,		"irq normal %ld err %ld reclaim %ld (lost %ld)\n",		ehci->stats.normal, ehci->stats.error, ehci->stats.reclaim,		ehci->stats.lost_iaa);	size -= temp;	next += temp;	temp = scnprintf (next, size, "complete %ld unlink %ld\n",		ehci->stats.complete, ehci->stats.unlink);	size -= temp;	next += temp;#endifdone:	spin_unlock_irqrestore (&ehci->lock, flags);	return PAGE_SIZE - size;}static CLASS_DEVICE_ATTR (registers, S_IRUGO, show_registers, NULL);static inline void create_debug_files (struct ehci_hcd *ehci){	struct class_device *cldev = ehci_to_hcd(ehci)->self.class_dev;	int retval;	retval = class_device_create_file(cldev, &class_device_attr_async);	retval = class_device_create_file(cldev, &class_device_attr_periodic);	retval = class_device_create_file(cldev, &class_device_attr_registers);}static inline void remove_debug_files (struct ehci_hcd *ehci){	struct class_device *cldev = ehci_to_hcd(ehci)->self.class_dev;	class_device_remove_file(cldev, &class_device_attr_async);	class_device_remove_file(cldev, &class_device_attr_periodic);	class_device_remove_file(cldev, &class_device_attr_registers);}#endif /* STUB_DEBUG_FILES */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线播放91灌醉迷j高跟美女| 亚洲天堂成人网| 国产午夜亚洲精品羞羞网站| 一区二区三区免费在线观看| 国内精品伊人久久久久av一坑| 色综合天天综合狠狠| 久久久久国产精品人| 亚洲午夜精品在线| 99视频有精品| 国产网红主播福利一区二区| 日韩电影网1区2区| 欧美综合在线视频| 中文字幕亚洲视频| 国产精品夜夜爽| 91.com在线观看| 亚洲一区二区美女| 91天堂素人约啪| 日韩理论电影院| 成人性生交大片免费看在线播放| 精品日韩欧美在线| 日本vs亚洲vs韩国一区三区| 欧美午夜电影一区| 亚洲区小说区图片区qvod| 成人毛片视频在线观看| 久久精品亚洲乱码伦伦中文| 乱一区二区av| 精品欧美乱码久久久久久| 日韩高清一区二区| 欧美日韩卡一卡二| 亚洲韩国精品一区| 在线观看亚洲精品视频| 一区二区三区资源| 欧美在线|欧美| 午夜精品免费在线| 在线成人免费观看| 日本aⅴ精品一区二区三区 | 精品美女一区二区三区| 亚洲成人免费观看| 欧美日韩三级在线| 日本在线不卡一区| 精品少妇一区二区三区日产乱码 | 中文字幕视频一区| 91免费视频网址| 夜夜揉揉日日人人青青一国产精品 | 亚洲成av人片在线观看| 制服.丝袜.亚洲.另类.中文| 日韩国产一区二| 日韩色在线观看| 国产剧情av麻豆香蕉精品| 国产三级三级三级精品8ⅰ区| 国产精品亚洲一区二区三区妖精 | 欧美一三区三区四区免费在线看| 免费日韩伦理电影| 欧美韩国一区二区| 91福利小视频| 奇米色777欧美一区二区| 欧美大白屁股肥臀xxxxxx| 久久se精品一区二区| 国产精品毛片高清在线完整版| 99re亚洲国产精品| 日韩精品一二三四| 亚洲国产精品精华液2区45| 91在线你懂得| 青青草原综合久久大伊人精品| 精品成人在线观看| 在线观看视频一区二区欧美日韩| 美女视频黄免费的久久 | 久久久国际精品| 99re热这里只有精品免费视频| 亚洲bdsm女犯bdsm网站| 久久久电影一区二区三区| 色一情一乱一乱一91av| 另类欧美日韩国产在线| 亚洲视频资源在线| 精品免费一区二区三区| 色哟哟日韩精品| 激情五月婷婷综合网| 一区二区三区四区中文字幕| 欧美电视剧免费观看| 一本久久a久久精品亚洲| 久久成人久久爱| 亚洲精品午夜久久久| 久久久久久久久蜜桃| 欧美日韩国产系列| 92国产精品观看| 国产真实乱子伦精品视频| 亚洲成人免费视| 亚洲色图都市小说| 国产色综合一区| 欧美videossexotv100| 日本大香伊一区二区三区| 国产成人精品免费看| 日本特黄久久久高潮 | 欧美韩国日本综合| 精品国偷自产国产一区| 欧美日韩成人综合| 91精品福利在线| 91女厕偷拍女厕偷拍高清| 国产iv一区二区三区| 久久精品国产色蜜蜜麻豆| 日本中文字幕不卡| 日韩电影免费在线看| 亚洲国产色一区| 夜夜精品视频一区二区| 国产精品美女久久久久高潮 | 欧美一区二区日韩一区二区| 91久久线看在观草草青青| 国产91精品精华液一区二区三区| 激情欧美一区二区三区在线观看| 青娱乐精品在线视频| 午夜激情综合网| 午夜精品在线看| 亚洲成精国产精品女| 亚洲综合一区二区| 亚洲一区二区三区四区在线免费观看| 亚洲欧美一区二区在线观看| 日韩理论电影院| 亚洲图片另类小说| 一区二区三区在线视频观看58| 亚洲欧美日韩在线| 亚洲影院理伦片| 亚洲成a人v欧美综合天堂下载| 亚洲第一激情av| 亚洲成va人在线观看| 免费看黄色91| 国内精品国产三级国产a久久| 韩国v欧美v日本v亚洲v| 国产99久久久精品| 成人av网站在线观看| 91免费看片在线观看| 精品视频1区2区| 日韩一区二区三区四区| 精品va天堂亚洲国产| 亚洲国产精品传媒在线观看| 亚洲天堂成人在线观看| 午夜亚洲福利老司机| 久久精品国产一区二区| 国产91对白在线观看九色| 色婷婷亚洲综合| 欧美一级黄色大片| 中文字幕av一区二区三区高| 依依成人综合视频| 免费看日韩a级影片| 成人黄色av网站在线| 欧美三级欧美一级| 久久久三级国产网站| 亚洲品质自拍视频网站| 蜜乳av一区二区| 北岛玲一区二区三区四区| 欧美视频中文一区二区三区在线观看| 欧美精品一二三区| 久久九九国产精品| 亚洲小说春色综合另类电影| 国内精品写真在线观看| 91成人网在线| 久久久精品日韩欧美| 亚洲大片免费看| 国产91丝袜在线18| 欧美日韩一区成人| 国产亚洲视频系列| 日韩va亚洲va欧美va久久| 成人免费毛片app| 欧美一区永久视频免费观看| 综合欧美亚洲日本| 国内精品伊人久久久久av影院| 在线精品视频免费播放| 国产亚洲精品免费| 美女爽到高潮91| 色婷婷综合久久久中文字幕| 精品三级av在线| 三级一区在线视频先锋| 91美女视频网站| 国产三级久久久| 韩国av一区二区三区| 欧美精品丝袜中出| 伊人一区二区三区| www.亚洲在线| 久久五月婷婷丁香社区| 日韩vs国产vs欧美| 在线观看视频91| 亚洲欧美另类小说| 不卡欧美aaaaa| 欧美极品aⅴ影院| 国产在线看一区| 日韩美女视频在线| 日本美女视频一区二区| 欧美日韩精品福利| 夜夜精品视频一区二区| 99久久婷婷国产综合精品 | 日韩一区精品视频| 欧美午夜影院一区| 一区二区三区免费在线观看| 91麻豆蜜桃一区二区三区| 国产精品久久久久久久岛一牛影视 | 99re8在线精品视频免费播放| 欧美国产视频在线| 成人激情小说网站| 中文av字幕一区| 99久久婷婷国产综合精品| 中文字幕制服丝袜成人av|