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

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

?? smc_model.v

?? 自己設計的Smartcard功能模塊
?? V
字號:
module SMC_model(smc_clk,smc_data, smc_rstn);

input smc_clk	    	;
inout smc_data		;
input smc_rstn		;




//local signals
parameter 	IDLE		    = 0,
		RESET		    = 1,
		RESET_WAIT	    = 2,
		RX_START	    = 3,
		RX_PARITY	    = 4,
		RX_WAIT		    = 5,
		TX_START	    = 6,
		TX_PARITY_CHECK	    = 7,
		TX_REPEAT_WAIT	    = 8,
		TX_WAIT		    = 9,
		CLOCK_STOP	    = 10,
		DEACTIVE	    = 11,
		BLOCK_WAIT	    = 12;


reg [3:0]cur_state, next_state;			

reg smc_data_out		;
reg smc_data_en			;

reg [7:0]tx_shifter		;
reg [7:0]rx_shifter		;

wire reset_resp_timeout		;
reg [23:0]bit_cnt		;

wire [3:0]D			;
wire [15:0]fi			;
reg [7:0]di			;
reg [2:0]bit_shift		;
reg [21:0]clk_num		;
reg [21:0]smc_clk_cnt		;	
reg smc_bit_en			;
reg smc_half_bit_en		;
reg rx_start			;
reg tx_start			;

reg smc_data_in_d		;
reg data_parity			;
reg smc_rstn_d			;


assign smc_data = (!smc_data_en) ? smc_data_out  : 'bZ;
assign smc_data_in = smc_data;

assign D = 4'd1;
assign fi = 'b1010;


always @(D)
begin
 case(D)
    4'b0001: begin	di = 8'b00000001;   bit_shift = 0; end
    4'b0010: begin	di = 8'b00000010;   bit_shift = 1; end
    4'b0011: begin	di = 8'b00000100;   bit_shift = 2; end
    4'b0100: begin	di = 8'b00001000;   bit_shift = 3; end
    4'b0101: begin	di = 8'b00010000;   bit_shift = 4; end
    4'b0110: begin	di = 8'b00100000;   bit_shift = 5; end
    4'b1010: begin	di = 8'b10000010;   bit_shift = 1; end
    4'b1011: begin	di = 8'b10000100;   bit_shift = 2; end
    4'b1100: begin	di = 8'b10001000;   bit_shift = 3; end
    4'b1101: begin	di = 8'b10010000;   bit_shift = 4; end
    4'b1110: begin	di = 8'b10100000;   bit_shift = 5; end
    4'b1111: begin	di = 8'b11000000;   bit_shift = 6; end
    default: begin	di = 8'b00000001;   bit_shift = 0; end
 endcase
end

//generate F/D
always @(bit_shift or fi or di[7])
begin
    if (di[7])
	clk_num = (fi << bit_shift);
    else 
	clk_num = (fi >> bit_shift);
end

always @(posedge smc_clk or negedge smc_rstn)
begin
    if (!smc_rstn)
	smc_clk_cnt <= 1;
    else if (rx_start)
	smc_clk_cnt <= 1;
    else if (smc_clk_cnt == clk_num)
	smc_clk_cnt <= 1;
    else
	smc_clk_cnt <= smc_clk_cnt + 1;
end
	

always @(posedge smc_clk or negedge smc_rstn)
begin
    if (!smc_rstn)
    	smc_bit_en <= 1'b0;
    else if (smc_clk_cnt == clk_num)
    	smc_bit_en <= 1'b1;
    else
    	smc_bit_en <= 1'b0;
end

always @(posedge smc_clk or negedge smc_rstn)
begin
    if (!smc_rstn)
    	smc_half_bit_en <= 1'b0;
    else if (smc_clk_cnt == (clk_num >> 1))
    	smc_half_bit_en <= 1'b1;
   else
	smc_half_bit_en <= 1'b0;
end
			

