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

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

?? tests.v

?? USB 1.1的verilog代碼
?? V
字號:
/////////////////////////////////////////////////////////////////////////                                                             ////////  Test Case Collection                                       ////////                                                             ////////                                                             ////////  Author: Rudolf Usselmann                                   ////////          rudi@asics.ws                                      ////////                                                             ////////                                                             ////////  Downloaded from: http://www.opencores.org/cores/usb1_funct/////////                                                             /////////////////////////////////////////////////////////////////////////////                                                             //////// Copyright (C) 2000-2002 Rudolf Usselmann                    ////////                         www.asics.ws                        ////////                         rudi@asics.ws                       ////////                                                             //////// This source file may be used and distributed without        //////// restriction provided that this copyright statement is not   //////// removed from the file and that any derivative work contains //////// the original copyright notice and the associated disclaimer.////////                                                             ////////     THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY     //////// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED   //////// TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS   //////// FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL THE AUTHOR      //////// OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,         //////// INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES    //////// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE   //////// GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR        //////// BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF  //////// LIABILITY, WHETHER IN  CONTRACT, STRICT LIABILITY, OR TORT  //////// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT  //////// OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE         //////// POSSIBILITY OF SUCH DAMAGE.                                 ////////                                                             ///////////////////////////////////////////////////////////////////////////  CVS Log////  $Id: tests.v,v 1.1 2002/09/25 06:10:10 rudi Exp $////  $Date: 2002/09/25 06:10:10 $//  $Revision: 1.1 $//  $Author: rudi $//  $Locker:  $//  $State: Exp $//// Change History://               $Log: tests.v,v $//               Revision 1.1  2002/09/25 06:10:10  rudi//               Added Test Bench//////////////task send_setup;input	[7:0]	fa;input	[7:0]	req_type;input	[7:0]	request;input	[15:0]	wValue;input	[15:0]	wIndex;input	[15:0]	wLength;integer		len;beginbuffer1[0] = req_type;buffer1[1] = request;buffer1[3] = wValue[15:8];buffer1[2] = wValue[7:0];buffer1[5] = wIndex[15:8];buffer1[4] = wIndex[7:0];buffer1[7] = wLength[15:8];buffer1[6] = wLength[7:0];buffer1_last = 0;send_token(	fa,			// Function Address		0,			// Logical Endpoint Number		`USBF_T_PID_SETUP	// PID		);repeat(1)	@(posedge clk);send_data(`USBF_T_PID_DATA0, 8, 1);// Wait for ACKutmi_recv_pack(len);if(8'hd2 !== txmem[0])   begin	$display("ERROR: SETUP: ACK mismatch. Expected: %h, Got: %h (%t)",	8'hd2, txmem[0], $time);	error_cnt = error_cnt + 1;   endif(len !== 1)   begin	$display("ERROR: SETUP: Length mismatch. Expected: %h, Got: %h (%t)",	8'h1, len, $time);	error_cnt = error_cnt + 1;   endrepeat(1)	@(posedge clk);setup_pid = 1;repeat(1)	@(posedge clk);endendtasktask data_in;input	[7:0]	fa;input	[7:0]	pl_size;integer		rlen;reg	[3:0]	pid, expect_pid;begin	buffer1_last = 0;	repeat(5)	@(posedge clk);	send_token(	fa,		// Function Address			0,		// Logical Endpoint Number			`USBF_T_PID_IN	// PID			);	recv_packet(pid,rlen);	if(setup_pid)	expect_pid = 4'hb; // DATA 1	else		expect_pid = 4'h3; // DATA 0	if(pid !== expect_pid)	   begin		$display("ERROR: Data IN PID mismatch. Expected: %h, Got: %h (%t)",			expect_pid, pid, $time);		error_cnt = error_cnt + 1;	   end	setup_pid = ~setup_pid;	if(rlen != pl_size)	   begin		$display("ERROR: Data IN Size mismatch. Expected: %d, Got: %d (%t)",			pl_size, rlen, $time);		error_cnt = error_cnt + 1;	   end	for(n=0;n<rlen;n=n+1)		$display("RCV Data[%0d]: %h",n,buffer1[n]);	repeat(5)	@(posedge clk);	send_token(	fa,		// Function Address			0,		// Logical Endpoint Number			`USBF_T_PID_ACK	// PID			);	repeat(5)	@(posedge clk);endendtasktask data_out;input	[7:0]	fa;input	[7:0]	pl_size;integer len;begin	send_token(	fa,		// Function Address			0,		// Logical Endpoint Number			`USBF_T_PID_OUT	// PID			);	repeat(1)	@(posedge clk);	if(setup_pid==0)	send_data(`USBF_T_PID_DATA0, pl_size, 1);	else			send_data(`USBF_T_PID_DATA1, pl_size, 1);	setup_pid = ~setup_pid;	// Wait for ACK	utmi_recv_pack(len);	if(8'hd2 !== txmem[0])	   begin		$display("ERROR: ACK mismatch. Expected: %h, Got: %h (%t)",		8'hd2, txmem[0], $time);		error_cnt = error_cnt + 1;	   end	if(len !== 1)	   begin		$display("ERROR: SETUP: Length mismatch. Expected: %h, Got: %h (%t)",		8'h1, len, $time);		error_cnt = error_cnt + 1;	   end	repeat(5)	@(posedge clk);endendtaskparameter	GET_STATUS	=	8'h0,		CLEAR_FEATURE	=	8'h1,		SET_FEATURE	=	8'h3,		SET_ADDRESS	=	8'h5,		GET_DESCRIPTOR	=	8'h6,		SET_DESCRIPTOR	=	8'h7,		GET_CONFIG	=	8'h8,		SET_CONFIG	=	8'h9,		GET_INTERFACE	=	8'ha,		SET_INTERFACE	=	8'hb,		SYNCH_FRAME	=	8'hc;task setup1;begin$display("\n\n");$display("*****************************************************");$display("*** CTRL ep test 1                                ***");$display("*****************************************************\n");$display("\n\nSetting Address ...");send_setup(	8'h0, 		// Function Address		8'h00,		// Request Type		SET_ADDRESS,	// Request		16'h012,	// wValue		16'h0,		// wIndex		16'h0		// wLength		);// Status OKdata_in(	8'h0,		// Function Address		8'h0		// Expected payload size	);$display("\n\nGetting descriptor ...");send_setup(	8'h12, 		// Function Address		8'h80,		// Request Type		GET_DESCRIPTOR,	// Request		16'h0100,	// wValue		16'h0,		// wIndex		16'h8		// wLength		);data_in(	8'h12,		// Function Address		8'd08		// Expected payload size	);// Status OKdata_out(	8'h12,		// Function Address		8'h0		// Expected payload size	);$display("\n\nGetting descriptor ...");send_setup(	8'h12, 		// Function Address		8'h80,		// Request Type		GET_DESCRIPTOR,	// Request		16'h0200,	// wValue		16'h0,		// wIndex		16'h8		// wLength		);data_in(	8'h12,		// Function Address		8'd08		// Expected payload size	);// Status OKdata_out(	8'h12,		// Function Address		8'h0		// Expected payload size	);$display("\n\nGetting descriptor ...");send_setup(	8'h12, 		// Function Address		8'h80,		// Request Type		GET_DESCRIPTOR,	// Request		16'h0200,	// wValue		16'h0,		// wIndex		16'd053		// wLength		);data_in(	8'h12,		// Function Address		8'd053		// Expected payload size	);// Status OKdata_out(	8'h12,		// Function Address		8'h0		// Expected payload size	);$display("\n\nGetting descriptor ...");send_setup(	8'h12, 		// Function Address		8'h80,		// Request Type		GET_DESCRIPTOR,	// Request		16'h0300,	// wValue		16'h0,		// wIndex		16'd04		// wLength		);data_in(	8'h12,		// Function Address		8'd04		// Expected payload size	);// Status OKdata_out(	8'h12,		// Function Address		8'h0		// Expected payload size	);$display("\n\nGetting descriptor ...");send_setup(	8'h12, 		// Function Address		8'h80,		// Request Type		GET_DESCRIPTOR,	// Request		16'h0301,	// wValue		16'h0,		// wIndex		16'd010		// wLength		);data_in(	8'h12,		// Function Address		8'd010		// Expected payload size	);// Status OKdata_out(	8'h12,		// Function Address		8'h0		// Expected payload size	);$display("\n\nGetting descriptor ...");send_setup(	8'h12, 		// Function Address		8'h80,		// Request Type		GET_DESCRIPTOR,	// Request		16'h0302,	// wValue		16'h0,		// wIndex		16'd08		// wLength		);data_in(	8'h12,		// Function Address		8'd08		// Expected payload size	);// Status OKdata_out(	8'h12,		// Function Address		8'h0		// Expected payload size	);$display("\n\nGetting descriptor ...");send_setup(	8'h12, 		// Function Address		8'h80,		// Request Type		GET_DESCRIPTOR,	// Request		16'h0303,	// wValue		16'h0,		// wIndex		16'd016		// wLength		);data_in(	8'h12,		// Function Address		8'd010		// Expected payload size	);// Status OKdata_out(	8'h12,		// Function Address		8'h0		// Expected payload size	);$display("\n\nGetting descriptor ...");send_setup(	8'h12, 		// Function Address		8'h80,		// Request Type		GET_DESCRIPTOR,	// Request		16'h0203,	// wValue		16'h0,		// wIndex		16'd053		// wLength		);data_in(	8'h12,		// Function Address		8'd053		// Expected payload size	);// Status OKdata_out(	8'h12,		// Function Address		8'h0		// Expected payload size	);show_errors;$display("*****************************************************");$display("*** Test DONE ...                                 ***");$display("*****************************************************\n\n");endendtasktask in0;reg	[6:0]	my_fa;integer		quick, n, m, rlen,fc;reg	[7:0]	fd;integer		pack_cnt, pack_cnt_max;reg	[7:0]	x;reg	[3:0]	pid;reg	[3:0]	expect_pid;reg	[31:0]	data;reg		pid_cnt;begin$display("\n\n");$display("*****************************************************");$display("*** IN ep test 0                                  ***");$display("*****************************************************\n");send_sof(11'h000 );	// Send SOFpack_sz_max = 64;pack_cnt_max = 4;pid_cnt = 0;my_fa = 7'h12;for(pack_sz=0;pack_sz<pack_sz_max;pack_sz=pack_sz+1)begin$display("PL size: %0d", pack_sz);for(pack_cnt=0;pack_cnt<pack_cnt_max;pack_cnt=pack_cnt+1)   begin	// Fill Buffer	buffer1_last = 0;	for(fc=0;fc<pack_sz;fc=fc+1)	   begin		#2;		while(ep1_f_full)	@(posedge clk);			#1;		//x = fc[7:0];		x = $random;		ep1_f_din = x;		buffer0[fc] = x;		ep1_f_we = 1;		@(posedge clk);		#1;		ep1_f_we = 0;		@(posedge clk);	   end	#1;	ep1_f_we = 0;	@(posedge clk);	// Send Data	repeat(1)	@(posedge clk);	send_sof(11'h000 );	// Send SOF	repeat(1)	@(posedge clk);	send_token(	my_fa,		// Function Address			1,		// Logical Endpoint Number			`USBF_T_PID_IN	// PID			);	repeat(1)	@(posedge clk);	recv_packet(pid,rlen);	if(pid_cnt)	expect_pid = 4'hb;	else		expect_pid = 4'h3;	expect_pid = 4'h3;	if(pid !== expect_pid)	   begin		$display("ERROR: PID mismatch. Expected: %h, Got: %h (%t)",			expect_pid, pid, $time);		error_cnt = error_cnt + 1;	   end	pid_cnt = ~pid_cnt;	if(rlen != pack_sz)	   begin		$display("ERROR: Size mismatch. Expected: %d, Got: %d (%t)",			pack_sz, rlen, $time);		error_cnt = error_cnt + 1;	   end	repeat(4)	@(posedge clk);	send_token(	my_fa,		// Function Address			1,		// Logical Endpoint Number			`USBF_T_PID_ACK	// PID			);	repeat(5)	@(posedge clk);	// Verify Data	for(fc=0;fc<pack_sz;fc=fc+1)	   begin		x =  buffer0[fc];		if( (buffer1[fc] !== x) | ( (^buffer1[fc] ^ ^x) === 1'hx) )		   begin			$display("ERROR: Data (%0d) mismatch. Expected: %h, Got: %h (%t)",			fc, buffer1[fc], x, $time);			error_cnt = error_cnt + 1;		   end	   end   endrepeat(50)	@(posedge clk);endshow_errors;$display("*****************************************************");$display("*** Test DONE ...                                 ***");$display("*****************************************************\n\n");endendtasktask out0;reg	[6:0]	my_fa;reg	[31:0]	data;integer		len, n, no_pack, pl_sz;integer		no_pack_max, pl_sz_max;reg		pid;reg	[7:0]	x;begin$display("\n\n");$display("*****************************************************");$display("*** OUT ep test 0                                 ***");$display("*****************************************************\n");no_pack_max = 4;	// Number Of packets to transferpl_sz_max   = 128;	// Payload Sizeno_pack = 4;		// Number Of packets to transferpl_sz = 0;my_fa = 7'h12;for(pl_sz=0;pl_sz<pl_sz_max;pl_sz=pl_sz+4)beginpid = 0;$display("PL size: %0d", pl_sz);for(n=0;n<4096;n=n+1)	//buffer1[n] = $random;	buffer1[n] = n;buffer1_last = 0;forkfor(no_pack=0;no_pack<no_pack_max;no_pack=no_pack+1)	// Send no_pack Out packets   begin	repeat(1)	@(posedge clk);	send_sof(11'h000 );	// Send SOF	repeat(1)	@(posedge clk);	send_token(	my_fa,		// Function Address			4,		// Logical Endpoint Number			`USBF_T_PID_OUT	// PID			);	repeat(1)	@(posedge clk);	if(pid==0)	send_data(`USBF_T_PID_DATA0, pl_sz, 1);	else		send_data(`USBF_T_PID_DATA1, pl_sz, 1);	pid = ~pid;	// Wait for ACK	utmi_recv_pack(len);	if(8'hd2 !== txmem[0])	   begin		$display("ERROR: ACK mismatch. Expected: %h, Got: %h (%t)",		8'hd2, txmem[0], $time);		error_cnt = error_cnt + 1;	   end		repeat(1)	@(posedge clk);   end   begin	repeat(10)	@(posedge clk2);	for(n=0;n<(no_pack_max*pl_sz);n=n+1)	// Compare Buffers	   begin			#4;		ep4_f_re = 0;		repeat(1)	@(posedge clk2);		while(ep4_f_empty)		   begin			ep4_f_re = 0;			repeat(2)	@(posedge clk2);		   end		#2;		if(buffer1[n] !== ep4_f_dout)		   begin			$display("ERROR: DATA mismatch. Expected: %h, Got: %h (%t)",				buffer1[n], ep4_f_dout, $time);			error_cnt = error_cnt + 1;		   end			ep4_f_re = 1;		@(posedge clk2);	   end	#1;	ep4_f_re = 0;	@(posedge clk2);    endjoinrepeat(1)	@(posedge clk);endshow_errors;$display("*****************************************************");$display("*** Test DONE ...                                 ***");$display("*****************************************************\n\n");endendtask

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品视频一二三区| 五月婷婷综合在线| 午夜一区二区三区视频| 国产精品亚洲视频| 91麻豆精品国产91久久久使用方法 | 亚洲欧洲av一区二区三区久久| 丝袜国产日韩另类美女| 成人国产精品免费观看动漫| 日韩美女视频在线| 一个色在线综合| 成人亚洲一区二区一| 日韩限制级电影在线观看| 亚洲视频中文字幕| 国产成a人亚洲| 精品国产污污免费网站入口| 丝袜诱惑制服诱惑色一区在线观看| av在线不卡电影| 久久久精品国产99久久精品芒果 | 精品国产一区二区国模嫣然| 亚洲摸摸操操av| 成人黄色小视频| 国产午夜亚洲精品午夜鲁丝片| 美美哒免费高清在线观看视频一区二区| 日本高清不卡一区| 亚洲日本在线天堂| 91视频免费播放| 国产精品蜜臀在线观看| 国产成人午夜电影网| 久久久噜噜噜久久中文字幕色伊伊| 久久精品国产精品亚洲红杏| 欧美一区二区三区在| 首页亚洲欧美制服丝腿| 欧美二区在线观看| 日韩av电影免费观看高清完整版| 欧美男同性恋视频网站| 午夜激情一区二区三区| 538在线一区二区精品国产| 午夜激情久久久| 欧美一区二区三区在线观看| 久久成人久久爱| 精品国产乱码久久久久久影片| 狠狠色狠狠色合久久伊人| 精品日产卡一卡二卡麻豆| 蜜桃一区二区三区在线观看| 欧美精品一区二区三区蜜桃视频| 黄一区二区三区| 国产欧美日本一区视频| 成人91在线观看| 亚洲综合视频在线观看| 7777精品久久久大香线蕉| 日本不卡免费在线视频| 久久午夜色播影院免费高清 | 国产欧美一区二区精品久导航| 国产91丝袜在线18| 最新高清无码专区| 欧美日韩久久久久久| 久久国产人妖系列| 国产欧美精品一区二区色综合| 99久久er热在这里只有精品66| 亚洲在线视频免费观看| 欧美一二区视频| 国产99久久久国产精品| 亚洲电影一区二区三区| 日韩欧美精品在线视频| 成人av在线播放网站| 亚洲电影欧美电影有声小说| 欧美精品一区二区三区蜜桃视频 | 亚洲欧洲制服丝袜| 欧美一区二区久久久| 国产精品一二三在| 亚洲一区影音先锋| 久久伊99综合婷婷久久伊| 一本久久a久久精品亚洲| 日韩和欧美的一区| 中文字幕制服丝袜成人av | 精品国产人成亚洲区| av成人老司机| 精品午夜久久福利影院| 中文字幕一区二区5566日韩| 欧美麻豆精品久久久久久| 国产激情视频一区二区三区欧美 | 蜜臀av性久久久久蜜臀av麻豆| 成人欧美一区二区三区白人 | 欧美视频一区二区在线观看| 狠狠色丁香久久婷婷综合_中| 国产精品激情偷乱一区二区∴| 91.com在线观看| 99久久久国产精品| 国内精品免费**视频| 亚洲福利一区二区| 最新久久zyz资源站| 久久美女艺术照精彩视频福利播放 | 一区av在线播放| 国产欧美一区二区精品性| 欧美一级免费观看| 欧美午夜在线观看| 97久久超碰精品国产| 国产乱码精品一区二区三区忘忧草| 亚洲一区二区三区国产| 中文字幕一区二区三中文字幕| 欧美精品一区二区三区高清aⅴ| 欧美精品在线视频| 91福利在线观看| 色婷婷久久综合| 97精品超碰一区二区三区| 国产二区国产一区在线观看| 蜜臀久久99精品久久久久久9 | 亚洲国产精品成人综合| 久久久久亚洲综合| 日韩一级精品视频在线观看| 欧美影院午夜播放| 在线亚洲高清视频| 91精品福利视频| 色一情一乱一乱一91av| 91亚洲精品乱码久久久久久蜜桃| 成人av网址在线| 成人av影视在线观看| 91亚洲大成网污www| av电影天堂一区二区在线观看| 成人黄色小视频| 91麻豆国产香蕉久久精品| 色综合天天综合色综合av| 色天使久久综合网天天| 色婷婷久久久久swag精品| 欧美亚洲高清一区二区三区不卡| 色偷偷一区二区三区| 91久久精品日日躁夜夜躁欧美| 欧美午夜宅男影院| 91精品综合久久久久久| 精品国产伦一区二区三区免费 | 国产精品91一区二区| 成人a级免费电影| 欧美在线影院一区二区| 欧美人妇做爰xxxⅹ性高电影 | 蜜桃一区二区三区在线| 国产美女精品在线| 成人精品鲁一区一区二区| 91美女福利视频| 欧美日韩中文字幕精品| 日韩欧美国产一区在线观看| 久久久久久久综合狠狠综合| 中文字幕一区二区在线观看| 亚洲成人av一区二区| 国内精品伊人久久久久av一坑| 成人午夜视频免费看| 在线视频你懂得一区二区三区| 91精品国产综合久久久久久久| 精品国产一区二区三区久久久蜜月| 国产农村妇女精品| 亚洲一区中文在线| 另类小说一区二区三区| www.欧美日韩| 欧美日韩在线三级| 精品成人在线观看| 亚洲欧美aⅴ...| 精品一区二区三区免费| 不卡av电影在线播放| 884aa四虎影成人精品一区| 国产亚洲成年网址在线观看| 美腿丝袜在线亚洲一区| 国产成人综合亚洲91猫咪| 欧美视频在线一区二区三区| 久久久久久久综合日本| 亚洲大片精品永久免费| 成人性生交大合| 日韩三级免费观看| 亚洲欧美日韩在线| 国产伦精一区二区三区| 欧美日本韩国一区| 亚洲毛片av在线| 懂色av一区二区三区免费观看| 欧美日韩小视频| 亚洲靠逼com| 国产精品538一区二区在线| 在线播放亚洲一区| 亚洲色图欧洲色图婷婷| 国产精品综合一区二区| 51久久夜色精品国产麻豆| 亚洲色图色小说| www.成人网.com| 精品国产伦一区二区三区免费 | 一区二区三区av电影| 国产精品456露脸| 精品久久久久久久久久久久包黑料 | 欧美午夜电影网| 中文字幕一区二区三中文字幕 | 日本在线不卡视频一二三区| 色视频成人在线观看免| 国产精品女同互慰在线看| 国产一区二区三区在线观看免费视频| 欧美色男人天堂| 一区二区三区在线看| 成人免费视频视频在线观看免费| 欧美精品一区男女天堂| 麻豆精品在线观看| 欧美精品视频www在线观看 | 亚洲日韩欧美一区二区在线| a美女胸又www黄视频久久| 欧美tickling网站挠脚心| 奇米综合一区二区三区精品视频|