always @ (posedge lcd_pclk or negedge rst_n) begin
if (!rst_n) begin
lcd_bl <= 1'b1;
lcd_rst <= 1'b1;
lcd_de <= 1'b0;
end else begin
lcd_bl <= 1'b1;
lcd_rst <= 1'b1;
lcd_de <= 1'b0;
end
end
//行场信号的启动边沿是同时动作的
//行计数器对像素时钟计数
always@ (posedge lcd_pclk or negedge rst_n) begin
if(!rst_n)
h_cnt <= 11'd0;
else begin
if(h_cnt == H_TOTAL_7016 - 1'b1)
h_cnt <= 11'd0;
else
h_cnt <= h_cnt + 1'b1;
end
end
//场计数器对行计数
always@ (posedge lcd_pclk or negedge rst_n) begin
if(!rst_n)
v_cnt <= 11'd0;
else begin
if(h_cnt == H_TOTAL_7016 - 1'b1) begin
if(v_cnt == V_TOTAL_7016 - 1'b1)
v_cnt <= 11'd0;
else
v_cnt <= v_cnt + 1'b1;
end
end
end
always @ (posedge lcd_pclk or negedge rst_n) begin
if (!rst_n) begin
lcd_hs <= 1'b1;
end else if( h_cnt == ( H_TOTAL_7016 - 1 ) ) begin
lcd_hs <= 1'b0;
end else if( h_cnt == ( H_SYNC_7016 - 1 ) ) begin
lcd_hs <= 1'b1;
end
end
always @ (posedge lcd_pclk or negedge rst_n) begin
if (!rst_n) begin
lcd_vs <= 1'b1;
end else if( (v_cnt == ( V_TOTAL_7016 - 1 ))&&( h_cnt == H_TOTAL_7016 - 1'b1 ) ) begin
lcd_vs <= 1'b0;
end else if( v_cnt == ( V_SYNC_7016 - 1 )&&( h_cnt == H_TOTAL_7016 - 1'b1 ) ) begin
lcd_vs <= 1'b1;
end
end