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

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

?? usbf_idma.v

?? USB2.0 chip的一部分verilog源碼。opencore上下的
?? V
字號:
                           `include "usbf_defines.v"module usbf_idma(	clk, rst,		// Packet Disassembler/Assembler interface		rx_data_st, rx_data_valid, rx_data_done, 		send_data, tx_data_st, rd_next,		// Protocol Engine		rx_dma_en, tx_dma_en,		abort, idma_done,		buf_size, dma_en,		send_zero_length,		// Register File Manager Interface		adr, size, sizu_c,		// Memory Arb interface		madr, mdout, mdin, mwe, mreq, mack		);parameter	SSRAM_HADR = 14;// Packet Disassembler/Assembler interfaceinput		clk, rst;input	[7:0]	rx_data_st;input		rx_data_valid;input		rx_data_done;output		send_data;output	[7:0]	tx_data_st;input		rd_next;// Protocol Engineinput		rx_dma_en;	// Allows the data to be storedinput		tx_dma_en;	// Allows for data to be retrievedinput		abort;		// Abort Transfer (time_out, crc_err or rx_error)output		idma_done;	// DMA is doneinput	[13:0]	buf_size;	// Actual buffer sizeinput		dma_en;		// External DMA enabledinput		send_zero_length;// Register File Manager Interfaceinput	[SSRAM_HADR + 2:0]	adr;	// Byte Addressinput	[13:0]	size;		// Size in bytesoutput	[10:0]	sizu_c;		// Up and Down counting size registers, used to update// Memory Arb interfaceoutput	[SSRAM_HADR:0]	madr;	// word addressoutput	[31:0]	mdout;input	[31:0]	mdin;output		mwe;output		mreq;input		mack;/////////////////////////////////////////////////////////////////////// Local Wires and Registers//parameter	[7:0]	// synopsys enum state		IDLE		= 8'b00000001,		WAIT_MRD	= 8'b00000010,		MEM_WR		= 8'b00000100,		MEM_WR1		= 8'b00001000,		MEM_WR2		= 8'b00010000,		MEM_RD1		= 8'b00100000,		MEM_RD2		= 8'b01000000,		MEM_RD3		= 8'b10000000;reg	[7:0]	/* synopsys enum state */ state, next_state;// synopsys state_vector statereg		tx_dma_en_r, rx_dma_en_r;reg	[SSRAM_HADR:0]	adr_cw;		// Internal word address counterreg	[2:0]	adr_cb;			// Internal byte address counterreg	[SSRAM_HADR:0]	adrw_next;	// next addressreg	[SSRAM_HADR:0]	adrw_next1;	// next address (after overrun check)reg	[SSRAM_HADR:0]	last_buf_adr;	// Last Buffer Addressreg	[2:0]	adrb_next;		// next byte addressreg	[13:0]	sizd_c;			// Internal size counterreg	[10:0]	sizu_c;			// Internal size counterwire		adr_incw;wire		adr_incb;wire		siz_dec;wire		siz_inc;reg		word_done;		// Indicates that a word has been					// assembledreg		mreq_d;			// Memory request from State Machinereg	[31:0]	dtmp_r;			// Temp data assembly registerreg	[31:0]	dout_r;			// Data output registerreg		mwe_d;			// Memory Write enablereg		dtmp_sel;		// Selects tmp data register for pre-fetchreg		sizd_is_zero;		// Indicates when all bytes have been					// transferredwire		sizd_is_zero_d;reg	[7:0]	tx_data_st;		// Data output to packet assemblerreg	[31:0]	rd_buf0, rd_buf1;	// Mem Rd. buffers for TXreg		rd_first;		// Indicates initial fill of buffersreg		idma_done;		// DMA transfer is donereg		mack_r;wire		send_data;		// Enable UTMI Transmitterreg		send_data_r;reg		word_done_r;reg		wr_last;reg		wr_last_en;reg		wr_done;reg		wr_done_r;reg		dtmp_sel_r;reg		mwe;reg		rx_data_done_r2;wire		fill_buf0, fill_buf1;wire		adrb_is_3;reg		rx_data_done_r;reg		rx_data_valid_r;reg	[7:0]	rx_data_st_r;reg		send_zero_length_r;/////////////////////////////////////////////////////////////////////// Memory Arb interface//// Memory Requestassign mreq = (mreq_d & !mack_r) | word_done_r;// Output Dataassign mdout = dout_r;// Memory Addressassign madr = adr_cw;always @(posedge clk)	mwe <= mwe_d;always @(posedge clk)	mack_r <= mreq & mack;/////////////////////////////////////////////////////////////////////// Misc Logic//always @(posedge clk)	rx_data_valid_r <= rx_data_valid;always @(posedge clk)	rx_data_st_r <= rx_data_st;always @(posedge clk)	rx_data_done_r <= rx_data_done;always @(posedge clk)	rx_data_done_r2 <= rx_data_done_r;// Generate one cycle pulses for tx and rx dma enablealways @(posedge clk)	tx_dma_en_r <= tx_dma_en;always @(posedge clk)	rx_dma_en_r <= rx_dma_en;always @(posedge clk)	send_zero_length_r <= send_zero_length;// address counteralways @(posedge clk)	if(rx_dma_en_r || tx_dma_en_r)	adr_cw <= adr[SSRAM_HADR + 2:2];	else				adr_cw <= adrw_next1;always @(posedge clk)	last_buf_adr <= adr + { {SSRAM_HADR+2-13{1'b0}}, buf_size };always @(dma_en or adrw_next or last_buf_adr)	if(adrw_next == last_buf_adr && dma_en)	adrw_next1 = {SSRAM_HADR+1{1'b0}};	else					adrw_next1 = adrw_next;always @(adr_incw or adr_cw)	if(adr_incw)	adrw_next = adr_cw + {{SSRAM_HADR{1'b0}}, 1'b1};	else		adrw_next = adr_cw;`ifdef USBF_ASYNC_RESETalways @(posedge clk or negedge rst)`elsealways @(posedge clk)`endif	if(!rst)			adr_cb <= 3'h0;	else	if(rx_dma_en_r || tx_dma_en_r)	adr_cb <= adr[2:0];	else				adr_cb <= adrb_next;always @(adr_incb or adr_cb)	if(adr_incb)	adrb_next = adr_cb + 3'h1;	else		adrb_next = adr_cb;assign adr_incb = rx_data_valid_r | rd_next;assign adr_incw = !dtmp_sel_r & mack_r;// Size Counter (counting backward from input size)`ifdef USBF_ASYNC_RESETalways @(posedge clk or negedge rst)`elsealways @(posedge clk)`endif	if(!rst)			sizd_c <= 14'h3fff;	else	if(tx_dma_en || tx_dma_en_r)	sizd_c <= size;	else	if(siz_dec)			sizd_c <= sizd_c - 14'h1;assign siz_dec = (rd_first & mack_r) | (rd_next & (sizd_c != 14'h0));assign sizd_is_zero_d = sizd_c == 14'h0;always @(posedge clk)	sizd_is_zero <= sizd_is_zero_d;// Size Counter (counting up from zero)`ifdef USBF_ASYNC_RESETalways @(posedge clk or negedge rst)`elsealways @(posedge clk)`endif	if(!rst)		sizu_c <= 11'h0;	else	// Do I need to add "abort" in the next line ???	if(rx_dma_en_r)		sizu_c <= 11'h0;	else	if(siz_inc)		sizu_c <= sizu_c + 11'h1;assign siz_inc = rx_data_valid_r;// DMA Done Indicatoralways @(posedge clk)	idma_done <= (rx_data_done_r | sizd_is_zero_d); // & !tx_dma_en;/////////////////////////////////////////////////////////////////////// RX Logic//always @(posedge clk)	dtmp_sel_r <= dtmp_sel;// Memory data inputalways @(posedge clk)	if(dtmp_sel_r)			dtmp_r <= mdin;	else	if(rx_data_valid_r)	   begin		if(adr_cb[1:0] == 2'h0)	dtmp_r[07:00] <= rx_data_st_r;		if(adr_cb[1:0] == 2'h1)	dtmp_r[15:08] <= rx_data_st_r;		if(adr_cb[1:0] == 2'h2)	dtmp_r[23:16] <= rx_data_st_r;		if(adr_cb[1:0] == 2'h3)	dtmp_r[31:24] <= rx_data_st_r;	   endalways @(posedge clk)	word_done <= ((adr_cb[1:0] == 2'h3) & rx_data_valid_r) | wr_last;always @(posedge clk)	word_done_r <= word_done & !word_done_r;// Store output data and address when we got a wordalways @(posedge clk)	if(word_done)	dout_r <= dtmp_r;always @(posedge clk)	wr_last <= (adr_cb[1:0] != 2'h0) & !rx_data_valid_r & wr_last_en;always @(posedge clk)	wr_done_r <= rx_data_done_r;always @(posedge clk)	wr_done <= wr_done_r;/////////////////////////////////////////////////////////////////////// TX Logic//// Fill TX Buffersalways @(posedge clk)	if(fill_buf0)	rd_buf0 <= mdin;always @(posedge clk)	if(fill_buf1)	rd_buf1 <= mdin;always @(adrb_next or rd_buf0 or rd_buf1)	case(adrb_next[2:0])	// synopsys full_case parallel_case	   3'h0: tx_data_st = rd_buf0[07:00];	   3'h1: tx_data_st = rd_buf0[15:08];	   3'h2: tx_data_st = rd_buf0[23:16];	   3'h3: tx_data_st = rd_buf0[31:24];	   3'h4: tx_data_st = rd_buf1[07:00];	   3'h5: tx_data_st = rd_buf1[15:08];	   3'h6: tx_data_st = rd_buf1[23:16];	   3'h7: tx_data_st = rd_buf1[31:24];	endcaseassign fill_buf0 = !adr_cw[0] & mack_r;assign fill_buf1 =  adr_cw[0] & mack_r;assign	adrb_is_3 = adr_cb[1:0] == 2'h3;`ifdef USBF_ASYNC_RESETalways @(posedge clk or negedge rst)`elsealways @(posedge clk)`endif	if(!rst)		send_data_r <= 1'b0;	else	if(rd_first)		send_data_r <= 1'b1;	else	if(((sizd_c==14'h1) && rd_next) || sizd_is_zero_d)	send_data_r <= 1'b0;assign send_data = send_data_r | send_zero_length_r;/////////////////////////////////////////////////////////////////////// IDMA Load/Store State Machine//// store incoming data to memory until rx_data done// First pre-fetch data from memory, so that bytes can be stuffed properly`ifdef USBF_ASYNC_RESETalways @(posedge clk or negedge rst)`elsealways @(posedge clk)`endif	if(!rst)	state <= IDLE;	else		state <= next_state;always @(state or mack_r or abort or rx_dma_en_r or tx_dma_en_r or 	sizd_is_zero or wr_last or wr_done or rx_data_done_r2 or 	rd_next or adrb_is_3 or send_zero_length_r)   begin	next_state = state;	// Default do not change state	mreq_d = 1'b0;	mwe_d = 1'b0;	rd_first = 1'b0;	dtmp_sel = 1'b0;	wr_last_en = 1'b0;	case(state)	// synopsys full_case parallel_case	   IDLE:		   begin// synopsys translate_off`ifdef USBF_VERBOSE_DEBUG$display("IDMA: Entered IDLE state (%t)", $time);`endif`ifdef USBF_DEBUGif(rst)beginif(rx_dma_en_r === 1'bx)	$display("ERROR: IDMA: IDLE: rx_dma_en_r is unknown. (%t)", $time);if(tx_dma_en_r === 1'bx)	$display("ERROR: IDMA: IDLE: tx_dma_en_r is unknown. (%t)", $time);if(abort === 1'bx)		$display("ERROR: IDMA: IDLE: abort is unknown. (%t)", $time);end`endif// synopsys translate_on			if(rx_dma_en_r && !abort)			   begin				next_state = WAIT_MRD;			   end			if(tx_dma_en_r && !abort && !send_zero_length_r)			   begin				next_state = MEM_RD1;			   end		   end	   WAIT_MRD:	// Pre-fetch a word from memory		   begin// synopsys translate_off`ifdef USBF_VERBOSE_DEBUG$display("IDMA: Entered WAIT_MRD state (%t)", $time);`endif`ifdef USBF_DEBUGif(abort === 1'bx)	$display("ERROR: IDMA: WAIT_MRD: abort is unknown. (%t)", $time);if(mack_r === 1'bx)	$display("ERROR: IDMA: WAIT_MRD: mack_r is unknown. (%t)", $time);`endif// synopsys translate_on			if(abort)	next_state = IDLE;			else			if(mack_r)	next_state = MEM_WR;			else			   begin				dtmp_sel = 1'b1;				mreq_d = 1'b1;			   end		   end	   MEM_WR:		   begin// synopsys translate_off`ifdef USBF_VERBOSE_DEBUG$display("IDMA: Entered MEM_WR state (%t)", $time);`endif`ifdef USBF_DEBUGif(abort === 1'bx)	$display("ERROR: IDMA: MEM_WR: abort is unknown. (%t)", $time);if(rx_data_done_r2 === 1'bx)	$display("ERROR: IDMA: MEM_WR: rx_data_done_r2 is unknown. (%t)", $time);`endif// synopsys translate_on			mwe_d = 1'b1;			if(abort)			next_state = IDLE;			else			if(rx_data_done_r2)				   begin				wr_last_en = 1'b1;				next_state = MEM_WR1;			   end		   end	   MEM_WR1:		   begin// synopsys translate_off`ifdef USBF_VERBOSE_DEBUG$display("IDMA: Entered MEM_WR1 state (%t)", $time);`endif`ifdef USBF_DEBUGif(abort === 1'bx)	$display("ERROR: IDMA: MEM_WR1: abort is unknown. (%t)", $time);if(wr_last === 1'bx)	$display("ERROR: IDMA: MEM_WR1: wr_last is unknown. (%t)", $time);if(wr_done === 1'bx)	$display("ERROR: IDMA: MEM_WR1: wr_done is unknown. (%t)", $time);`endif// synopsys translate_on			mwe_d = 1'b1;			wr_last_en = 1'b1;			if(abort)			next_state = IDLE;			else			if(wr_last)			next_state = MEM_WR2;			else			if(wr_done)			next_state = IDLE;		   end	   MEM_WR2:		   begin// synopsys translate_off`ifdef USBF_VERBOSE_DEBUG$display("IDMA: Entered MEM_WR2 state (%t)", $time);`endif`ifdef USBF_DEBUGif(mack_r === 1'bx)	$display("ERROR: IDMA: MEM_WR2: mack_r is unknown. (%t)", $time);`endif// synopsys translate_on			mwe_d = 1'b1;			if(mack_r)			next_state = IDLE;		   end	   MEM_RD1:		   begin// synopsys translate_off`ifdef USBF_VERBOSE_DEBUG$display("IDMA: Entered MEM_RD1 state (%t)", $time);`endif`ifdef USBF_DEBUGif(abort === 1'bx)	$display("ERROR: IDMA: MEM_RD1: abort is unknown. (%t)", $time);if(mack_r === 1'bx)	$display("ERROR: IDMA: MEM_RD1: mack_r is unknown. (%t)", $time);`endif// synopsys translate_on			mreq_d = 1'b1;			if(mack_r)		rd_first = 1'b1;			if(abort)		next_state = IDLE;			else			if(mack_r)		next_state = MEM_RD2;		   end	   MEM_RD2:		   begin// synopsys translate_off`ifdef USBF_VERBOSE_DEBUG$display("IDMA: Entered MEM_RD2 state (%t)", $time);`endif`ifdef USBF_DEBUGif(abort === 1'bx)	$display("ERROR: IDMA: MEM_RD2: abort is unknown. (%t)", $time);if(mack_r === 1'bx)	$display("ERROR: IDMA: MEM_RD2: mack_r is unknown. (%t)", $time);`endif// synopsys translate_on			mreq_d = 1'b1;			if(abort)		next_state = IDLE;			else			if(mack_r)		next_state = MEM_RD3;		   end	   MEM_RD3:		   begin// synopsys translate_off`ifdef USBF_VERBOSE_DEBUG$display("IDMA: Entered MEM_RD3 state (%t)", $time);`endif`ifdef USBF_DEBUGif(abort === 1'bx)	$display("ERROR: IDMA: MEM_RD3: abort is unknown. (%t)", $time);if(sizd_is_zero===1'bx) $display("ERROR: IDMA: MEM_RD3: sizd_is_zero is unknown. (%t)", $time);if(adrb_is_3 === 1'bx)	$display("ERROR: IDMA: MEM_RD3: adrb_is_3 is unknown. (%t)", $time);if(rd_next === 1'bx)	$display("ERROR: IDMA: MEM_RD3: rd_next is unknown. (%t)", $time);`endif// synopsys translate_on			if(sizd_is_zero || abort)	next_state = IDLE;			else			if(adrb_is_3 && rd_next)	next_state = MEM_RD2;		   end	endcase   endendmodule

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产福利一区二区三区视频| 日本高清无吗v一区| 成人av资源下载| 欧美色图片你懂的| 久久久美女毛片| 亚洲成人综合网站| 国产激情精品久久久第一区二区 | 成人激情免费视频| 欧美日韩国产一二三| 国产精品欧美久久久久一区二区 | 一区二区三区四区在线播放| 极品少妇一区二区三区精品视频| 欧美亚洲另类激情小说| 久久久久九九视频| 蜜桃av一区二区三区| 欧美视频一区二| 一色桃子久久精品亚洲| 国产在线精品一区二区不卡了| 欧洲精品视频在线观看| 中文字幕中文字幕一区二区| 国产乱码精品一品二品| 欧美大黄免费观看| 麻豆精品一区二区三区| 欧美一区二区精美| 免费在线视频一区| 91精品国产福利在线观看| 亚洲国产日韩a在线播放 | 国产高清不卡二三区| 日韩欧美电影在线| 日韩精品一卡二卡三卡四卡无卡| 欧美三区免费完整视频在线观看| 亚洲三级视频在线观看| aaa亚洲精品| 综合激情成人伊人| 色狠狠av一区二区三区| 一区二区三区国产豹纹内裤在线| 色综合久久综合网欧美综合网| 最新国产の精品合集bt伙计| 91视频在线观看| 一区二区三区在线看| 在线精品视频免费播放| 一级做a爱片久久| 欧美三级乱人伦电影| 亚洲国产欧美在线| 欧美一级夜夜爽| 韩国欧美国产1区| 国产精品视频看| 欧洲一区在线电影| 蜜桃一区二区三区在线| 亚洲sss视频在线视频| 91麻豆精品国产91久久久资源速度 | 欧美午夜不卡在线观看免费| 亚洲福利国产精品| 91精品国产品国语在线不卡| 精久久久久久久久久久| 欧美国产综合一区二区| 色婷婷香蕉在线一区二区| 亚洲综合精品自拍| 日韩三级在线免费观看| 国产一区二区电影| 亚洲欧洲www| 9191精品国产综合久久久久久| 蜜桃视频在线观看一区二区| 欧美激情在线免费观看| 欧美亚洲日本一区| 国产福利精品导航| 一级特黄大欧美久久久| 欧美岛国在线观看| 色94色欧美sute亚洲13| 日本网站在线观看一区二区三区| 中文一区在线播放| 555夜色666亚洲国产免| 高清日韩电视剧大全免费| 亚洲一区二区三区四区的| 久久综合成人精品亚洲另类欧美 | 精品一区二区三区免费| 成人免费一区二区三区在线观看| 欧美日韩www| www.久久精品| 麻豆精品精品国产自在97香蕉 | 天堂成人国产精品一区| 国产精品麻豆99久久久久久| 欧美精品日韩一区| a4yy欧美一区二区三区| 看国产成人h片视频| 亚洲综合色视频| 国产精品欧美综合在线| 日韩免费观看高清完整版 | 日韩一区日韩二区| xfplay精品久久| 欧美人狂配大交3d怪物一区| 日韩一卡二卡三卡四卡| 日本韩国欧美三级| 成人深夜福利app| 精品一区二区免费在线观看| 偷窥国产亚洲免费视频| 亚洲乱码一区二区三区在线观看| 久久综合久久综合久久综合| 欧美一区二区三区四区高清| 欧美日韩在线直播| 91黄色免费看| 色哟哟在线观看一区二区三区| 国产凹凸在线观看一区二区| 精品一区二区综合| 久久精品国产亚洲高清剧情介绍 | 国产精品久久久久久久久动漫 | 综合久久久久久久| 国产精品欧美一级免费| 久久久午夜精品理论片中文字幕| 91精品国产91久久久久久最新毛片| 在线亚洲精品福利网址导航| 91在线视频免费91| av在线一区二区三区| 国产91精品一区二区麻豆网站| 国产成人综合网| 国产成人自拍网| 91麻豆精品国产自产在线观看一区| 欧美日韩一区二区在线视频| 欧美亚洲国产一区二区三区| 欧美亚洲高清一区二区三区不卡| 色狠狠桃花综合| 欧美日韩一区中文字幕| 欧美日韩精品三区| 欧美一级二级三级蜜桃| 欧美一区二区三区人| 日韩精品在线一区二区| 亚洲精品一区二区在线观看| 久久综合色鬼综合色| 国产精品丝袜91| 亚洲精品国产一区二区精华液| 亚洲黄色av一区| 天堂蜜桃一区二区三区| 美女视频一区在线观看| 国产激情视频一区二区三区欧美| 成人爱爱电影网址| 欧美少妇xxx| 久久亚洲免费视频| 中文字幕一区在线观看视频| 亚洲黄色小说网站| 麻豆国产精品777777在线| 国产毛片一区二区| 色94色欧美sute亚洲13| 日韩欧美三级在线| 国产精品视频一区二区三区不卡| 夜色激情一区二区| 九色综合狠狠综合久久| 99精品国产99久久久久久白柏| 欧美日韩精品一区二区三区四区| 精品成人私密视频| 亚洲精选一二三| 九九九精品视频| 91免费看`日韩一区二区| 亚洲精品视频免费看| 日韩高清国产一区在线| 成人丝袜18视频在线观看| 欧美精品日韩精品| 国产精品美女久久久久久久久| 亚洲国产裸拍裸体视频在线观看乱了| 精品一区二区在线视频| 92国产精品观看| www亚洲一区| 午夜精品福利一区二区蜜股av | 成人综合婷婷国产精品久久免费| 欧美影视一区二区三区| 国产日韩欧美激情| 日韩av在线发布| 97精品电影院| 久久精品这里都是精品| 午夜电影一区二区三区| 成人高清免费观看| 欧美sm极限捆绑bd| 丝瓜av网站精品一区二区| 99久久99久久免费精品蜜臀| 精品粉嫩aⅴ一区二区三区四区| 夜夜爽夜夜爽精品视频| 成人sese在线| 欧美激情一区二区在线| 精品在线一区二区| 日韩一区二区影院| 亚洲第一激情av| 一本到不卡免费一区二区| 中文字幕av资源一区| 精品综合免费视频观看| 欧美一区欧美二区| 视频在线观看91| 欧美日韩亚洲综合在线 | 麻豆91精品视频| 欧美日韩精品高清| 亚洲国产欧美在线| 欧洲精品一区二区| 亚洲国产欧美日韩另类综合 | 成人av在线播放网站| 久久精品亚洲一区二区三区浴池 | 成人动漫一区二区三区| 久久久777精品电影网影网 | 久久免费看少妇高潮| 国产一区二区三区日韩| 久久免费偷拍视频| 国产成人午夜99999| 国产精品免费人成网站|