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

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

?? stub_rx.c

?? linux virtual usb host source
?? C
?? 第 1 頁 / 共 2 頁
字號:
	if (pdu->base.devid == sdev->devid) {		spin_lock(&ud->lock);		if (ud->status == SDEV_ST_USED) {			/* A request is valid. */			spin_unlock(&ud->lock);			return 1;		}		spin_unlock(&ud->lock);	}	return 0;}static struct stub_priv *stub_priv_alloc(struct stub_device *sdev,		struct usbip_header *pdu){	struct stub_priv *priv;	struct usbip_device *ud = &sdev->ud;	unsigned long flags;	spin_lock_irqsave(&sdev->priv_lock, flags);	priv = kmem_cache_alloc(stub_priv_cache, GFP_ATOMIC);	if (!priv) {		uerr("alloc stub_priv\n");		spin_unlock_irqrestore(&sdev->priv_lock, flags);		usbip_event_add(ud, SDEV_EVENT_ERROR_MALLOC);		return NULL;	}	memset(priv, 0, sizeof(struct stub_priv));	priv->seqnum = pdu->base.seqnum;	priv->sdev = sdev;	/*	 * After a stub_priv is linked to a list_head,	 * our error handler can free allocated data.	 */	list_add_tail(&priv->list, &sdev->priv_init);	spin_unlock_irqrestore(&sdev->priv_lock, flags);	return priv;}#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,21)static inline int usb_endpoint_xfer_bulk(		const struct usb_endpoint_descriptor *epd){	return ((epd->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK) ==			USB_ENDPOINT_XFER_BULK);}static inline int usb_endpoint_xfer_control(		const struct usb_endpoint_descriptor *epd){	return ((epd->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK) ==			USB_ENDPOINT_XFER_CONTROL);}static inline int usb_endpoint_xfer_int(		const struct usb_endpoint_descriptor *epd){	return ((epd->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK) ==			USB_ENDPOINT_XFER_INT);}static inline int usb_endpoint_xfer_isoc(		const struct usb_endpoint_descriptor *epd){	return ((epd->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK) ==			USB_ENDPOINT_XFER_ISOC);}#endifstatic struct usb_host_endpoint *get_ep_from_epnum(struct usb_device *udev,		int epnum0){	struct usb_host_config *config;	int i = 0, j = 0;	struct usb_host_endpoint *ep = NULL;	int epnum;	int found = 0;	if (epnum0 == 0)		return &udev->ep0;	config = udev->actconfig;	if (!config)		return NULL;	for (i = 0; i < config->desc.bNumInterfaces; i++) {		struct usb_host_interface *setting;		setting = config->interface[i]->cur_altsetting;		for (j = 0; j < setting->desc.bNumEndpoints; j++) {			ep = &setting->endpoint[j];			epnum = (ep->desc.bEndpointAddress & 0x7f);			if (epnum == epnum0) {				//uinfo("found epnum %d\n", epnum0);				found = 1;				break;			}		}	}	if (found)		return ep;	else		return NULL;}static int get_pipe(struct stub_device *sdev, int epnum, int dir){	struct usb_device *udev = interface_to_usbdev(sdev->interface);	struct usb_host_endpoint *ep;	struct usb_endpoint_descriptor *epd = NULL;	ep = get_ep_from_epnum(udev, epnum);	if (!ep) {		uerr("no such endpoint?, %d", epnum);		BUG();	}	epd = &ep->desc;#if 0	/* epnum 0 is always control */	if (epnum == 0) {		if (dir == USBIP_DIR_OUT)			return usb_sndctrlpipe(udev, 0);		else			return usb_rcvctrlpipe(udev, 0);	}#endif	if (usb_endpoint_xfer_control(epd)) {		if (dir == USBIP_DIR_OUT)			return usb_sndctrlpipe(udev, epnum);		else			return usb_rcvctrlpipe(udev, epnum);	}	if (usb_endpoint_xfer_bulk(epd)) {		if (dir == USBIP_DIR_OUT)			return usb_sndbulkpipe(udev, epnum);		else			return usb_rcvbulkpipe(udev, epnum);	}	if (usb_endpoint_xfer_int(epd)) {		if (dir == USBIP_DIR_OUT)			return usb_sndintpipe(udev, epnum);		else			return usb_rcvintpipe(udev, epnum);	}	if (usb_endpoint_xfer_isoc(epd)) {		if (dir == USBIP_DIR_OUT)			return usb_sndisocpipe(udev, epnum);		else			return usb_rcvisocpipe(udev, epnum);	}	/* NOT REACHED */	uerr("get pipe, epnum %d\n", epnum);	return 0;}static void stub_recv_cmd_submit(struct stub_device *sdev, struct usbip_header *pdu){	int ret;	struct stub_priv *priv;	struct usbip_device *ud = &sdev->ud;	struct usb_device *udev = interface_to_usbdev(sdev->interface);	int pipe = get_pipe(sdev, pdu->base.ep, pdu->base.direction);	priv = stub_priv_alloc(sdev, pdu);	if (!priv)		return;	/* setup a urb */	if (usb_pipeisoc(pipe))		priv->urb = usb_alloc_urb(pdu->u.cmd_submit.number_of_packets, GFP_KERNEL);	else		priv->urb = usb_alloc_urb(0, GFP_KERNEL);	if (!priv->urb) {		uerr("malloc urb\n");		usbip_event_add(ud, SDEV_EVENT_ERROR_MALLOC);		return;	}	/* set priv->urb->transfer_buffer */	if (pdu->u.cmd_submit.transfer_buffer_length > 0) {		priv->urb->transfer_buffer =			kzalloc(pdu->u.cmd_submit.transfer_buffer_length, GFP_KERNEL);		if (!priv->urb->transfer_buffer) {			uerr("malloc x_buff\n");			usbip_event_add(ud, SDEV_EVENT_ERROR_MALLOC);			return;		}	}	/* set priv->urb->setup_packet */	priv->urb->setup_packet = kzalloc(8, GFP_KERNEL);	if (!priv->urb->setup_packet) {		uerr("allocate setup_packet\n");		usbip_event_add(ud, SDEV_EVENT_ERROR_MALLOC);		return;	}	memcpy(priv->urb->setup_packet, &pdu->u.cmd_submit.setup, 8);	/* set other members from the base header of pdu */	priv->urb->context                = (void *) priv;	priv->urb->dev                    = udev;	priv->urb->pipe                   = pipe;	priv->urb->complete               = stub_complete;	usbip_pack_pdu(pdu, priv->urb, USBIP_CMD_SUBMIT, 0);	if (usbip_recv_xbuff(ud, priv->urb) < 0)		return;	if (usbip_recv_iso(ud, priv->urb) < 0)		return;	/* no need to submit an intercepted request, but harmless? */	tweak_special_requests(priv->urb);	/* urb is now ready to submit */	ret = usb_submit_urb(priv->urb, GFP_KERNEL);	if (ret == 0)		dbg_stub_rx("submit urb ok, seqnum %u\n", pdu->base.seqnum);	else {		uerr("submit_urb error, %d\n", ret);		usbip_dump_header(pdu);		usbip_dump_urb(priv->urb);		/*		 * Pessimistic.		 * This connection will be discarded.		 */		usbip_event_add(ud, SDEV_EVENT_ERROR_SUBMIT);	}	dbg_stub_rx("Leave\n");	return;}/* recv a pdu */static void stub_rx_pdu(struct usbip_device *ud){	int ret;	struct usbip_header pdu;	struct stub_device *sdev = container_of(ud, struct stub_device, ud);	dbg_stub_rx("Enter\n");	memset(&pdu, 0, sizeof(pdu));	/* 1. receive a pdu header */	ret = usbip_xmit(0, ud->tcp_socket, (char *) &pdu, sizeof(pdu),0);	if (ret != sizeof(pdu)) {		uerr("recv a header, %d\n", ret);		usbip_event_add(ud, SDEV_EVENT_ERROR_TCP);		return;	}	usbip_header_correct_endian(&pdu, 0);	if (dbg_flag_stub_rx)		usbip_dump_header(&pdu);	if (!valid_request(sdev, &pdu)) {		uerr("recv invalid request\n");		usbip_event_add(ud, SDEV_EVENT_ERROR_TCP);		return;	}	switch (pdu.base.command) {		case USBIP_CMD_UNLINK:			stub_recv_cmd_unlink(sdev, &pdu);			break;		case USBIP_CMD_SUBMIT:			stub_recv_cmd_submit(sdev, &pdu);			break;		default:			/* NOTREACHED */			uerr("unknown pdu\n");			usbip_event_add(ud, SDEV_EVENT_ERROR_TCP);			return;	}}void stub_rx_loop(struct usbip_task *ut){	struct usbip_device *ud = container_of(ut, struct usbip_device, tcp_rx);	while (1) {		if (signal_pending(current)) {			dbg_stub_rx("signal caught!\n");			break;		}		if (usbip_event_happend(ud))			break;		stub_rx_pdu(ud);	}}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品乱人伦小说| 欧美午夜免费电影| 亚洲综合色视频| 国产日本一区二区| 欧美一级片在线| 91一区二区在线观看| 久久99久久久久| 国产日本亚洲高清| 一区二区成人在线| 国产精品系列在线| 精品sm捆绑视频| 久久综合色综合88| 久久免费偷拍视频| 精品女同一区二区| 亚洲午夜激情网站| 亚洲在线观看免费| 国产高清不卡一区二区| 欧美视频精品在线观看| 日韩精品一区二区三区老鸭窝| 国产精品资源在线看| 欧美国产精品一区二区三区| 国产寡妇亲子伦一区二区| 国产一区在线视频| 久久久精品综合| 国产精品久久久久一区| 在线中文字幕不卡| 成人黄色在线看| 国产一区二区影院| 欧美日韩小视频| 日韩一区二区三区精品视频| 欧美一卡二卡在线观看| 亚洲精品视频免费观看| 中文字幕日韩一区| 综合婷婷亚洲小说| 伊人性伊人情综合网| 国产成人免费xxxxxxxx| 日韩精品一区二区在线观看| 亚洲伦理在线免费看| 高清不卡一区二区| 在线观看91精品国产入口| 欧美区在线观看| 久久久久99精品一区| 国产一区二区三区黄视频| 日韩一区二区三区电影| 石原莉奈一区二区三区在线观看 | 日韩美女精品在线| 国产a久久麻豆| 精品福利二区三区| 美腿丝袜亚洲色图| 免费成人在线播放| 蜜臀久久99精品久久久画质超高清| 欧美图片一区二区三区| 亚洲午夜三级在线| 69堂精品视频| 国产亚洲一区二区三区在线观看| 久久一留热品黄| 成人avav影音| 亚洲一区二区成人在线观看| 欧美日韩性生活| 精品在线一区二区三区| 国产亚洲一区二区三区| 99久久精品国产毛片| 欧美女孩性生活视频| 午夜精品久久久久久久99樱桃| 99re热这里只有精品免费视频| 亚洲一二三专区| 国产日韩欧美在线一区| 欧美在线影院一区二区| 蜜桃视频一区二区三区| 欧美国产一区在线| 91成人免费在线视频| 久久黄色级2电影| 国产精品天干天干在线综合| 欧美性大战xxxxx久久久| 精品一区二区三区视频| 中文字幕亚洲在| 久久综合久久综合久久| 欧美中文字幕不卡| 国产成人精品免费网站| 日本在线播放一区二区三区| 91国内精品野花午夜精品| 国产一区亚洲一区| 天天爽夜夜爽夜夜爽精品视频| 亚洲欧洲一区二区在线播放| 欧美电影免费观看高清完整版| 欧美在线观看一区| 99视频精品全部免费在线| 自拍偷在线精品自拍偷无码专区| 亚洲精品一区二区在线观看| 欧美日本不卡视频| 色婷婷综合久久| 日韩不卡一区二区三区| 亚洲综合色区另类av| 一区二区三区在线视频观看58 | 欧美日韩一本到| 在线影视一区二区三区| 不卡av在线免费观看| 国产乱子伦一区二区三区国色天香| 日韩和欧美一区二区| 亚洲地区一二三色| 欧美不卡一区二区三区四区| 制服视频三区第一页精品| 欧美剧在线免费观看网站| 日韩二区三区四区| 亚洲成精国产精品女| 亚洲一区二区欧美日韩| 成人欧美一区二区三区小说 | 欧美精品日日鲁夜夜添| 欧美综合一区二区| 精品视频在线视频| 欧美性受xxxx黑人xyx性爽| 91国产免费看| 欧美欧美欧美欧美| 日韩免费看的电影| 亚洲精品在线免费播放| 国产偷国产偷亚洲高清人白洁 | 久草在线在线精品观看| 成人午夜视频在线| 琪琪久久久久日韩精品| 精品一区二区在线免费观看| gogo大胆日本视频一区| 欧美午夜一区二区三区 | 精品一区二区三区在线观看国产| 国产高清不卡一区二区| 欧美亚洲综合一区| 精品国产一区二区三区不卡| 亚洲欧洲成人自拍| 美国十次了思思久久精品导航| 成人美女视频在线观看18| 制服丝袜亚洲色图| 中文字幕在线不卡一区| 老司机精品视频导航| 色网站国产精品| 中文字幕av在线一区二区三区| 秋霞av亚洲一区二区三| 色综合夜色一区| 日本韩国一区二区| 国产欧美精品一区aⅴ影院| 日本午夜一本久久久综合| 99久久精品国产麻豆演员表| 精品精品国产高清a毛片牛牛| 亚洲第一激情av| 色婷婷一区二区| 国产精品女同一区二区三区| 九色porny丨国产精品| 91精品综合久久久久久| 夜夜亚洲天天久久| 91丨porny丨国产入口| 亚洲人成网站精品片在线观看| 国产精品女人毛片| fc2成人免费人成在线观看播放| 日韩一区和二区| 狠狠久久亚洲欧美| 国产不卡视频一区| 国产精品美女久久久久久久久久久| 国产乱妇无码大片在线观看| 亚洲一区二区三区视频在线播放| 色国产精品一区在线观看| 亚洲乱码精品一二三四区日韩在线 | 国产xxx精品视频大全| 久久免费视频一区| 国产酒店精品激情| 久久天堂av综合合色蜜桃网| 狠狠网亚洲精品| 久久久久久麻豆| 黄色成人免费在线| 欧美激情一区二区三区在线| 国产一区二区毛片| 2020国产精品自拍| 久久精品国产亚洲a| 日韩美女视频在线| 国产米奇在线777精品观看| 久久亚洲二区三区| 99riav久久精品riav| 国产精品美女www爽爽爽| 国产美女视频91| 亚洲欧洲制服丝袜| 在线影院国内精品| 奇米777欧美一区二区| 26uuu另类欧美亚洲曰本| 丰满放荡岳乱妇91ww| 亚洲精品一二三四区| 在线播放国产精品二区一二区四区 | 国产高清久久久久| 亚洲一二三区不卡| 欧美变态tickle挠乳网站| 成人国产精品免费网站| 三级久久三级久久久| 欧美国产亚洲另类动漫| 欧美日韩在线免费视频| 国产精品1区二区.| 午夜视频一区二区三区| 国产午夜精品美女毛片视频| 欧美日韩在线一区二区| 国产.精品.日韩.另类.中文.在线.播放| 亚洲精品免费在线观看| 亚洲国产精品av| 国产午夜精品理论片a级大结局| 制服丝袜中文字幕一区| 91久久香蕉国产日韩欧美9色|