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

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

?? packer.v

?? verilog data packer verilog data packer verilog data packer
?? V
字號:
/*******************************************************************/
/*   		This module implements Data packer Stage of the	       */
/*				Entropy Encoder					                   */
/*******************************************************************/

module packer( Reset,
               Enable,
               CodeandLength,
               Coefficient,
               Category,
               Clk,
               ValidCode,
               EOB,
               EndD, 
               DataOut,
               OutputValid,
               Ready
               );

/********************INPUTS***********************/
input [19:0] CodeandLength;    // Variable length Huffman Code and its Length
input [10:0] Coefficient;      // Variable length Coefficient
input [3:0]  Category;         // Category (Coefficient's length)
input        Clk;              // System wide clock
input        ValidCode;        // Arrival of Valid Data Signal.  The frequency of this
             // signal depends upon amount of compression being achieved in previous stages
input        Reset;            // System wide reset
input        EOB;              // Signal for End of Block
input        EndD;             // Signal for End of Data
input        Enable;           // System wide enable

/********************OUTPUTS**********************/
output[15:0] DataOut;          // Packed Output Data
output       OutputValid;      // Signals external logic that valid data is available
output       Ready;            // Signal showing if Data packer stage is ready or not

reg [15:0]   DataOut;
reg          OutputValid;	 
reg          Ready;		

/********************INTERNAL**********************/
reg [26:0]   RegA;            // These two registers hold data
reg [47:0]   RegB;            // for output
reg [4:0]    Length;          // Length Register contains lenght of valid data in RegA
reg [5:0]    EndP;            // It Points to end of valid data in RegB
						
reg          OutputLastData;  // Internal Signal
reg          ResetMe;         // Internal Reset
reg [15:0]   TempReg;         // Register for internal use
reg          EOB2, EOB3;	

wire [10:0] 	CoefficientIn, TempValue;
wire [3:0]		CodeLength;
wire 			ResetIt;
wire 			[15:0]Code;
wire 			[15:0] Data;
wire [5:0] 		Shift1, Shift2;

/*****************Extract Code and its length from CodeandLength***************/
assign Code = CodeandLength[15:0];         //Take Code from CodeandLength
assign CodeLength = CodeandLength[19:16];  //Take Code Length

/*****************Assignment of Output port************************/
assign Data = RegB[47:32];   //Output is taken from 16 upper bits of RegB 


/****************************************************************************************/
/*Value of Shift for Shifting contents of RegA to concatenate them with contents of RegB*/
/****************************************************************************************/
assign Shift1 = EndP - Length; 	

/****************************************************************************/
/* Value of Shift for Shifting contents of RegA in RegB when output is valid*/
/****************************************************************************/
assign Shift2 = (Shift1 + 16 );  // 16 more shifts are required b/c 16 bit of data has
                                 // been taken out of higher 16 bits of RegB

/**************Masking off of extra bits of Ceofficient*****************/
/********The Category contains length of valid bits in Coefficient******/
/*****Using Category garbage values in higher bits are masked off*******/
assign {CoefficientIn, TempValue}  = {Coefficient, 11'b 00000000000} & (22'b 0000000000011111111111 << Category);

/************Internally generated Reset***************/
assign ResetIt = Reset | ResetMe; //Reset = External Reset + Internal Reset



/********************************HANDLING OUTPUTS*******************************/
always @(posedge Clk or posedge ResetIt)
begin
if(ResetIt)
begin
	EndP <= 48;
	OutputValid <= 0;
end

else if(Enable)         // If pipeline is not freezed
begin
	if(ValidCode)       // If code has arrived in this clock cycle
	begin               // then take its length in Length register
		Length <= Category + CodeLength + 1;
	end                 // This register now contains length of data in RegA

	else
		Length <= 0;	

/****The variable length code and coefficients are concatenated and stored in RegA***/
/****All this is done even when no new code or category has come.  The same operation is 
***********************then performed at the old values*********/
	RegA <= CoefficientIn | (Code << Category);  // {Code, Coefficient}
					
	if(EndP < 33)                 // If there is valid data in upper
	begin                         // 16 bits of RegB
		OutputValid <= 1;         // Signal the output
		DataOut <= Data;          // Latch the higher 16 bits of RegB in DataOut