always @(posedge smc_clk or negedge smc_rstn)
begin
    if (!smc_rstn)
	begin
	    rx_start <= 1'b0;
	    smc_data_in_d <= 1'b1;
	end
    else begin
	    smc_data_in_d <= smc_data_in;
	    if (~smc_data_in & smc_data_in_d & ((cur_state == RX_WAIT) || (cur_state == RESET_WAIT) || (cur_state == IDLE)))
		rx_start <= 1'b1;
	    else
		rx_start <= 1'b0;
	end
end

reg [15:0]reset_timer;
always @(posedge smc_clk or negedge smc_rstn)
begin
    if (!smc_rstn)
	reset_timer <= 0;
    else if (reset_timer !== 'hffff)
	reset_timer <= reset_timer + 1;
end
	
assign reset_resp_timeout = (reset_timer == 'H20);

always @(posedge smc_clk or negedge smc_rstn)
begin
    if (!smc_rstn)
	bit_cnt <= 'h0;
    else if (rx_start || tx_start)
	bit_cnt <= 'h0;
    else if (smc_bit_en)
	bit_cnt <= bit_cnt + 1;
end


always @(posedge smc_clk or negedge smc_rstn)
begin
    if (!smc_rstn)
	tx_start <= 1'b0;	    
    else if ((next_state == TX_START) && (cur_state != TX_START))
	tx_start <= 1'b1;
    else
	tx_start <= 1'b0;
end

wire smc_rstn_tmp;
assign #10000 smc_rstn_tmp = smc_rstn; 
always @(negedge smc_clk)
    smc_rstn_d <= smc_rstn_tmp;

assign trig_reset = ~smc_rstn & smc_rstn_d;


//state machine		
initial
    cur_state = DEACTIVE;

always @(posedge smc_clk)
    cur_state <= next_state;


always @(cur_state or rx_start or trig_reset or reset_resp_timeout or bit_cnt or smc_data_in)
begin
    next_state = cur_state;

    case(cur_state)
	IDLE: 
	    if (rx_start)
		next_state = RX_START;
	RESET:
	    if (smc_rstn)
		next_state = RESET_WAIT;
	RESET_WAIT:
	    if (reset_resp_timeout)
		next_state = TX_START;
	RX_START:
	    if (bit_cnt == 10)
		next_state = RX_PARITY;
	RX_PARITY:   
	    if (bit_cnt == 12)
		next_state = RX_WAIT;
	RX_WAIT:
	    next_state = IDLE;
	BLOCK_WAIT:
	    next_state = IDLE;
	TX_START:
	    if (bit_cnt == 10)
		next_state = TX_PARITY_CHECK;
	TX_PARITY_CHECK:
	    if (bit_cnt == 12) 
		next_state = TX_WAIT;
	TX_WAIT:
	    next_state = IDLE;
    endcase

    if (trig_reset)
	next_state = RESET;

end		
		
			
always @(posedge smc_clk or negedge smc_rstn)
begin
    if (!smc_rstn)
    	tx_shifter <= 8'b0;
    else if ((cur_state == TX_START) && smc_bit_en && (bit_cnt <= 8) && (bit_cnt != 0))
    	tx_shifter <= {tx_shifter[6:0],1'b0};
    else if (cur_state != TX_START)
	tx_shifter <= $random;
end


always @(posedge smc_clk or negedge smc_rstn)
begin
    if (!smc_rstn)
	begin
	    smc_data_out <= 'b1;
	    smc_data_en <= 'b1;
	end
    else if ((cur_state == IDLE) || (cur_state == RESET))
	begin
	    smc_data_en <= 1'b1;
	    smc_data_en <= 1'b1;
	end
    else begin
	    if ((cur_state == RX_PARITY) && smc_half_bit_en)
		begin
		    smc_data_en <= 1'b0; //parity signaling
		    smc_data_out <= ~data_parity;
		    if (!smc_data_en)
			smc_data_en <= 1'b1;
		end
	    else if ((cur_state == TX_START) && smc_bit_en)
		begin
		    if (bit_cnt == 0)
			begin
			    smc_data_out <= 'b0;
			    smc_data_en <= 'b0;
			end
		    else if (bit_cnt == 9)
			begin
			    smc_data_out <= data_parity;
			    smc_data_en <= 'b0;
			end
		    else
			begin
			    smc_data_out <= tx_shifter[7];
			    smc_data_en <= 'b0;
			end
		end			
	    else if ((cur_state == TX_WAIT) && smc_bit_en)
		begin
		    smc_data_out <= 'b1;
		    smc_data_en <= 'b0;
		end
	    else if ((cur_state == TX_PARITY_CHECK) && smc_bit_en)
		begin
		    smc_data_out <= 'b1;
		    smc_data_en <= 'b0;
		end
	end
end	

always @(posedge smc_clk or negedge smc_rstn)
begin
    if (!smc_rstn)
	data_parity <= 'b0;
    else if (rx_start | tx_start)
	data_parity <= 1'b0; 
    else if (smc_half_bit_en)
	begin
	    if ((cur_state == TX_START) && (bit_cnt != 0) && (bit_cnt <= 8))
		data_parity <= data_parity ^ tx_shifter[7];
	    else if ((cur_state == RX_START) && (bit_cnt != 0) && (bit_cnt <= 8))
		data_parity <= data_parity ^ smc_data_in;
	end
end
			

always @(posedge smc_clk or negedge smc_rstn)
begin
    if (!smc_rstn)
	rx_shifter <= 8'b0;
    else if ((cur_state == RX_START) && smc_half_bit_en && (bit_cnt != 0) && (bit_cnt != 9))
	rx_shifter <= {rx_shifter[6:0], smc_data_in};
    else if (cur_state != RX_START)
	rx_shifter <= 'h0;
end



endmodule

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
4438成人网| 亚洲欧美日韩在线不卡| 国产亚洲精品中文字幕| 亚洲欧美在线aaa| 日本不卡一二三区黄网| 国产91清纯白嫩初高中在线观看| 在线免费不卡电影| 国产欧美一区二区在线观看| 亚洲综合一区二区| 成人av综合一区| 日韩一区二区三区av| 亚洲同性同志一二三专区| 美女久久久精品| 欧美三级三级三级爽爽爽| 亚洲成人av一区| 成人小视频在线| 亚洲精品一线二线三线无人区| 亚洲免费观看高清完整版在线| 久久机这里只有精品| 91高清在线观看| 国产精品无码永久免费888| 青草国产精品久久久久久| 在线日韩一区二区| 国产精品网站导航| 国产高清一区日本| 日韩欧美在线影院| 天堂久久久久va久久久久| 色诱视频网站一区| 国产精品久久久久久久午夜片| 日本不卡视频在线观看| 91麻豆精品国产自产在线| 亚洲国产成人高清精品| 一本色道久久综合亚洲91| 国产精品美女久久久久aⅴ| 免费观看91视频大全| 在线不卡a资源高清| 亚洲成人三级小说| 欧美日韩一区二区在线观看视频| 亚洲欧美一区二区三区久本道91 | av资源网一区| 国产精品蜜臀av| 成人黄色免费短视频| 国产日本一区二区| 成人高清伦理免费影院在线观看| 国产清纯白嫩初高生在线观看91 | 欧美性受xxxx黑人xyx性爽| 亚洲日韩欧美一区二区在线| gogo大胆日本视频一区| 一区二区中文视频| 94-欧美-setu| 亚洲国产成人av| 91精品久久久久久久99蜜桃| 奇米888四色在线精品| 日韩精品一区国产麻豆| 精品一区二区三区免费播放 | 国产精品网站在线观看| 99精品久久免费看蜜臀剧情介绍| 国产精品麻豆久久久| 色综合一个色综合| 欧美羞羞免费网站| 日韩精品亚洲专区| 欧美精品一区二区三区蜜桃| 国产很黄免费观看久久| 中文字幕亚洲成人| 欧美日韩国产a| 国内精品国产成人| 亚洲欧洲www| 欧美日韩亚州综合| 久久超级碰视频| 国产精品大尺度| 欧美日韩亚洲国产综合| 国内一区二区视频| 亚洲色图欧美激情| 日韩三级免费观看| av动漫一区二区| 天天影视涩香欲综合网| 国产亚洲欧美一级| 精品视频免费看| 国内成人免费视频| 亚洲福利视频导航| 久久免费国产精品| 欧美色欧美亚洲另类二区| 国产综合一区二区| 亚洲精品成人天堂一二三| 日韩精品一区二区三区老鸭窝| av中文字幕不卡| 狠狠色丁香婷婷综合| 一二三四区精品视频| 国产婷婷色一区二区三区在线| 在线视频国内一区二区| 成人网在线播放| 美女视频黄频大全不卡视频在线播放| 国产精品网曝门| 日韩欧美色综合| 在线亚洲一区二区| 高清久久久久久| 免费视频一区二区| 亚洲一区影音先锋| 日本一区二区高清| 欧美成人一级视频| 4438x亚洲最大成人网| 99riav一区二区三区| 国产在线播放一区三区四| 丝袜美腿高跟呻吟高潮一区| 日韩理论片一区二区| 国产视频一区不卡| 久久一区二区视频| 精品国产人成亚洲区| 日韩丝袜美女视频| 日韩一区二区三区三四区视频在线观看| av网站一区二区三区| 成人app在线| 成人免费看片app下载| 国产精品一卡二| 国产一区在线观看视频| 久久疯狂做爰流白浆xx| 美腿丝袜亚洲综合| 日韩高清不卡在线| 青青青爽久久午夜综合久久午夜| 性久久久久久久久| 天堂va蜜桃一区二区三区漫画版| 亚洲一区二区高清| 亚洲不卡在线观看| 亚洲福利视频导航| 亚洲五月六月丁香激情| 亚洲精品免费在线观看| 精品国产一区二区亚洲人成毛片| 欧美日韩一二三区| 欧美精品一二三区| 欧美日韩在线综合| 在线观看免费视频综合| 97精品久久久久中文字幕| 成人的网站免费观看| 国产成人免费av在线| 久久精品999| 久久狠狠亚洲综合| 老司机精品视频导航| 国产剧情一区二区| 国内精品伊人久久久久av一坑| 美日韩一区二区三区| 免费人成网站在线观看欧美高清| 日韩**一区毛片| 日韩av在线发布| 美女一区二区视频| 久久不见久久见免费视频1| 奇米影视在线99精品| 国产激情视频一区二区在线观看| 黑人巨大精品欧美黑白配亚洲| 卡一卡二国产精品| 国产在线不卡一区| 国产成人午夜高潮毛片| 91免费版pro下载短视频| 国产.欧美.日韩| youjizz久久| 91麻豆视频网站| 欧美精品久久天天躁| 欧美成人aa大片| 国产精品区一区二区三| 久久九九久久九九| 亚洲一级二级三级在线免费观看| 偷拍一区二区三区四区| 久久国产生活片100| 久久国产精品露脸对白| 91免费精品国自产拍在线不卡| 欧美日韩精品一区二区在线播放| 91精品国产欧美日韩| 久久久久久久久久久久久女国产乱 | 日本一区二区三区四区在线视频| 国产亚洲欧美激情| 亚洲综合在线免费观看| 蜜臀av一区二区| 国产成人综合网站| 欧美一级欧美三级在线观看 | 色综合久久综合中文综合网| 欧美日韩国产美女| 中文字幕在线一区| 免费看欧美美女黄的网站| 成人美女在线观看| 欧美日韩国产高清一区| 亚洲美腿欧美偷拍| 激情五月播播久久久精品| 99re热视频精品| 日韩一本二本av| 亚瑟在线精品视频| 不卡的电视剧免费网站有什么| 欧美日韩国产中文| 国产精品动漫网站| 成人欧美一区二区三区视频网页| 国内久久精品视频| 91福利国产成人精品照片| 久久综合久色欧美综合狠狠| 亚洲靠逼com| 三级一区在线视频先锋| 99久久精品免费看| 久久免费国产精品| 麻豆精品在线视频| 在线观看网站黄不卡| 欧美经典一区二区三区| 久久国产精品一区二区| 欧美日韩一区高清|