当前位置: 首页 > news >正文

想要个网站如何做网站客户端

想要个网站,如何做网站客户端,搜索引擎推广有哪些平台,做论坛网站用什么系统1.引言 此驱动程序已经完成很久了,花了2个星期的时间,主要是提升程序运行的效率。最近整理文件的时候又看到了,记录一下。 2.程序框架分解 module adc7254_Ctrl(input sys_clk, //system clkc 50Minput re…

1.引言

此驱动程序已经完成很久了,花了2个星期的时间,主要是提升程序运行的效率。最近整理文件的时候又看到了,记录一下。

2.程序框架分解

module adc7254_Ctrl(input               sys_clk,    //system clkc 50Minput               reset_n,    //reset flaginput               iData_a_in,      //ADC to fpga input               iData_b_in, output               sclk_out,   //to ADC output              cs_out,     //to ADC  output              sdin,    //to ADCoutput 		 [11:0]	oData_a, //get dataoutput		 [11:0]	oData_b	//get data
);
wire clk_200M;                   //PLL驱动
AD_PLL AD_PLL_inst(.inclk0(sys_clk),.c0(Clk_200M),.c1(sclk_out)
);
wire En_conv,En_send;            //定义ADC发送和接收程序的状态切换时间
adc_test adc_test_inst(.iRst_n(reset_n),.iDclk(sclk_out),.iSend_down(Send_down),.oAdc_rst_n(adc_rst_n),.oEn_conv(En_conv),.oEn_send(En_send)
);
wire Send_down;                   //ADC指令发送部分
adc_in_send adc_in_send_inst
(.iClk_200M(Clk_200M),.iRst_n(adc_rst_n),.iDcLK(sclk_out),.iEn_send(En_send),.oSDATA(sdin),.oSend_down(Send_down)
); 
wire Conv_down;
adc_out_conv adc_out_conv_inst				//ADC数据采样部分
(.iClk_200M		( Clk_200M  	    ),.iRst_n		   ( adc_rst_n 	 ),.iEn_conv		( En_conv 		),.iDcLK			( sclk_out 		),.iData_a_in		( iData_a_in 	),.iData_b_in		( iData_b_in 	),.oData_a		( oData_a	 	),	.oData_b		( oData_b 		),.oConv_down     ( Conv_down     )
);
assign cs_out = Conv_down & Send_down;       //状态完成
endmodule

3.子任务分解

(1)状态控制程序

其主要是以空状态,写状态,读状态三个状态顺序执行的。

module adc_test(input iRst_n,input iDclk,input iSend_down,output oAdc_rst_n,output reg oEn_send,output reg oEn_conv
);reg [1:0] state;
reg [5:0] sclk_cnt;
localparam state_IDLE  = 2'd0;
localparam state_Write = 2'd1;
localparam state_Read  = 2'd3;assign oAdc_rst_n = (iRst_n & state);
always @(posedge iDclk or negedge iRst_n) beginif(!iRst_n)beginsclk_cnt <= 6'd0;state <= state_IDLE;oEn_conv = 1'd0;oEn_send = 1'd0;  end else begin   case(state)state_IDLE:beginif (sclk_cnt > 6'd30 ) beginsclk_cnt <= 6'd0;state <= state_Write;oEn_conv = 1'd0;oEn_send = 1'd1;end else beginsclk_cnt <= sclk_cnt + 1'd1;state <= state_IDLE; oEn_conv = 1'd0;oEn_send = 1'd0;   end    endstate_Write:beginif (iSend_down == 1'd1 && sclk_cnt > 6'd30 ) beginsclk_cnt <= 0;state <= state_Read;oEn_conv = 1'd1;oEn_send = 1'd0;end else beginsclk_cnt <= sclk_cnt + 1'd1;state <= state_Write;oEn_conv = 1'd0;oEn_send = 1'd1;endendstate_Read:beginstate <= state_Read;sclk_cnt <= 1'd0;oEn_conv = 1'd1;oEn_send = 1'd0;endendcaseend
endendmodule