/**** Load new value in RegB with remaining bits shifted left 16 more times to fill ****/
/************************* the vaccancy created due to output***************************/
		RegB <= (RegB << 16) | ( RegA << Shift2 );
					
		EndP <= Shift2;          // Modify EndP to new end
	end

	else if(EOB3)                // If End of Block has arrived
	begin
		OutputValid <= 1;        // Signal the external circuitry
		OutputLastData <= 1;     // Set internal flag
                          // Padding of 1s in the remaining bits to create a 16 bit output
		{DataOut, TempReg} <= {RegB[47:32], 16'b 0000000000000000} | (32'b 00000000000000001111111111111111 << (EndP-16));	
	end

/*****************************************************************************************/
/*Arrive here when RegB contains less than 16 bits of data and EOB signal has not arrived*/
/*****************************************************************************************/
	else			 
	begin
	  	RegB <= RegB | ( RegA << Shift1);  
        //Concatenate new value in RegA with the previous ones in RegB

		EndP <= Shift1;              // and modify EndP to new end of valid data in RegB
		OutputValid <= 0;            //Output is invalid
	end

 end
 end

always @(posedge Clk or posedge ResetIt)
begin
if(ResetIt)	
begin	
	ResetMe <= 0;
	EOB2 <= 0;
	EOB3 <= 0;
end
else if(Enable) 
begin
	if(EOB)               // Temporary storage of EOB signal equal to no of stages
	begin                 // in data packer
		EOB2 <= 1;
	end
	else if(EOB3)         // so that till EOB reaches EOB3, data has reached RegB, the 
	begin                 // final destination from where it is to be output
		ResetMe <= 1;     // hence the remaining bits are then padded with 1s as specified
	end				      // in JPEG standard and output
	else if(EOB2)
	begin
		EOB3 <= 1;
	end
		
	if(OutputLastData )     // if last data has been output
	begin					
		if(EndD)            // of last block
			Ready <= 1;	    // tell this to external circuitry that the chip 
                            // has processed the data.  Pipeline is empty and
                            // ready for new set of data
		else                 
			Ready <= 0;     
	end
	
end
end

