安陆EGS20 SDRAM仿真

news2025/1/23 2:22:32

 

目录

一. 搭建仿真平台

二. 实现SDRAM连续写入1024个数据,然后再连续读出,并比较

1. 调试过程中问题:

2. 顶层代码

3. 功能代码 

三. SDRAM+FIFO实现上述功能调试

1. 代码设计要点

2. 仿真过程问题

 3. 上板运行调试

安陆反馈:


一. 搭建仿真平台

        EGS20这款IC内部集成了SDRAM,不需要硬件电路板再外部挂一个存储器。使用起来很方便。在代码设计时,可以在顶层直接调用其IP,就可以直接使用连接内部SDRAM。实际上板时不需要调用代码如下:

EG_PHY_SDRAM_2M_32 sdram(
		.clk(SDRAM_CLK),
		.ras_n(SDR_RAS),
		.cas_n(SDR_CAS),
		.we_n(SDR_WE),
		.addr(SDR_ADDR[10:0]),
		.ba(SDR_BA),
		.dq(SDR_DQ),
		.cs_n(1'b0),
		.dm0(SDR_DM[0]),
		.dm1(SDR_DM[1]),
		.dm2(SDR_DM[2]),
		.dm3(SDR_DM[3]),
		.cke(1'b1)
		);

                用Modelsim仿真时,可以在testbench文件中直接调用模拟SDRAM的IP核,就可以软件仿真SDRAM的读写过程了。代码如下:

IS42s32200 SDR1
    (
		.Clk ( SDRAM_CLK),
		.Cke ( SDRAM_CKE),
		.Cs_n ( 1'b0),
		.Ras_n ( SDRAM_RASn),
		.Cas_n ( SDRAM_CASn),
		.We_n ( SDRAM_WEn),
		.Ba ( SDRAM_BA),
		.Dqm ( SDRAM_DQM),
		.Addr ( SDRAM_ADDR),
		.Dq ( SDRAM_DQ)
    );   

        上面的文件IS42s32200需要与FAE联系获取。

二. 实现SDRAM连续写入1024个数据,然后再连续读出,并比较

1. 调试过程中问题:

1)连续读写SDRAM是否中间需要等待一段时间

       不需要,可以写完后直接读。

2)确认PLL的使用限制3)SDRAM的使用时钟限制

        使用100M时钟,相位180°。如图1,当写完立马开始读后,DQ的每4个数据的最后一个数据,在数据先上保留的时间比其他数据短,导致读到的数据不是4的倍数,发生错误。用高于100M以上的时钟,如200M,结果如图2,读到的数据不完整。

        使用75M时钟,50M时钟,相位180,读写正确。

        数据手册上显示,自带的SDRAM读写频率最高支持是200M,FAE反馈可能是自带的IS42s32200模型,读出的数据频率最高是75M 100M及以上会出错。

                                                                         图1

图2

仿真过程中Modelsim出现以下错误:

这个是时序警告,仿真用的模型IS42s32200 -3 最高只能跑到143MHz

        搭建硬件平台:在开发板上下载bit文件。相比仿真调试,需要将PLL的复位修改成正常的。同时需要调用EG_PHY_SDRAM_2M_3模块,将内置的SDRAM的接口给引出来。以下时运行实际效果,总体来说,需要调节相位,不同相位可能导致数据错位。

1)时钟100M,相位180°,调试结果OK;

2)时钟150M,相位180°,读SDRAM错误;

3)时钟50M,相位180°、70°、45°,读SDRAM错误;

4)时钟50M,相位225°、270°时,调试结果OK。

2. 顶层代码

`include "..\para.v"
`define SIMULATION 
module MotorControl(

    /*基准时钟及复位信号*/
    input     sys_clk,                        //系统时钟,25 MHz
    input     sys_rst_n,                    //复位信号,低电平有效
   
    `ifdef SIMULATION
        output                    SDRAM_CLK,
        output                    SDR_CKE,
        output                    SDR_RAS,
        output                    SDR_CAS,
        output                    SDR_WE,
        output    [`BA_WIDTH-1:0]    SDR_BA,
        output    [`ROW_WIDTH-1:0]SDR_ADDR,
        output    [`DM_WIDTH-1:0]    SDR_DM,
        inout    [`DATA_WIDTH-1:0]    SDR_DQ,    
    `endif
    
    input  key,                    //按键输入
 
    output error_led,                    //LED错误信号
    output work_led               //正常状态接口    
   
);
wire [`BA_WIDTH-1:0]    SDR_BA;
wire [`DM_WIDTH-1 :0]SDR_DM;
wire [`ROW_WIDTH-1:0]SDR_ADDR;
wire [`DATA_WIDTH-1:0]    SDR_DQ;