(2)写命令程序部分

module adc_in_send(input iClk_200M,     //200Minput iRst_n,input iDcLK,    //最小T>60ns input iEn_send,	 output  oSDATA,output oSend_down     );//==================使能接收标志位en==================////一旦启动不会突然停止除非复位信号到来reg en;reg [5:0] sclk_cnt;always @(posedge iDcLK or negedge iRst_n ) beginif (!iRst_n) beginen <= 1'd0;sclk_cnt <= 6'd0;end else if ( iEn_send == 1'd1 && sclk_cnt == 6'd0 ) beginen <= 1'd1;sclk_cnt <= 6'd32;end else if ( sclk_cnt > 6'd1 ) beginen <= en;sclk_cnt <= sclk_cnt - 1'd1;end else if (oSend_down == 1'd1 && sclk_cnt == 6'd1 ) beginen <= 1'd0;sclk_cnt <= sclk_cnt - 1'd1;end else beginen <= en;sclk_cnt <= sclk_cnt;endend
//==================使能接收标志位en==================//
//==================SDATA输出操作=========================//
reg [15:0]CFR_16bit_data = 16'h8840;	//需要写入寄存器中的数据
assign oSDATA = (en > 1'd0) ? ((sclk_cnt > 6'd17) ? CFR_16bit_data[sclk_cnt-6'd17] : 0 ): 0;
//==================SDATA操作=========================//
//==================oSend_down操作======================//
assign oSend_down = (sclk_cnt > 6'd1) ? 0 : 1;
//==================oSend_down操作======================//
endmodule

(3)读数据程序部分

module adc_out_conv(input iClk_200M,     //200Minput iRst_n,input iData_a_in,input iData_b_in,  input iDcLK,    //最小T=60ns input iEn_conv,output reg [11:0] oData_a,output reg [11:0] oData_b,output  oConv_down     //T>70ns);
//下降沿接收
//==================使能接收标志位en==================//
//一旦启动不会突然停止除非复位信号到来
reg en;//接收使能标志位
reg [5:0] sclk_cnt;
always @(posedge iDcLK or negedge iRst_n ) beginif (!iRst_n) beginen <= 1'd0;sclk_cnt <= 5'd0;end else if (iEn_conv == 1'd1   &&  sclk_cnt == 4'd0) beginen <= 1'd1;sclk_cnt <= 6'd17;end else if (sclk_cnt > 4'd1) beginen <= en;sclk_cnt  <= sclk_cnt - 1'd1;end else if (oConv_down == 1'd1 &&  sclk_cnt == 4'd1)beginen <= 1'd0;sclk_cnt <= sclk_cnt - 1'd1;end else beginen <= en;sclk_cnt <= sclk_cnt;end
end
//==================使能接收标志位en==================//
//==================dclk时钟采样==================//
reg	[6:0] dclk;
always@(posedge iClk_200M or negedge iRst_n) beginif(!iRst_n) begindclk <= 7'd0;end	else if(!en) begindclk <= 7'd0;end  else begindclk <= {dclk[5:0],iDcLK};endend
//==================dclk时钟采样==================//
//==================状态切换==================//reg [1:0] state;parameter state_IDLE = 2'd0;parameter state_Read = 2'd1;parameter state_Write = 2'd2;always@(posedge iClk_200M or negedge iRst_n)  beginif(!iRst_n ) beginstate <= state_IDLE;end else if(!en) beginstate <= state_IDLE;end else if(dclk[1] == 1 & dclk[2] == 0) beginstate <= state_Read;end else if (dclk[1] == 0 & dclk[2] == 1) beginstate <= state_Write;end else beginstate <=state;end            end
//==================状态切换==================//
//==================data串行转并行==================//
reg [2:0] Data_a_in_temp,Data_b_in_temp;//保证7次采样有4次为1
reg [11:0]  Data_a_temp,Data_b_temp;
always@(posedge iClk_200M or negedge iRst_n)
beginif(!iRst_n ) beginData_a_temp    <= 12'd0;Data_b_temp    <= 12'd0;Data_a_in_temp <= 3'd0;Data_b_in_temp <= 3'd0;end else if(sclk_cnt > 6'd16)beginData_a_in_temp <= 3'd0;Data_b_in_temp <= 3'd0;Data_a_temp    <= 12'd0;Data_b_temp    <= 12'd0;end else if(sclk_cnt > 6'd3 ) beginif(state == state_Read && dclk[6] == 0 ) beginData_a_in_temp <= Data_a_in_temp + iData_a_in;Data_b_in_temp <= Data_b_in_temp + iData_b_in;Data_a_temp    <= Data_a_temp;Data_b_temp    <= Data_b_temp;end else if(state == state_Write && dclk[0]!=dclk[1])beginData_a_in_temp <= 3'd0;Data_b_in_temp <= 3'd0;Data_a_temp    <= {Data_a_temp[10:0],Data_a_in_temp[2]};Data_b_temp    <= {Data_b_temp[10:0],Data_b_in_temp[2]};end else beginData_a_in_temp <= Data_a_in_temp;Data_b_in_temp <= Data_b_in_temp;Data_a_temp    <= Data_a_temp;Data_b_temp    <= Data_b_temp;endend else beginData_a_in_temp <= Data_a_in_temp;Data_b_in_temp <= Data_b_in_temp;Data_a_temp    <= Data_a_temp;Data_b_temp    <= Data_b_temp;end
end
//==================data串行转并行==================//
//==================oConv_down操作======================//
assign oConv_down = (sclk_cnt > 6'd1) ? 0 : 1;
//==================oConv_down操作======================//
//==================数据按帧输出==================//
always@(posedge iClk_200M or negedge iRst_n)
beginif(!iRst_n )beginoData_a <= 12'd0;oData_b <= 12'd0;endelse if( oConv_down == 1'd1)beginoData_a <= Data_a_temp;oData_b <= Data_b_temp;endelsebeginoData_a <= oData_a;oData_b <= oData_b;end
end
//==================数据按帧输出==================//
endmodule

http://www.yayakq.cn/news/155626/

相关文章:

  • 做房地产用什么网站好滁州新手跨境电商建站哪家好
  • 简洁网站布局软件开发模型有哪些各有什么特点
  • 外国男男做暧暧视频网站wordpress快递主题
  • 开发公司代收业主契税如何记账上海优化外包公司
  • 为什么找不到做网站的软件网站开发一般有那些语言
  • 做音频的网站襄阳网站建设知名品牌
  • 编程的网站都有哪些网站如何做企业电子宣传册
  • 禅城教育网站建站电子商务网站建设基本组成
  • 成都网站建设技巧免费的站外推广
  • 网站虚拟主机费用cpanel wordpress
  • 外国做袜子的网站免费的图片做视频在线观看网站
  • 在那些免费网站做宣传效果好免费下载网站软件
  • 做响应式网站的菜单栏动漫制作教学
  • 网站流量与广告费深圳本地网站建设
  • 珠海高端网站开发我们公司在做网站推广
  • 房地产的设计网站建设ps做网站一般用多大字体
  • 旅游网站建设的概念做生意网站
  • 360网站建设服务公司门户最新版下载
  • php网站后台入口网站设计背景怎么写
  • 图书馆网站结构怎么做做网站的空间是啥
  • 长沙 做营销型网站的公司怎样做自己的微商网站
  • 湘潭网站建设 电话磐石网络小型企业网站建设旅游景点网论文
  • 2015网站建设网站优化方式
  • 医疗器械为什么做网站企业查重名
  • 电子商务网站开发问题研究建网站推广淘宝店
  • 苏州书生商友专业做网站做网站后期怎么维护
  • 有没有专门做ppt的网站吗国外网站空间 月付
  • 网站营销推广临沂专业做网站
  • 网站不交换友情链接可以吗成立公司代理
  • 不要验证码的广告网站xp 做网站服务器吗