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

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

?? linux_usbfs.c

?? 最新的libusb庫
?? C
?? 第 1 頁 / 共 4 頁
字號:
		usbi_err(TRANSFER_CTX(transfer),			"submiturb failed error %d errno=%d", r, errno);		return LIBUSB_ERROR_IO;	}	return 0;}static int op_submit_transfer(struct usbi_transfer *itransfer){	struct libusb_transfer *transfer =		__USBI_TRANSFER_TO_LIBUSB_TRANSFER(itransfer);	switch (transfer->type) {	case LIBUSB_TRANSFER_TYPE_CONTROL:		return submit_control_transfer(itransfer);	case LIBUSB_TRANSFER_TYPE_BULK:		return submit_bulk_transfer(itransfer, USBFS_URB_TYPE_BULK);	case LIBUSB_TRANSFER_TYPE_INTERRUPT:		return submit_bulk_transfer(itransfer, USBFS_URB_TYPE_INTERRUPT);	case LIBUSB_TRANSFER_TYPE_ISOCHRONOUS:		return submit_iso_transfer(itransfer);	default:		usbi_err(TRANSFER_CTX(transfer),			"unknown endpoint type %d", transfer->type);		return LIBUSB_ERROR_INVALID_PARAM;	}}static int cancel_control_transfer(struct usbi_transfer *itransfer){	struct linux_transfer_priv *tpriv = usbi_transfer_get_os_priv(itransfer);	struct libusb_transfer *transfer =		__USBI_TRANSFER_TO_LIBUSB_TRANSFER(itransfer);	struct linux_device_handle_priv *dpriv =		__device_handle_priv(transfer->dev_handle);	int r;	tpriv->reap_action = CANCELLED;	r = ioctl(dpriv->fd, IOCTL_USBFS_DISCARDURB, tpriv->urbs);	if(r) {		if (errno == EINVAL) {			usbi_dbg("URB not found --> assuming ready to be reaped");			return 0;		} else {			usbi_err(TRANSFER_CTX(transfer),				"unrecognised DISCARD code %d", errno);			return LIBUSB_ERROR_OTHER;		}	}	return 0;}static void cancel_bulk_transfer(struct usbi_transfer *itransfer){	struct linux_transfer_priv *tpriv = usbi_transfer_get_os_priv(itransfer);	struct libusb_transfer *transfer =		__USBI_TRANSFER_TO_LIBUSB_TRANSFER(itransfer);	struct linux_device_handle_priv *dpriv =		__device_handle_priv(transfer->dev_handle);	int i;	tpriv->reap_action = CANCELLED;	tpriv->awaiting_reap = 0;	tpriv->awaiting_discard = 0;	for (i = 0; i < tpriv->num_urbs; i++) {		int tmp = ioctl(dpriv->fd, IOCTL_USBFS_DISCARDURB, &tpriv->urbs[i]);		if (tmp == 0)			tpriv->awaiting_discard++;		else if (errno == EINVAL)			tpriv->awaiting_reap++;		else			usbi_warn(TRANSFER_CTX(transfer),				"unrecognised discard return %d", errno);	}}static void cancel_iso_transfer(struct usbi_transfer *itransfer){	struct linux_transfer_priv *tpriv = usbi_transfer_get_os_priv(itransfer);	struct libusb_transfer *transfer =		__USBI_TRANSFER_TO_LIBUSB_TRANSFER(itransfer);	struct linux_device_handle_priv *dpriv =		__device_handle_priv(transfer->dev_handle);	int i;	tpriv->reap_action = CANCELLED;	tpriv->awaiting_reap = 0;	tpriv->awaiting_discard = 0;	for (i = 0; i < tpriv->num_urbs; i++) {		int tmp = ioctl(dpriv->fd, IOCTL_USBFS_DISCARDURB, tpriv->iso_urbs[i]);		if (tmp == 0)			tpriv->awaiting_discard++;		else if (errno == EINVAL)			tpriv->awaiting_reap++;		else			usbi_warn(TRANSFER_CTX(transfer),				"unrecognised discard return %d", errno);	}}static int op_cancel_transfer(struct usbi_transfer *itransfer){	struct libusb_transfer *transfer =		__USBI_TRANSFER_TO_LIBUSB_TRANSFER(itransfer);	switch (transfer->type) {	case LIBUSB_TRANSFER_TYPE_CONTROL:		return cancel_control_transfer(itransfer);	case LIBUSB_TRANSFER_TYPE_BULK:	case LIBUSB_TRANSFER_TYPE_INTERRUPT:		cancel_bulk_transfer(itransfer);		return 0;	case LIBUSB_TRANSFER_TYPE_ISOCHRONOUS:		cancel_iso_transfer(itransfer);		return 0;	default:		usbi_err(TRANSFER_CTX(transfer),			"unknown endpoint type %d", transfer->type);		return LIBUSB_ERROR_INVALID_PARAM;	}}static void op_clear_transfer_priv(struct usbi_transfer *itransfer){	struct libusb_transfer *transfer =		__USBI_TRANSFER_TO_LIBUSB_TRANSFER(itransfer);	struct linux_transfer_priv *tpriv = usbi_transfer_get_os_priv(itransfer);	switch (transfer->type) {	case LIBUSB_TRANSFER_TYPE_CONTROL:	case LIBUSB_TRANSFER_TYPE_BULK:	case LIBUSB_TRANSFER_TYPE_INTERRUPT:		free(tpriv->urbs);		break;	case LIBUSB_TRANSFER_TYPE_ISOCHRONOUS:		free_iso_urbs(tpriv);		break;	default:		usbi_err(TRANSFER_CTX(transfer),			"unknown endpoint type %d", transfer->type);	}}static int handle_bulk_completion(struct usbi_transfer *itransfer,	struct usbfs_urb *urb){	struct linux_transfer_priv *tpriv = usbi_transfer_get_os_priv(itransfer);	int num_urbs = tpriv->num_urbs;	int urb_idx = urb - tpriv->urbs;	enum libusb_transfer_status status = LIBUSB_TRANSFER_COMPLETED;	usbi_dbg("handling completion status %d of bulk urb %d/%d", urb->status,		urb_idx + 1, num_urbs);	if (urb->status == 0 ||			(urb->status == -EOVERFLOW && urb->actual_length > 0))		itransfer->transferred += urb->actual_length;	if (tpriv->reap_action != NORMAL) {		/* cancelled, submit_fail, or completed early */		if (urb->status == -ENOENT) {			usbi_dbg("CANCEL: detected a cancelled URB");			if (tpriv->awaiting_discard == 0)				usbi_err(ITRANSFER_CTX(itransfer),					"CANCEL: cancelled URB but not awaiting discards?");			else				tpriv->awaiting_discard--;		} else if (urb->status == 0) {			usbi_dbg("CANCEL: detected a completed URB");			/* FIXME we could solve this extreme corner case with a memmove			 * or something */			if (tpriv->reap_action == COMPLETED_EARLY)				usbi_warn(ITRANSFER_CTX(itransfer), "SOME DATA LOST! "					"(completed early but remaining urb completed)");			if (tpriv->awaiting_reap == 0)				usbi_err(ITRANSFER_CTX(itransfer),					"CANCEL: completed URB not awaiting reap?");			else				tpriv->awaiting_reap--;		} else if (urb->status == -EPIPE || urb->status == -EOVERFLOW) {			if (tpriv->awaiting_reap == 0)				usbi_err(ITRANSFER_CTX(itransfer),					"CANCEL: completed URB not awaiting reap?");			else				tpriv->awaiting_reap--;		} else {			usbi_warn(ITRANSFER_CTX(itransfer),				"unhandled CANCEL urb status %d", urb->status);		}		if (tpriv->awaiting_reap == 0 && tpriv->awaiting_discard == 0) {			usbi_dbg("CANCEL: last URB handled, reporting");			if (tpriv->reap_action == CANCELLED) {				free(tpriv->urbs);				usbi_handle_transfer_cancellation(itransfer);				return 0;			} else if (tpriv->reap_action == COMPLETED_EARLY) {				goto out;			} else {				status = LIBUSB_TRANSFER_ERROR;				goto out;			}		}		return 0;	}	if (urb->status == -EPIPE) {		usbi_dbg("detected endpoint stall");		status = LIBUSB_TRANSFER_STALL;		goto out;	} else if (urb->status == -EOVERFLOW) {		/* overflow can only ever occur in the last urb */		usbi_dbg("overflow, actual_length=%d", urb->actual_length);		status = LIBUSB_TRANSFER_OVERFLOW;		goto out;	} else if (urb->status != 0) {		usbi_warn(ITRANSFER_CTX(itransfer),			"unrecognised urb status %d", urb->status);	}	/* if we're the last urb or we got less data than requested then we're	 * done */	if (urb_idx == num_urbs - 1) {		usbi_dbg("last URB in transfer --> complete!");	} else if (urb->actual_length < urb->buffer_length) {		struct libusb_transfer *transfer =			__USBI_TRANSFER_TO_LIBUSB_TRANSFER(itransfer);		struct linux_device_handle_priv *dpriv =			__device_handle_priv(transfer->dev_handle);		int i;		usbi_dbg("short transfer %d/%d --> complete!", urb->actual_length,			urb->buffer_length);		/* we have to cancel the remaining urbs and wait for their completion		 * before reporting results */		tpriv->reap_action = COMPLETED_EARLY;		for (i = urb_idx + 1; i < tpriv->num_urbs; i++) {			int r = ioctl(dpriv->fd, IOCTL_USBFS_DISCARDURB, &tpriv->urbs[i]);			if (r == 0)				tpriv->awaiting_discard++;			else if (errno == EINVAL)				tpriv->awaiting_reap++;			else				usbi_warn(ITRANSFER_CTX(itransfer),					"unrecognised discard return %d", errno);		}		return 0;	} else {		return 0;	}out:	free(tpriv->urbs);	usbi_handle_transfer_completion(itransfer, status);	return 0;}static int handle_iso_completion(struct usbi_transfer *itransfer,	struct usbfs_urb *urb){	struct libusb_transfer *transfer =		__USBI_TRANSFER_TO_LIBUSB_TRANSFER(itransfer);	struct linux_transfer_priv *tpriv = usbi_transfer_get_os_priv(itransfer);	int num_urbs = tpriv->num_urbs;	int urb_idx = 0;	int i;	for (i = 0; i < num_urbs; i++) {		if (urb == tpriv->iso_urbs[i]) {			urb_idx = i + 1;			break;		}	}	if (urb_idx == 0) {		usbi_err(TRANSFER_CTX(transfer), "could not locate urb!");		return LIBUSB_ERROR_NOT_FOUND;	}	usbi_dbg("handling completion status %d of iso urb %d/%d", urb->status,		urb_idx, num_urbs);	if (urb->status == 0) {		/* copy isochronous results back in */		for (i = 0; i < urb->number_of_packets; i++) {			struct usbfs_iso_packet_desc *urb_desc = &urb->iso_frame_desc[i];			struct libusb_iso_packet_descriptor *lib_desc =				&transfer->iso_packet_desc[tpriv->iso_packet_offset++];			lib_desc->status = urb_desc->status;			lib_desc->actual_length = urb_desc->actual_length;		}	}	if (tpriv->reap_action != NORMAL) { /* cancelled or submit_fail */		if (urb->status == -ENOENT) {			usbi_dbg("CANCEL: detected a cancelled URB");			if (tpriv->awaiting_discard == 0)				usbi_err(TRANSFER_CTX(transfer),					"CANCEL: cancelled URB but not awaiting discards?");			else				tpriv->awaiting_discard--;		} else if (urb->status == 0) {			usbi_dbg("CANCEL: detected a completed URB");			if (tpriv->awaiting_reap == 0)				usbi_err(TRANSFER_CTX(transfer),					"CANCEL: completed URB not awaiting reap?");			else				tpriv->awaiting_reap--;		} else {			usbi_warn(TRANSFER_CTX(transfer),				"unhandled CANCEL urb status %d", urb->status);		}		if (tpriv->awaiting_reap == 0 && tpriv->awaiting_discard == 0) {			usbi_dbg("CANCEL: last URB handled, reporting");			free_iso_urbs(tpriv);			if (tpriv->reap_action == CANCELLED)				usbi_handle_transfer_cancellation(itransfer);			else				usbi_handle_transfer_completion(itransfer,					LIBUSB_TRANSFER_ERROR);		}		return 0;	}	if (urb->status != 0)		usbi_warn(TRANSFER_CTX(transfer),			"unrecognised urb status %d", urb->status);	/* if we're the last urb or we got less data than requested then we're	 * done */	if (urb_idx == num_urbs) {		usbi_dbg("last URB in transfer --> complete!");		free_iso_urbs(tpriv);		usbi_handle_transfer_completion(itransfer, LIBUSB_TRANSFER_COMPLETED);	}	return 0;}static int handle_control_completion(struct usbi_transfer *itransfer,	struct usbfs_urb *urb){	struct linux_transfer_priv *tpriv = usbi_transfer_get_os_priv(itransfer);	int status;	usbi_dbg("handling completion status %d", urb->status);	if (urb->status == 0)		itransfer->transferred += urb->actual_length;	if (tpriv->reap_action == CANCELLED) {		if (urb->status != 0 && urb->status != -ENOENT)			usbi_warn(ITRANSFER_CTX(itransfer),				"cancel: unrecognised urb status %d", urb->status);		free(tpriv->urbs);		usbi_handle_transfer_cancellation(itransfer);		return 0;	}	if (urb->status == -EPIPE) {		usbi_dbg("unsupported control request");		status = LIBUSB_TRANSFER_STALL;		goto out;	} else if (urb->status != 0) {		usbi_warn(ITRANSFER_CTX(itransfer),			"unrecognised urb status %d", urb->status);		status = LIBUSB_TRANSFER_ERROR;		goto out;	}	itransfer->transferred = urb->actual_length;	status = LIBUSB_TRANSFER_COMPLETED;out:	free(tpriv->urbs);	usbi_handle_transfer_completion(itransfer, status);	return 0;}static int reap_for_handle(struct libusb_device_handle *handle){	struct linux_device_handle_priv *hpriv = __device_handle_priv(handle);	int r;	struct usbfs_urb *urb;	struct usbi_transfer *itransfer;	struct libusb_transfer *transfer;	r = ioctl(hpriv->fd, IOCTL_USBFS_REAPURBNDELAY, &urb);	if (r == -1 && errno == EAGAIN)		return 1;	if (r < 0) {		if (errno == ENODEV)			return LIBUSB_ERROR_NO_DEVICE;		usbi_err(HANDLE_CTX(handle), "reap failed error %d errno=%d",			r, errno);		return LIBUSB_ERROR_IO;	}	itransfer = urb->usercontext;	transfer = __USBI_TRANSFER_TO_LIBUSB_TRANSFER(itransfer);	usbi_dbg("urb type=%d status=%d transferred=%d", urb->type, urb->status,		urb->actual_length);	switch (transfer->type) {	case LIBUSB_TRANSFER_TYPE_ISOCHRONOUS:		return handle_iso_completion(itransfer, urb);	case LIBUSB_TRANSFER_TYPE_BULK:	case LIBUSB_TRANSFER_TYPE_INTERRUPT:		return handle_bulk_completion(itransfer, urb);	case LIBUSB_TRANSFER_TYPE_CONTROL:		return handle_control_completion(itransfer, urb);	default:		usbi_err(HANDLE_CTX(handle), "unrecognised endpoint type %x",			transfer->type);		return LIBUSB_ERROR_OTHER;	}}static int op_handle_events(struct libusb_context *ctx,	struct pollfd *fds, nfds_t nfds, int num_ready){	int r;	int i = 0;	pthread_mutex_lock(&ctx->open_devs_lock);	for (i = 0; i < nfds && num_ready > 0; i++) {		struct pollfd *pollfd = &fds[i];		struct libusb_device_handle *handle;		struct linux_device_handle_priv *hpriv = NULL;		if (!pollfd->revents)			continue;		num_ready--;		list_for_each_entry(handle, &ctx->open_devs, list) {			hpriv =  __device_handle_priv(handle);			if (hpriv->fd == pollfd->fd)				break;		}		if (pollfd->revents & POLLERR) {			usbi_remove_pollfd(HANDLE_CTX(handle), hpriv->fd);			usbi_handle_disconnect(handle);			continue;		}		r = reap_for_handle(handle);		if (r == 1 || r == LIBUSB_ERROR_NO_DEVICE)			continue;		else if (r < 0)			goto out;	}	r = 0;out:	pthread_mutex_unlock(&ctx->open_devs_lock);	return r;}const struct usbi_os_backend linux_usbfs_backend = {	.name = "Linux usbfs",	.init = op_init,	.exit = NULL,	.get_device_list = op_get_device_list,	.get_device_descriptor = op_get_device_descriptor,	.get_active_config_descriptor = op_get_active_config_descriptor,	.get_config_descriptor = op_get_config_descriptor,	.open = op_open,	.close = op_close,	.get_configuration = op_get_configuration,	.set_configuration = op_set_configuration,	.claim_interface = op_claim_interface,	.release_interface = op_release_interface,	.set_interface_altsetting = op_set_interface,	.clear_halt = op_clear_halt,	.reset_device = op_reset_device,	.kernel_driver_active = op_kernel_driver_active,	.detach_kernel_driver = op_detach_kernel_driver,	.destroy_device = op_destroy_device,	.submit_transfer = op_submit_transfer,	.cancel_transfer = op_cancel_transfer,	.clear_transfer_priv = op_clear_transfer_priv,	.handle_events = op_handle_events,	.device_priv_size = sizeof(struct linux_device_priv),	.device_handle_priv_size = sizeof(struct linux_device_handle_priv),	.transfer_priv_size = sizeof(struct linux_transfer_priv),	.add_iso_packet_size = 0,};

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧洲日产国码二区| 国产精品福利一区| 一本到一区二区三区| 日韩不卡一二三区| 亚洲精选一二三| 久久久久久一二三区| 欧美日韩中文国产| 99re成人精品视频| 国产高清不卡二三区| 美女视频黄频大全不卡视频在线播放| 国产精品不卡视频| 久久伊99综合婷婷久久伊| 欧美日韩亚洲综合在线 欧美亚洲特黄一级 | 日韩国产精品久久久久久亚洲| 中文字幕制服丝袜成人av| 精品sm捆绑视频| 欧美高清视频一二三区| 色94色欧美sute亚洲线路二| 国产乱人伦偷精品视频免下载| 日韩综合小视频| 一区二区三区日韩在线观看| 中文字幕一区在线观看| 国产人伦精品一区二区| xnxx国产精品| 精品美女被调教视频大全网站| 欧美日韩久久一区| 欧美婷婷六月丁香综合色| 播五月开心婷婷综合| 国产成人精品一区二| 国产精品一二一区| 国产精品99精品久久免费| 美腿丝袜在线亚洲一区| 日本免费新一区视频| 天堂久久一区二区三区| 午夜精品久久一牛影视| 亚洲va欧美va人人爽| 亚洲国产va精品久久久不卡综合| 亚洲精品中文字幕在线观看| 亚洲精品久久久蜜桃| 亚洲欧美福利一区二区| 亚洲免费伊人电影| 亚洲午夜久久久| 亚洲成a人在线观看| 日本伊人精品一区二区三区观看方式| 不卡在线视频中文字幕| 成人激情校园春色| 99久久亚洲一区二区三区青草| www.亚洲国产| 91久久精品一区二区二区| 欧美优质美女网站| 欧美久久高跟鞋激| 26uuu久久综合| |精品福利一区二区三区| 亚洲蜜桃精久久久久久久| 亚洲一区二区三区中文字幕在线| 亚洲国产精品久久艾草纯爱| 五月婷婷久久综合| 精品一区二区三区免费观看| 国产成人精品亚洲午夜麻豆| 91婷婷韩国欧美一区二区| 欧美专区日韩专区| 日韩欧美国产一区二区三区| 久久久久久久国产精品影院| 国产精品久久久久7777按摩| 一区二区日韩av| 免费观看一级特黄欧美大片| 国产成人综合自拍| 在线观看亚洲成人| 欧美成人性福生活免费看| 亚洲国产精品国自产拍av| 一区二区三区免费看视频| 日本色综合中文字幕| 国产成人免费xxxxxxxx| 欧美午夜精品久久久久久超碰| 日韩欧美一区二区视频| 中文字幕精品一区二区精品绿巨人| 亚洲精品免费一二三区| 奇米精品一区二区三区四区| 国产成人亚洲综合a∨猫咪| 欧美在线free| 国产日韩欧美精品一区| 亚洲国产欧美在线| 国产精选一区二区三区| 欧美主播一区二区三区| 久久亚区不卡日本| 亚洲午夜精品网| 国产一区二区福利视频| 欧美日韩日本视频| 中文字幕一区日韩精品欧美| 日韩 欧美一区二区三区| 99视频一区二区| 日韩精品中文字幕在线一区| 亚洲精品视频一区二区| 国产精品资源在线观看| 欧美精品乱码久久久久久| 中文字幕av一区二区三区免费看| 五月激情丁香一区二区三区| eeuss鲁片一区二区三区在线看| 欧美一区二区三区小说| 自拍av一区二区三区| 国产精品系列在线播放| 6080日韩午夜伦伦午夜伦| 自拍视频在线观看一区二区| 国产美女精品人人做人人爽| 欧美一区二区在线看| 亚洲激情自拍视频| 成年人网站91| 日本一区二区三级电影在线观看| 视频在线观看国产精品| 欧洲一区在线观看| 亚洲欧美怡红院| 国产高清精品在线| 久久综合色一综合色88| 美美哒免费高清在线观看视频一区二区 | 日韩成人一区二区三区在线观看| 91视频www| 亚洲婷婷综合久久一本伊一区| 国产一区二区调教| 欧美电视剧在线观看完整版| 日本系列欧美系列| 欧美日韩1234| 亚洲国产另类精品专区| 91久久一区二区| 亚洲精品欧美在线| 成人久久视频在线观看| 久久久久一区二区三区四区| 麻豆91在线播放免费| 日韩精品专区在线| 久久爱另类一区二区小说| 日韩欧美国产成人一区二区| 免费欧美在线视频| 91精品婷婷国产综合久久 | 国产suv精品一区二区三区| 日韩一级大片在线| 丝袜a∨在线一区二区三区不卡| 91豆麻精品91久久久久久| 日韩毛片视频在线看| caoporm超碰国产精品| 国产精品激情偷乱一区二区∴| 国产成人在线视频网站| 久久久不卡网国产精品一区| 国内精品伊人久久久久av影院| 91精品国产综合久久福利软件| 水野朝阳av一区二区三区| 91精品国产aⅴ一区二区| 国产在线精品一区二区三区不卡 | 欧美视频完全免费看| 日韩中文字幕亚洲一区二区va在线 | 国产在线观看免费一区| 国产亚洲污的网站| 成人手机电影网| 亚洲私人黄色宅男| 欧美婷婷六月丁香综合色| 天天操天天色综合| 欧美videofree性高清杂交| 国产美女久久久久| 亚洲天堂av一区| 欧美精品乱码久久久久久| 九九热在线视频观看这里只有精品| 精品久久国产97色综合| 国产1区2区3区精品美女| 亚洲另类一区二区| 欧美一区二区三区视频免费| 国产精品一区免费视频| 一区二区三区免费观看| 91麻豆精品国产91久久久| 国产精品一区二区免费不卡 | 国产精品小仙女| 亚洲精品视频免费看| 日韩精品中文字幕在线一区| 懂色av中文一区二区三区| 亚洲成av人片一区二区| 精品久久免费看| 91麻豆国产自产在线观看| 日韩国产高清在线| 国产精品视频九色porn| 欧美人xxxx| av成人老司机| 男女男精品视频网| 1区2区3区欧美| 日韩精品一区二区三区中文精品| 成人丝袜18视频在线观看| 日韩电影网1区2区| 自拍偷拍亚洲激情| 精品国产免费视频| 91黄色激情网站| 粉嫩av一区二区三区在线播放| 亚洲成av人**亚洲成av**| 中文字幕欧美国产| 337p亚洲精品色噜噜噜| jizz一区二区| 久久国内精品自在自线400部| 亚洲精品少妇30p| 日本一区二区综合亚洲| 欧美一级日韩一级| 91蝌蚪porny九色| 国产高清不卡一区| 久久av老司机精品网站导航| 亚洲午夜一二三区视频| 国产精品久久久久三级|