endmodule

 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲人成网站精品片在线观看| 欧美三级韩国三级日本三斤| 国产女人水真多18毛片18精品视频| 国产一区二区三区在线观看免费| 久久亚洲春色中文字幕久久久| 成人性视频网站| 亚洲自拍偷拍欧美| 91精品国产91综合久久蜜臀| 国产乱对白刺激视频不卡| 国产精品家庭影院| 欧美日韩在线精品一区二区三区激情 | 色猫猫国产区一区二在线视频| 亚洲永久免费av| 精品毛片乱码1区2区3区| 成人动漫视频在线| 亚洲地区一二三色| 久久―日本道色综合久久| 91一区在线观看| 亚洲sss视频在线视频| 久久精品一区二区三区av| 91蝌蚪porny| 看电视剧不卡顿的网站| 欧美经典一区二区三区| 欧美性受xxxx黑人xyx性爽| 九九精品一区二区| 亚洲日本在线a| 日韩三级在线免费观看| www.久久久久久久久| 日韩高清一区二区| 亚洲欧洲日产国产综合网| 日韩一区二区免费电影| 色婷婷香蕉在线一区二区| 精品中文字幕一区二区小辣椒| 亚洲视频网在线直播| 日韩一区二区三区在线观看| 91老师片黄在线观看| 国产精一区二区三区| 亚洲在线免费播放| 欧美激情一区二区三区| 亚洲精品视频免费看| 91精品啪在线观看国产60岁| 韩国av一区二区| 亚洲乱码国产乱码精品精小说| 欧美一级视频精品观看| 欧美性色黄大片手机版| 成人免费电影视频| 九九精品一区二区| 日韩经典一区二区| 一区二区三区欧美在线观看| 国产亚洲人成网站| 欧美一区二区三区四区久久| 色综合欧美在线视频区| 成人教育av在线| 久久99精品久久久久久国产越南 | 亚洲国产成人av网| 精品国精品国产尤物美女| 久久综合九色综合久久久精品综合 | 国产亚洲成aⅴ人片在线观看| 欧美肥妇bbw| 在线看不卡av| 91视频精品在这里| 91影院在线免费观看| 成人av在线影院| 成人国产精品免费观看视频| 国产成人午夜99999| 久久国产剧场电影| 狠狠色丁香久久婷婷综合_中| 午夜一区二区三区在线观看| 亚洲三级免费观看| 亚洲女女做受ⅹxx高潮| 中文字幕亚洲不卡| 亚洲视频香蕉人妖| 亚洲精品免费在线观看| 亚洲乱码国产乱码精品精可以看 | 国产三级一区二区| 波多野结衣中文字幕一区二区三区 | 粉嫩一区二区三区在线看| 国产在线一区观看| 国产精品99久久久久久似苏梦涵 | av午夜一区麻豆| 成人av在线资源网| 91在线精品秘密一区二区| 97国产精品videossex| 99久久精品国产导航| 97超碰欧美中文字幕| 在线观看网站黄不卡| 欧美精品黑人性xxxx| 欧美一级片免费看| 国产日本亚洲高清| 亚洲欧美电影院| 成人午夜免费视频| 99久久久精品免费观看国产蜜| 色综合中文字幕国产| 欧美日韩三级视频| 亚洲国产欧美日韩另类综合| 国产精品久久久久7777按摩| 亚洲精品视频免费看| 亚洲成av人在线观看| 九色综合狠狠综合久久| 成人高清视频在线观看| 欧美性猛交xxxx黑人交| 日韩一级片网址| 国产精品久久久久久户外露出| 一区二区三区四区高清精品免费观看| 日韩精品一卡二卡三卡四卡无卡| 国产做a爰片久久毛片| 91网站最新网址| 91精品综合久久久久久| 国产精品久久久久久久久图文区 | 蜜臀av一区二区| 丁香婷婷综合色啪| 欧美精品一二三区| 国产精品沙发午睡系列990531| 亚洲国产精品久久不卡毛片| 国产一区二区不卡老阿姨| 欧美午夜精品一区二区蜜桃| 26uuu国产在线精品一区二区| 亚洲日穴在线视频| 精品一区二区三区在线播放视频 | 亚洲丝袜美腿综合| 美腿丝袜亚洲色图| 精品国产一区二区三区忘忧草| 久久综合九色欧美综合狠狠| 亚洲视频精选在线| 九一九一国产精品| 欧美性三三影院| 国产欧美综合在线| 美国欧美日韩国产在线播放| 色综合天天综合网天天狠天天| 日韩精品中文字幕在线一区| 樱花草国产18久久久久| 成人免费av网站| 精品理论电影在线观看| 亚洲mv大片欧洲mv大片精品| 99久久精品一区| 国产性色一区二区| 免费成人av资源网| 欧美亚洲一区二区在线| 国产精品国产三级国产aⅴ原创 | 精品成人在线观看| 丝袜亚洲另类丝袜在线| 97精品视频在线观看自产线路二| 久久老女人爱爱| 裸体歌舞表演一区二区| 欧美日韩国产欧美日美国产精品| 国产精品久久久久久亚洲毛片| 国产一区二区91| 久久综合久久久久88| 久久精品噜噜噜成人av农村| 欧美日韩成人一区二区| 亚洲国产视频一区| 欧美性一级生活| 亚洲国产成人av网| 欧美性受xxxx黑人xyx性爽| 一区二区三区四区亚洲| 91麻豆视频网站| 一区在线观看免费| 91免费看片在线观看| 亚洲天堂成人网| 91在线看国产| 一区二区三区在线视频播放| 色综合一区二区| 伊人性伊人情综合网| 色综合久久天天综合网| 亚洲精品va在线观看| 91久久奴性调教| 亚洲午夜久久久久久久久久久| 在线观看三级视频欧美| 亚洲国产一区二区a毛片| 欧美美女激情18p| 蜜臂av日日欢夜夜爽一区| 欧美成人官网二区| 国产美女主播视频一区| 中文字幕第一区| 欧美肥妇bbw| 国产一区二区三区精品欧美日韩一区二区三区 | 337p日本欧洲亚洲大胆精品| 国产很黄免费观看久久| 国产精品毛片高清在线完整版| 99热这里都是精品| 亚洲超碰精品一区二区| 51久久夜色精品国产麻豆| 激情另类小说区图片区视频区| 久久久久久99久久久精品网站| 国产传媒日韩欧美成人| 亚洲精品日韩一| 欧美日韩三级在线| 国产一区二区三区观看| 日韩一区在线看| 51精品久久久久久久蜜臀| 国产一区二区三区av电影| 中文字幕色av一区二区三区| 在线观看日韩精品| 黄一区二区三区| 17c精品麻豆一区二区免费| 欧美体内she精视频| 国产精品综合一区二区三区| 亚洲欧美成aⅴ人在线观看| 日韩一区二区视频| 99精品视频一区|