/*对于复位情况下的亚稳态,常常是由于恢复时间和移除时钟不满足造成的,
  因此,最常用的处理方式是采用异步复位、同步释放。常用电路模型如所示。
  采用第二级寄存器输出作为全局复位信号输出。*/

reg[1:0] rst_n_r;
wire rst_n;
wire clk_50m /* synthesis keep */;                    
wire clk_100m1 /* synthesis keep */;                    
wire clk_100m_75deg /* synthesis keep */;                         
wire clk_200m;
wire clk_locked_flag /* synthesis keep */;        //clk ready flag
    
/*消除亚稳态的复位信号*/
assign    rst_n = rst_n_r[1] & clk_locked_flag; // synthesis keep
always @(posedge sys_clk or negedge sys_rst_n)
begin
         if(!sys_rst_n) 
            rst_n_r <= 2'd0;
         else         
            rst_n_r <= {rst_n_r[0], 1'b1};
end
`ifdef SIMULATION     
reg [5:0] por_cnt=0;
wire reset;
always @(posedge sys_clk ) begin
    if  (por_cnt <30)     por_cnt<=por_cnt+1'b1;
    else por_cnt<=por_cnt;
    end
assign reset=(por_cnt==30)?1'b1:1'b0;   
`endif

PLL_50M    u_Pll_50M(
    .refclk( sys_clk ),
    `ifdef SIMULATION 
     .reset(~reset),
     `else
    .reset(~rst_n_r[1]), //PLL 高电平复位
    `endif
    .extlock( clk_locked_flag ),
    .clk0_out ( clk_50m ),   
    .clk1_out( clk_100m ),
    .clk2_out( clk_100m_75deg )
    //.clk3_out( clk_200m )
    
);

//按键
wire sdram_test_en;
wire wr_sdram_done,sdram_test_done;
ANJIAN ANJIAN(
    .clk(clk_100m),         //系统时钟
    .rst(rst_n),         //系统复位,低电平有效
     .key(key),                    //按键输入信号
     .sdram_test_done(sdram_test_done),
     .sdram_test_en(sdram_test_en)//按下案件后开始测试置1,测试结束或者等待时间结束重新置0
     );
//led指示灯模块
wire error_flag;
led led_top (
             .clk(clk_100m),  //1M clk
             .rst_n(rst_n),                  //系统复位,低电平有效
             .error_flag(error_flag),
             .work_led(work_led),
             .error_led(error_led)
);

    
/**********一:连续读写0x7FFFF深度的sdram地址区间***********/

wire [`DATA_WIDTH-1:0]    sdram_dout;                     //从sdram中读出的数据

wire sdram_wr_reqT, sdram_rd_reqT;
wire [`ADDR_WIDTH-1:0] sdram_wr_addrT;
wire [`ADDR_WIDTH-1:0] sdram_rd_addrT;
wire [`DATA_WIDTH-1:0] sdram_dinT;
wire [`DM_WIDTH-1:0] sdram_wr_dm;
wire sdram_init_ref_vld;
wire sdram_init_done; 
wire sdram_rd_en;
//wrd_sdram_page1 wrd_sdram_page_inst   //使用FIFO,连续读写1024个数据并比较
wrd_sdram_page u1_app   //连续读写1024个数据并比较
(
    .clk(clk_100m) ,    // input  clk_sig
    .rstn(rst_n) ,    // input  rstn_sig
    .sdram_init_done(sdram_init_done),
    .sdram_init_ref_vld(sdram_init_ref_vld),
    .sdram_wr_burst(1'b1), //写突发长度
    .sdram_rd_burst(1'b1), //读突发长度
//    .wr_max_addr(19'h7FFFF),  //结束地址
//    .wr_min_addr(19'd0),   //起始地址
    .sdram_test_en(sdram_test_en),
    .sdram_rd_data(sdram_dout) ,    // input [15:0] sdram_rd_data_sig
    .sdram_rd_en(sdram_rd_en),
    .sdram_rd_addr(sdram_rd_addrT),
    .sdram_wr_addr(sdram_wr_addrT) ,    // output [23:0] sdram_wr_addr_sig
    .sdram_wr_data(sdram_dinT) ,    // output [15:0] sdram_wr_data_sig
    .sdram_wr_req(sdram_wr_reqT) ,    // output  sdram_wr_req_sig
    .sdram_rd_req(sdram_rd_reqT) ,    // output  sdram_rd_req_sig
    .sdram_wr_dm(sdram_wr_dm),
    .rd_done(sdram_test_done),
    .error_flag(error_flag) //测试错误指示
);
    
//*******************安陆SDRAM例化************************//

sdr_as_ram  #( .self_refresh_open(1'b1))
    u2_ram( 
        .Sdr_clk(clk_100m),
        .Sdr_clk_sft(clk_100m_75deg),
        .Rst(!rst_n),
                            
        .Sdr_init_done(sdram_init_done),
        .Sdr_init_ref_vld(sdram_init_ref_vld), //刷新有效
        .Sdr_busy(),
        
        .App_ref_req(1'b0),
        
        .App_wr_en(sdram_wr_reqT), 
        .App_wr_addr(sdram_wr_addrT),      
        .App_wr_dm(4'd0),
        .App_wr_din(sdram_dinT),

        .App_rd_en(sdram_rd_reqT),
        .App_rd_addr(sdram_rd_addrT),
        .Sdr_rd_en    (sdram_rd_en), //读有效
        .Sdr_rd_dout(sdram_dout),
    
        .SDRAM_CLK(SDRAM_CLK),
        .SDR_RAS(SDR_RAS),
        .SDR_CAS(SDR_CAS),
        .SDR_WE(SDR_WE),
        .SDR_BA(SDR_BA),
        .SDR_ADDR(SDR_ADDR),
        .SDR_DM(SDR_DM),
        .SDR_DQ(SDR_DQ)    
    );
assign SDR_CKE=1'b1;
`ifndef SIMULATION
    EG_PHY_SDRAM_2M_32 sdram(
        .clk(SDRAM_CLK),
        .ras_n(SDR_RAS),
        .cas_n(SDR_CAS),
        .we_n(SDR_WE),
        .addr(SDR_ADDR[10:0]),
        .ba(SDR_BA),
        .dq(SDR_DQ),
        .cs_n(1'b0),
        .dm0(SDR_DM[0]),
        .dm1(SDR_DM[1]),
        .dm2(SDR_DM[2]),
        .dm3(SDR_DM[3]),
        .cke(1'b1)
        );
`endif  
endmodule
 

3. 功能代码 

/************************/
//测试SDRAM读写
//按键触发读写,连续写多个地址,再连续读,判断读写数据是否一致
//页突发模式,突发长度1

/***********************/
//`define   DATA_WIDTH                        32
//`define   ADDR_WIDTH                        21
//`define   DM_WIDTH                          4
//`define   ROW_WIDTH                        11
//`define   BA_WIDTH                        2
`include "E:\yanghaizhu\work\12.program_exchange\TD\1 SDRAM_TEST\rtl\para.v"
module wrd_sdram_page ( 
        input  clk,  
		input  rstn,
	    input sdram_init_done,
        input  sdram_init_ref_vld,
		input [9:0] sdram_wr_burst, //写突发长度
		input [9:0] sdram_rd_burst, //写突发长度
//		input [23:0]  wr_max_addr,  //结束地址
//		input [23:0]  wr_min_addr,  //起始地址
		input sdram_test_en,

		input  [`DATA_WIDTH-1:0] sdram_rd_data, //读入的数据
		input  sdram_rd_en, //实际读SDRAM数据时的使能信号
        	
        output  sdram_wr_req,  //写请求	
	 	output  [`ADDR_WIDTH-1:0] sdram_wr_addr, //写地址
		output  [`DATA_WIDTH-1:0] sdram_wr_data, //写数据
		
		output  sdram_rd_req,  //读请求
		output  [`ADDR_WIDTH-1:0] sdram_rd_addr,
        output [`DM_WIDTH-1:0]sdram_wr_dm,
		output reg rd_done,       //完成一次读写测试
		output reg error_flag
		 		 	    	 
 );
 

 assign sdram_wr_dm=4'b0;
//输入信号、数据寄存 
reg [`DATA_WIDTH-1:0] rd_data;
reg sdr_rd_en;
always @(posedge clk or negedge rstn) begin
    if(!rstn) 
	   begin
       	rd_data<=0;
        sdr_rd_en<=0;
        end
    else if (sdram_test_en)
       begin 
    	rd_data<=sdram_rd_data;
        sdr_rd_en<=sdram_rd_en;
       end
    else
      begin
       	rd_data<=0;
        sdr_rd_en<=0;
       end  
	end

//sdram写计数器
reg [15:0]wr_cnt;
always @(posedge clk or negedge rstn) begin
    if(!rstn) wr_cnt<=0; 
	else if(sdram_test_en)
    	if(sdram_init_done &(~sdram_init_ref_vld) &(wr_cnt<=16'd1023)) 
        	wr_cnt<=wr_cnt+1'b1;
        else  wr_cnt<=wr_cnt;
    else wr_cnt<=0; 
    end
//sdram写使能、写地址、写数据
reg wr_req;
reg [`ADDR_WIDTH-1:0]wr_addr,wr_addr_r;
reg [`DATA_WIDTH-1:0]wr_data;
assign sdram_wr_req=wr_req;
assign sdram_wr_addr=wr_addr_r;
assign sdram_wr_data=wr_data;
always @(posedge clk or negedge rstn) begin
    if(!rstn) 
	   begin
		  wr_req <= 0;
		  wr_addr <= 0;
		  wr_data <= 0;
		end
     else if(sdram_test_en)
     	if(sdram_init_done &(~sdram_init_ref_vld))
         	if(wr_cnt==16'd1024) wr_req <= 0;
            else if (wr_cnt<16'd1024) 
		 		begin	
		  			wr_req <= 1;
		    		wr_addr <= wr_addr + sdram_wr_burst;
		   			wr_data <= wr_data + 1;
	     		end
       		else 
     	        begin
     	  			wr_req <= wr_req;
		   			wr_addr <= wr_addr;
		   			wr_data <= wr_data;	
         		end
    	 else 
        	begin
		  		wr_req <= 0;
		  		wr_addr <= wr_addr;
		  		wr_data <= wr_data;
			end	
      else 
      	begin
          wr_req <= 0;
		  wr_addr <= 0;
		  wr_data <= 0;
        end
end	 
always @(posedge clk or negedge rstn) begin
    if(!rstn) wr_addr_r<=0;
    else wr_addr_r<=wr_addr;
    end
//写完成标志
reg wr_done,wr_done_r;
always @(posedge clk or negedge rstn) begin
    if(!rstn) wr_done<=0;
    else if(sdram_test_en)
    	if (wr_data==16'd1024) wr_done<=1;
       	else   wr_done<=wr_done;
    else wr_done<=0;
    end
always @(posedge clk or negedge rstn) begin
    if(!rstn) wr_done_r<=0;
    else wr_done_r<=wr_done;
    end
    
//开始读等待时间
reg [15:0]wait_cnt;
wire rd_begin;
assign rd_begin=(wait_cnt==16'd100)?1'b1:1'b0;
always @(posedge clk or negedge rstn) begin
    if(!rstn) wait_cnt<=0; 
	else if(sdram_test_en & wr_done_r) 
    	if (wait_cnt<16'd100) wait_cnt<=wait_cnt + 1'b1;
        else wait_cnt<=wait_cnt;
    else wait_cnt<=0;
    end
//读地址计数器
reg [15:0]rd_cnt;
always @(posedge clk or negedge rstn) begin
    if(!rstn) rd_cnt<=0; 
	else if(sdram_test_en)
    	if(rd_begin & (rd_cnt<=16'd1023)) 
          rd_cnt<=rd_cnt+1'b1;
    	else  rd_cnt<=rd_cnt;
    else rd_cnt<=0; 
    end
//读使能、读地址
reg rd_req;
reg [`ADDR_WIDTH-1:0]rd_addr,rd_addr_r;
assign sdram_rd_req=rd_req;
assign sdram_rd_addr=rd_addr_r;
always @(posedge clk or negedge rstn) begin
    if(!rstn) 
	   begin
		rd_req <= 0;
		rd_addr <= 0; 
       end 
     else if (sdram_test_en)
     	if(rd_begin & (~sdram_init_ref_vld)) 
         	if(rd_cnt==16'd1024) 
      	 		begin 
                    rd_req <= 0;
					rd_addr <= rd_addr; 
       			end
            else if(rd_cnt<=16'd1023) 
      	 		begin
        			rd_req <= 1;
					rd_addr <= rd_addr + sdram_rd_burst;  
       			end 
     		else 
      			begin
        			rd_req <= rd_req;
					rd_addr <= rd_addr;
       			end 
        else 
      		begin
        		rd_req <= 0;
				rd_addr <= rd_addr;
       		end
     else 
      	begin
        	rd_req <= 0;
			rd_addr <= 0;
       	end
     end
always @(posedge clk or negedge rstn) begin
    if(!rstn) rd_addr_r<=0;
    else rd_addr_r<=rd_addr;
    end
//读完成信号
always @(posedge clk or negedge rstn) begin
    if(!rstn)  rd_done<=0;
    else if (sdram_test_en)
    	if(rd_cnt==16'd1024)   rd_done<=1;
    	else rd_done<=rd_done;
    else rd_done<=0;
    end
//生成对比数据   
reg [15:0] init_data;
always @(posedge clk or negedge rstn) begin
    if(!rstn) init_data<=0;       
	else if(sdram_rd_en)  init_data<=init_data+1'b1; 
    else init_data<=init_data;
    end 
//出现错误,报保持error_led一直亮,直到复位      
always @(posedge clk or negedge rstn) begin
    if(!rstn) error_flag<=0;
	else if(sdr_rd_en)
    	if(init_data!=rd_data) error_flag<=1; 
    else error_flag<=error_flag;
    end

endmodule 

三. SDRAM+FIFO实现上述功能调试

1. 代码设计要点

1)FIFO例化;2)FIFO的读写时序;3)FIFO的满空标志的利用;4)FIFO与SDRAM之间的信号;

2. 仿真过程问题

1)代码出现如下bug:

         原因是调用文件绝对路径或者相对路径格式, `ifdef的使用及中间连线wire的定义。

2)出现如下图所示的数据线高阻态,可能是数据在该输入的时候没有数据输入。

3)从FIFO读出,数据会比请求信号延迟2个时钟。因此输入到SDRAM的请求信号需要比读FIFO的请求信号延迟2个时钟。 从SDRAM读出的数据,Sdr_rd_dout会比Sdr_rd_en延迟一个时钟,因此写入FIFO的写请求信号应该是Sdr_rd_en延迟一个时钟后的。(与后面的上版调试结果不同,上板调试Sdr_rd_dout和Sdr_rd_en是同时给出的。)

正确FIFO读写过程时序如下图所示:

a)往FIFO中写入数据,以及从FIFO中读出。(读出信号未找到)

b)从SDRAM读出数据SDR_DQ,sdr_as_ram传输实际可看到的读使能sdram_rd_en和数据Sdr_rd_out。将数据打拍后写入到FIFO:rd_fifo_req,rd_fifo_data。时序图如下:

读到的部分数据显示错误是因为安陆提供的硬件仿真文件BUG。实际上板跑没有问题。

 3. 上板运行调试

如下图所示,读到的结果与上面最终仿真出的结果时序有不一样,发生了一位错位。

代码是一样的,因此以实际板上跑的结果为准。

观察SDRAM的输入,如下图,输入是正确的

 输出如下:可以看到sdram_rd_en和数据Sdr_rd_data是同时给出的。(这里与上面的仿真结果不同。)

 因此,在仿真OK的情况下修改代码,将从SDRAM输出的sdram_rd_en和数据Sdr_rd_data都打一拍寄存输入给FIFO。上板调试结果OK,波形如下:

 关于时钟限制:

1)100M,相位180°,运行OK;

2)50M,相位225°、270°,运行OK。相位180°,运行NG;

3)150M,相位135°,运行OK。相位180°、225°,运行NG;

4)200M,相位180°、225°,运行NG;

安陆反馈:

       关于SDRAM输出的sdram_rd_en和数据Sdr_rd_data同时到还是数据延迟一个时钟到,安陆技术支持反馈说上板和用do文件仿真是同时到,用modelsim的phy仿真模型仿真是晚一个时钟到。

       关于时序,技术支持反馈如果使用的IP核是 FIFO是硬核,不需要进行时序约束。如果使用的是RAMFIFO是软核,需要进行时序约束,好像是两个信号线的路径不一致。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/468639.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

80%的人都关注的电子合同签署疑问,君子签官方解答来了!

电子合同签错了在平台可以撤回吗&#xff1f;如果合同上名字签错了&#xff0c;有法律效力吗&#xff1f;签的电子合同&#xff0c;内容会不会被别人看见&#xff1f;… 最近&#xff0c;小编将80%的人都关注的电子合同签署问题进行了整理&#xff0c;官方专业解答帮助大家更好…

mac真机调试h5攻略

原因&#xff1a; h5项目想在mac本通过chrome://inspect/#devices调试 &#xff08;win上调试h5很简单&#xff0c;请参考&#xff1a;chrome真机调试Android_chrome 调试安卓_芒果终结者的博客-CSDN博客&#xff09; 调试步骤&#xff1a; 1. 需要下载安装安卓开发工具and…

信息化发展

信息系统是&#xff1a;管理模型、信息处理模型和系统实现条件结合的 信息系统生命周期&#xff1a; 可行性分析与项目开发计划 需求分析 概要设计 详细设计 编码 测试 可以简化为&#xff1a; 系统规划&#xff1a;现行情况的分析&#xff0c;可行性研究报告 -> 设计任务…

Java笔记_13(集合进阶2)

Java笔记_13 一、双列集合1.1、Map的常见API1.2、Map遍历方式一&#xff08;键找值&#xff09;1.3、Map集合遍历方法二&#xff08;键值对&#xff09;1.4、Map集合遍历方法三&#xff08;lambda表达式&#xff09;1.5、HashMap1.6、HashMap练习1.7、HashMap底层源码解析1.7、…

12秒内AI在手机上完成作画!谷歌提出扩散模型推理加速新方法

本文源自&#xff1a;量子位 只需12秒&#xff0c;只凭手机自己的算力&#xff0c;就能拿Stable Diffusion生成一张图像。 而且是完成了20次迭代的那种。 要知道&#xff0c;现在的扩散模型基本都超过了10亿参数&#xff0c;想要快速生成一张图片&#xff0c;要么基于云计算&…

Python 实现txt、excel、csv文件读写【附源码】

目录 前言 一、txt文件读写 二、excel文件读写 总结 前言 本文介绍使用Python进行文件读写操作&#xff0c;包括txt文件、excel文件(xlsx、xls、csv) 编译器使用的是PyCharm 一、txt文件读写 read() # 一次性读取全部内容readline() # 读取第一…

K8s入门教程:10分钟带你速览全程

K8s&#xff0c;英文全称为Kubernetes&#xff0c;就是基于容器的集群管理平台&#xff0c;是用于自动部署、扩缩和管理容器化应用程序的开源系统。 K8s是用来干啥的&#xff1f; 简单来说&#xff0c;可以用一句话来解释&#xff1a;K8s的特点就是所有主机上都装上docker&…

Win10老是蓝屏收集错误信息重启无效怎么办?

Win10老是蓝屏收集错误信息重启无效怎么办&#xff1f;有用户遇到了电脑开机蓝屏的情况&#xff0c;收集错误信息重启电脑之后&#xff0c;依然无法解决问题。那么这个问题要怎么去进行解决呢&#xff1f;接下来我们来看看以下具体的处理方法教学吧。 准备工作&#xff1a; 1、…

JAVA:基于Redis 实现计数器限流

1、简述 在现实世界中可能会出现服务器被虚假请求轰炸的情况&#xff0c;因此您可能希望控制这种虚假的请求。 一些实际使用情形可能如下所示&#xff1a; API配额管理-作为提供者&#xff0c;您可能希望根据用户的付款情况限制向服务器发出API请求的速率。这可以在客户端或服…

Bing 性能是如何跟随 .NET 一起迭代的?

大约两年前&#xff0c;我发表了一篇文章&#xff0c;详细的介绍了 Bing 的中央工作流引擎(XAP)从 .NET Framework 升级到 .NET 5 的过程。你可以通过这篇文章来了解 XAP 的工作原理&#xff0c;以及它在 Bing 全局中的位置。从那时起&#xff0c;XAP 一直是微软许多搜索和工作…

mysql语句高级用法使用记录和sql_mode=only_full_group_by错误解决

最近工作时用到的几种用法记录一下 sql_modeonly_full_group_by 报错 sql出错示例如下 column ‘qnaq.ta.issue_org_code’ which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_modeonly_full_group_by 原因分析&#xff1a;…

云服务器使用jenkins+docker自动化部署SpringBoot项目

docker 安装jenkins&#xff0c;就这一步都恶心死了 //拉取镜像&#xff0c;踩了很多坑&#xff0c;用其它版本的镜像插件一直安装失败&#xff0c;最后用的是lts版本&#xff08;基础版&#xff09; 用其它版本要么是连不上插件的下载地址&#xff0c;要么是插件下载不成功 d…

Window10搭建GPU环境(CUDA、cuDNN)

一、查看CUDA版本 方法一&#xff0c;cmd命令 nvidia-smi下图的 CUDA 版本是11.7 方法二&#xff0c;点击 NVIDIA的图标 1.右键点击会出现nvidia 控制面板 或者 2.点击系统信息 3.点击组件 二.下载CUDA 到官网下载根据不同的版本 https://developer.nvidia.com/cud…

IU5180C升降压充电芯片特点及应用

IU5180C是一款完全集成的开关模式升降压充电管理IC&#xff0c;用于1~4节鲤离子电池和锂聚合物电池&#xff0c;以及1~5节磷酸铁锂电池。芯片集成包括4开关MOSFET、输入和充电电流感应电路、电池以及升降压转换器的环路补偿。芯片具有3A的充电电流能力&#xff0c;充电电流可以…

算法套路十三——动态规划DP

算法套路十三——动态规划DP 动态规划和递归都是通过将大问题分解为较小的子问题来解决问题。它们都可以用来解决具有重叠子问题和最优子结构特性的问题。在很多情况下&#xff0c;动态规划算法的设计可以从递归算法开始&#xff0c;然后通过添加记忆化&#xff08;Memoizatio…

Java on Azure Tooling 3月更新|Azure Event Hubs 支持、Azure Functions 模板增强及日志流改进

作者&#xff1a;Jialuo Gan - Program Manager, Developer Division at Microsoft 排版&#xff1a;Alan Wang 大家好&#xff0c;欢迎来到 Java on Azure Tooling 的3月更新。在这次更新中&#xff0c;我们将介绍 Azure Event Hubs 支持、Azure Functions 的模板增强&#xf…

力扣sql中等篇练习(十四)

力扣sql中等篇练习(十四) 1 最后一个能进入电梯的人 1.1 题目内容 1.1.1 基本题目信息 1.1.2 示例输入输出 1.2 示例sql语句 # 在表某一个范围内的可以考虑自连接的方式,注意连接的表只需要精准的字段 # 需要排序是因为它需要找到最后一个上车的用户 SELECT q1.person_name…

SCA有什么作用?软件成分分析(SCA)技术详解

软件成分分析&#xff08;SCA&#xff09;是一种用来识别分析某一个软件中所使用的组件与第三方库的来源、版本、许可证信息的技术。这些组件和库可能来源于开源社区、商业供应商或是企业自行开发&#xff0c;其存在很多潜在的安全合规问题。 软件成分分析工具&#xff08;SCA工…

都23年了你还记得渐进式框架是什么意思吗

vue 文章目录 vue前言一、眼见为实举个栗子二、渐进式的优势 前言 渐进式框架是一种能够逐步增强应用功能的框架&#xff0c;它允许开发者在不影响应用性能的情况下&#xff0c;逐步添加新的功能和特性。Vue.js提供了一些基础功能&#xff0c;如数据绑定和组件化&#xff0c;然…

软件测试---BUG的生命周期

测试人员最本质的工作就是寻找bug&#xff0c;提交bug、验证bug、推进bug的解决&#xff0c;直至软件达到发布的标准&#xff0c;提高软件的质量&#xff0c;及研发的工作效率和质量。 一、什么是bug 软件的BUG,狭义概念是指软件程序的漏洞或缺陷&#xff0c;广义概念除此之外…