芯路恒电子技术论坛

 找回密码
 立即注册
热搜: 合集
查看: 19071|回复: 5

【更新0412】小梅哥OV7670摄像头适配的工程实例和使用说明

[复制链接]
  • TA的每日心情
    慵懒
    2021-2-24 10:16
  • 431

    主题

    818

    帖子

    1万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    16150
    QQ
    发表于 2019-4-10 23:32:05 | 显示全部楼层 |阅读模式
    2019年4月10日
    OV7670_SDRAM_VGA

    ov7670_sdram_vga.rar (131.21 KB, 下载次数: 1109)
    一、功能说明:
    ov7670_sdram_vga工程实现了FPGA采集OV7670CMOS摄像头的图像数据,存储到SDRAM,并经由VGA显示在VGA显示器上的功能。

    二、适配板卡:
    该工程支持小梅哥的众多FPGA开发板,包括AC620AC609以及红色经典(Starter)开发板。

    三、配置文件:
    在工程文件夹内,提供了一个名为sof的文件夹,该文件夹下存放了可以直接下载到对应的硬件板卡中查看实验现象的FPGA配置文件(.sof),连接好GM7123VGA模块和OV7670摄像头,下载对应的sof文件到开发板中。就能在VGA显示器上查看到实时的摄像头采集图像了。

    四、引脚分配脚本:
    另外在工程文件夹内,提供了一个名为tcl的文件夹,该文件夹下存放了针对每个FPGA开发板的引脚分配脚本,当用户需要基于某个具体的板卡进行调试时,只需要在Quartus软件中依次点击tools -》 tcl scripts,然后选中对应板卡的tcl文件,点击run按钮即可完成引脚更新。


    2019年4月12日
    OV7670_SDRAM_Display

    ov7670_sdram_display.rar (254.98 KB, 下载次数: 1186)
    在上一版ov7670_sdram_vga工程的基础上,进行了进一步的修改,实现支持VGA(640*480分辨率)、4.3寸TFT显示屏(480*272分辨率)、5寸触摸TFT显示屏(800*480)分辨率,继续支持AC620、AC609、Starter开发板。

    应用说明:
    一、模式配置:
    为了一个工程能够同时支持多个板卡(AC620AC609以及红色经典(Starter),以及每个板卡能够支持多种显示设备(VGA、4.3寸屏、5寸屏),在显示设备驱动设计时,使用了一个配置文件,名为“disp_parameter_cfg.v”,该文件中提供了3个可选择的预定义项:

    1、显示设备类型:
    1. `define HW_TFT
    2. //`define HW_VGA
    复制代码

    这两项主要定义硬件输出设备是使用VGA(GM7123 VGA输出模块)还是使用TFT显示屏(4.3、5寸屏),使用哪种硬件,就将对应的定义取消注释,以使其生效,而另一项通过注释的方式屏蔽。该定义主要在“disp_driver.v”文件的60~68行左右位置生效,为了调整显示设备的输出像素时钟相位,VGA输出时需要把控制器时钟取反输出,才能正常工作,否则会花屏,而TFT屏则不能取反,因此采用条件编译的方式实现。


    2、显示设备颜色模式
    1. `define MODE_RGB888
    2. //`define MODE_RGB565
    复制代码

    这两项主要定义硬件输出设备使用的颜色模式,从硬件设计上来讲,GM7123型VGA 输出模块设计的是24位色RGB888模式,而4.3寸和5寸显示屏使用的是16位色RGB565模式。本意是使用哪种硬件,就选择对应的颜色输出模式,但是发现这样会给工程的可移植性增加很多麻烦,因此在实际使用时,一律使用24位色RGB888模式,对于不同硬件的颜色位数的适配,放到了引脚分配时候完成,如果是VGA,则Red、Green、Blue三个颜色每个8位都分配指定引脚;如果是TFT,则将Red[7:3]、Green[7:2]、Blue[7:3]分别分配给TFT屏的Red[7:3]、Green[7:2]、Blue[7:3],剩余信号不再指定管脚。
    因此,在实际使用时,该项参数固定为选择MODE_RGB888

    3、分辨率设定
    VGA输出为640*480分辨率、4.3寸TFT显示屏480*272分辨率、5寸触摸TFT显示屏800*480分辨率,当选择不同的硬件时,显示设备驱动所需要采用的时序参数也是不一样的,因此通过分辨率设定选项来指定不同的参数。
    1. `define Resolution_480x272 1        //时钟为9MHz
    2. //`define Resolution_640x480 1        //时钟为25.175MHz
    3. //`define Resolution_800x480 1        //时钟为33MHz
    4. //`define Resolution_800x600 1        //时钟为40MHz
    5. //`define Resolution_1024x768 1        //时钟为65MHz
    6. //`define Resolution_1280x720 1        //时钟为74.25MHz
    7. //`define Resolution_1920x1080 1        //时钟为148.5MHz
    复制代码

    4.3寸屏就使能Resolution_480x272、5寸屏就使能Resolution_800x480、VGA就使能Resolution_640x480。该参数有多个地方生效
    第1个地方就是在本文件中,根据不同的分辨率选择,定义每个分辨率对应的时序参数,代码如下
    1. //定义不同分辨率的时序参数
    2. `ifdef Resolution_480x272
    3.         `define H_Total_Time  12'd525
    4.         `define H_Right_Border  12'd0
    5.         `define H_Front_Porch  12'd2
    6.         `define H_Sync_Time  12'd41
    7.         `define H_Back_Porch  12'd2
    8.         `define H_Left_Border  12'd0

    9.         `define V_Total_Time  12'd286
    10.         `define V_Bottom_Border  12'd0
    11.         `define V_Front_Porch  12'd2
    12.         `define V_Sync_Time  12'd10
    13.         `define V_Back_Porch  12'd2
    14.         `define V_Top_Border  12'd0
    15.         
    16. `elsif Resolution_640x480
    17.         `define H_Total_Time  12'd800
    18.         `define H_Right_Border  12'd8
    19.         `define H_Front_Porch  12'd8
    20.         `define H_Sync_Time  12'd96
    21.         `define H_Back_Porch  12'd40
    22.         `define H_Left_Border  12'd8

    23.         `define V_Total_Time  12'd525
    24.         `define V_Bottom_Border  12'd8
    25.         `define V_Front_Porch  12'd2
    26.         `define V_Sync_Time  12'd2
    27.         `define V_Back_Porch  12'd25
    28.         `define V_Top_Border  12'd8

    29. `elsif Resolution_800x480
    30.         `define H_Total_Time 12'd1056
    31.         `define H_Right_Border 12'd0
    32.         `define H_Front_Porch 12'd40
    33.         `define H_Sync_Time 12'd128
    34.         `define H_Back_Porch 12'd88
    35.         `define H_Left_Border 12'd0

    36.         `define V_Total_Time 12'd525
    37.         `define V_Bottom_Border 12'd8
    38.         `define V_Front_Porch 12'd2
    39.         `define V_Sync_Time 12'd2
    40.         `define V_Back_Porch 12'd25
    41.         `define V_Top_Border 12'd8

    42. `elsif Resolution_800x600
    43.         `define H_Total_Time 12'd1056
    44.         `define H_Right_Border 12'd0
    45.         `define H_Front_Porch 12'd40
    46.         `define H_Sync_Time 12'd128
    47.         `define H_Back_Porch 12'd88
    48.         `define H_Left_Border 12'd0

    49.         `define V_Total_Time 12'd628
    50.         `define V_Bottom_Border 12'd0
    51.         `define V_Front_Porch 12'd1
    52.         `define V_Sync_Time 12'd4
    53.         `define V_Back_Porch 12'd23
    54.         `define V_Top_Border 12'd0

    55. `elsif Resolution_1024x768
    56.         `define H_Total_Time 12'd1344
    57.         `define H_Right_Border 12'd0
    58.         `define H_Front_Porch 12'd24
    59.         `define H_Sync_Time 12'd136
    60.         `define H_Back_Porch 12'd160
    61.         `define H_Left_Border 12'd0

    62.         `define V_Total_Time 12'd806
    63.         `define V_Bottom_Border 12'd0
    64.         `define V_Front_Porch 12'd3
    65.         `define V_Sync_Time 12'd6
    66.         `define V_Back_Porch 12'd29
    67.         `define V_Top_Border 12'd0

    68. `elsif Resolution_1280x720
    69.         `define H_Total_Time 12'd1650
    70.         `define H_Right_Border 12'd0
    71.         `define H_Front_Porch 12'd110
    72.         `define H_Sync_Time 12'd40
    73.         `define H_Back_Porch 12'd220
    74.         `define H_Left_Border 12'd0

    75.         `define V_Total_Time 12'd750
    76.         `define V_Bottom_Border 12'd0
    77.         `define V_Front_Porch 12'd5
    78.         `define V_Sync_Time 12'd5
    79.         `define V_Back_Porch 12'd20
    80.         `define V_Top_Border 12'd0
    81.                
    82. `elsif Resolution_1920x1080
    83.         `define H_Total_Time 12'd2200
    84.         `define H_Right_Border 12'd0
    85.         `define H_Front_Porch 12'd88
    86.         `define H_Sync_Time 12'd44
    87.         `define H_Back_Porch 12'd148
    88.         `define H_Left_Border 12'd0

    89.         `define V_Total_Time 12'd1125
    90.         `define V_Bottom_Border 12'd0
    91.         `define V_Front_Porch 12'd4
    92.         `define V_Sync_Time 12'd5
    93.         `define V_Back_Porch 12'd36
    94.         `define V_Top_Border 12'd0        
    95.         
    96. `endif
    复制代码

    第2个地方在“ov7670_sdram_display.v”文件,也就是工程顶层中,大约75~80行,根据不同的分辨率设置写入到SDRAM中的图像的长宽尺寸,代码如下所示:

    1.         `ifdef Resolution_480x272
    2.                 parameter IMG_WIDTH = 480;
    3.                 parameter IMG_HIGHT = 272;
    4.         `else
    5.                 parameter IMG_WIDTH = 640;
    6.                 parameter IMG_HIGHT = 480;        
    7.         `endif        

    复制代码


    第3个地方也在“ov7670_sdram_display.v”文件,也就是工程顶层中,大约153~165行,进一步参数化设计,指定CMOS图像采集模块输出采集到的整幅图像的那一个区域。该选项主要是考虑到OV7670摄像头输出的图像大小固定为640*480像素,而4.3寸屏的分辨率只有480*272像素,所以通过设置CMOS图像采集模块仅输出640*480图像的正中心的480*272个像素的数据出来存入SDRAM,以实现图像裁剪的功能。该条件编译代码如下所示:

    1.         CMOS_Capture_RGB565        
    2.         #(
    3.                 .CMOS_FRAME_WAITCNT                (4'd10),                                //Wait n fps for steady(OmniVision need 10 Frame)
    4.         `ifdef Resolution_480x272
    5.                 .OUTIMG_HSTART                (12'd79),                //实际输出图像的宽度起始像素
    6.                 .OUTIMG_HSTOP                (12'd559),                //实际输出图像的宽度结束像素
    7.                 .OUTIMG_VSTART                (12'd103),                //实际输出图像的高度起始像素
    8.                 .OUTIMG_VSTOP                (12'd375)                //实际输出图像的高度结束像素
    9.         `else
    10.                 .OUTIMG_HSTART                (12'd0),                        //实际输出图像的宽度起始像素
    11.                 .OUTIMG_HSTOP                (12'd640),                //实际输出图像的宽度结束像素
    12.                 .OUTIMG_VSTART                (12'd0),                        //实际输出图像的高度起始像素
    13.                 .OUTIMG_VSTOP                (12'd480)                //实际输出图像的高度结束像素               
    14.         `endif        
    15.         )

    复制代码


    第4个地方还是在“ov7670_sdram_display.v”文件中,大约273~290行
    因为OV7670的输出分辨率为640*480,而5寸显示屏的分辨率为800*480,也就是说,5寸屏的行像素比OV7670的输出图像行像素多160个像素,因此,根据像素一一对应的关系,显示屏必然有160*480个像素区域没有实际图像像素与之对应,为了正常显示,可以将这个区域分成两部分,左右各80*480个像素,采用黑色填充,这样640*480的图像就会显示在5寸屏的正中心位置。该部分代码如下所示:

    1.         //定义不同分辨率时输出数据的选择情况
    2. `ifdef Resolution_800x480
    3.         assign Disp_Red = disp_req?Disp_Red_r : 8'd0;
    4.         assign Disp_Green = disp_req? Disp_Green_r : 8'd0;
    5.         assign Disp_Blue = disp_req? Disp_Blue_r : 8'd0;        
    6.         
    7.         always@(posedge ClkDisp)
    8.                 disp_req <= (DataReq && (H_Addr > 79) && (H_Addr < 720));
    9.         
    10.         assign RD_Req = disp_req;
    11.         
    12. `else
    13.         assign Disp_Red = Disp_Red_r;
    14.         assign Disp_Green = Disp_Green_r;
    15.         assign Disp_Blue = Disp_Blue_r;        
    16.         
    17.         assign RD_Req = DataReq;        
    18. `endif

    复制代码


    基本上几个设计要点就解释清楚了。再有什么内容,后面再补充吧。

    2019年4月22日
    修改了下,加入了对OV7725摄像头的支持,因此文件名称也改为了通配型的ov7xxx,不再特指某个具体型号,同时,将条件编译开关独立写在sys_cfg.v文件中,不再放在显示屏的参数配置文件里了,体现分层思想。
    ov7xxx_sdram_display.rar (188.74 KB, 下载次数: 871)

    回复

    使用道具 举报

  • TA的每日心情
    慵懒
    2021-2-24 10:16
  • 431

    主题

    818

    帖子

    1万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    16150
    QQ
     楼主| 发表于 2019-4-13 23:22:50 | 显示全部楼层
    适配VGA模块一定要通过翻转像素时钟来解决吗?不,一定不是这样的,一定是哪里没有做好,比如。。。。。IO的时序约束。

    emmmmm,说干就干,看了下GM7123的数据手册,建立时间0.8ns,保持时间1.5ns,emmmm,这个参数非常的常规,根本不用翻转时钟,所以,一定是没加IO约束,让Quartus随心所欲,结果搞砸了导致的。那么,开干,加上约束后,就真的解决了问题耶。以下为时序约束的内容


    1. ## Generated SDC file "ov7670_sdram_display.sdc"

    2. ## Copyright (C) 1991-2013 Altera Corporation
    3. ## Your use of Altera Corporation's design tools, logic functions
    4. ## and other software and tools, and its AMPP partner logic
    5. ## functions, and any output files from any of the foregoing
    6. ## (including device programming or simulation files), and any
    7. ## associated documentation or information are expressly subject
    8. ## to the terms and conditions of the Altera Program License
    9. ## Subscription Agreement, Altera MegaCore Function License
    10. ## Agreement, or other applicable license agreement, including,
    11. ## without limitation, that your use is for the sole purpose of
    12. ## programming logic devices manufactured by Altera and sold by
    13. ## Altera or its authorized distributors.  Please refer to the
    14. ## applicable agreement for further details.


    15. ## VENDOR  "Altera"
    16. ## PROGRAM "Quartus II"
    17. ## VERSION "Version 13.0.0 Build 156 04/24/2013 SJ Full Version"

    18. ## DATE    "Sat Apr 13 21:27:43 2019"

    19. ##
    20. ## DEVICE  "EP4CE10F17C8"
    21. ##


    22. #**************************************************************
    23. # Time Information
    24. #**************************************************************

    25. set_time_format -unit ns -decimal_places 3



    26. #**************************************************************
    27. # Create Clock
    28. #**************************************************************

    29. create_clock -name {clk50} -period 20.000 -waveform { 0.000 10.000 } [get_ports {clk}]
    30. create_clock -name {pclk} -period 46.667 -waveform { 0.000 23.333 } [get_ports {cmos_pclk}]


    31. #**************************************************************
    32. # Create Generated Clock
    33. #**************************************************************

    34. create_generated_clock -name {pll|altpll_component|auto_generated|pll1|clk[0]} -source [get_pins {pll|altpll_component|auto_generated|pll1|inclk[0]}] -duty_cycle 50.000 -multiply_by 2 -master_clock {clk50} [get_pins {pll|altpll_component|auto_generated|pll1|clk[0]}]
    35. create_generated_clock -name {pll|altpll_component|auto_generated|pll1|clk[1]} -source [get_pins {pll|altpll_component|auto_generated|pll1|inclk[0]}] -duty_cycle 50.000 -multiply_by 2 -phase -90.000 -master_clock {clk50} [get_pins {pll|altpll_component|auto_generated|pll1|clk[1]}]
    36. create_generated_clock -name {pll|altpll_component|auto_generated|pll1|clk[2]} -source [get_pins {pll|altpll_component|auto_generated|pll1|inclk[0]}] -duty_cycle 50.000 -multiply_by 12 -divide_by 25 -master_clock {clk50} [get_pins {pll|altpll_component|auto_generated|pll1|clk[2]}]
    37. create_generated_clock -name {pll|altpll_component|auto_generated|pll1|clk[3]} -source [get_pins {pll|altpll_component|auto_generated|pll1|inclk[0]}] -duty_cycle 50.000 -multiply_by 12 -divide_by 25 -master_clock {clk50} [get_pins {pll|altpll_component|auto_generated|pll1|clk[3]}]
    38. create_generated_clock -name {Clk_TFT} -source [get_pins {pll|altpll_component|auto_generated|pll1|clk[3]}] -master_clock {pll|altpll_component|auto_generated|pll1|clk[3]} [get_ports {Disp_PCLK}]


    39. #**************************************************************
    40. # Set Clock Latency
    41. #**************************************************************



    42. #**************************************************************
    43. # Set Clock Uncertainty
    44. #**************************************************************



    45. #**************************************************************
    46. # Set Input Delay
    47. #**************************************************************

    48. set_input_delay -add_delay -max -clock [get_clocks {pclk}]  26.667 [get_ports {cmos_data[0]}]
    49. set_input_delay -add_delay -min -clock [get_clocks {pclk}]  8.000 [get_ports {cmos_data[0]}]
    50. set_input_delay -add_delay -max -clock [get_clocks {pclk}]  26.667 [get_ports {cmos_data[1]}]
    51. set_input_delay -add_delay -min -clock [get_clocks {pclk}]  8.000 [get_ports {cmos_data[1]}]
    52. set_input_delay -add_delay -max -clock [get_clocks {pclk}]  26.667 [get_ports {cmos_data[2]}]
    53. set_input_delay -add_delay -min -clock [get_clocks {pclk}]  8.000 [get_ports {cmos_data[2]}]
    54. set_input_delay -add_delay -max -clock [get_clocks {pclk}]  26.667 [get_ports {cmos_data[3]}]
    55. set_input_delay -add_delay -min -clock [get_clocks {pclk}]  8.000 [get_ports {cmos_data[3]}]
    56. set_input_delay -add_delay -max -clock [get_clocks {pclk}]  26.667 [get_ports {cmos_data[4]}]
    57. set_input_delay -add_delay -min -clock [get_clocks {pclk}]  8.000 [get_ports {cmos_data[4]}]
    58. set_input_delay -add_delay -max -clock [get_clocks {pclk}]  26.667 [get_ports {cmos_data[5]}]
    59. set_input_delay -add_delay -min -clock [get_clocks {pclk}]  8.000 [get_ports {cmos_data[5]}]
    60. set_input_delay -add_delay -max -clock [get_clocks {pclk}]  26.667 [get_ports {cmos_data[6]}]
    61. set_input_delay -add_delay -min -clock [get_clocks {pclk}]  8.000 [get_ports {cmos_data[6]}]
    62. set_input_delay -add_delay -max -clock [get_clocks {pclk}]  26.667 [get_ports {cmos_data[7]}]
    63. set_input_delay -add_delay -min -clock [get_clocks {pclk}]  8.000 [get_ports {cmos_data[7]}]
    64. set_input_delay -add_delay -max -clock [get_clocks {pclk}]  26.667 [get_ports {cmos_href}]
    65. set_input_delay -add_delay -min -clock [get_clocks {pclk}]  8.000 [get_ports {cmos_href}]
    66. set_input_delay -add_delay -max -clock [get_clocks {pclk}]  26.667 [get_ports {cmos_vsync}]
    67. set_input_delay -add_delay -min -clock [get_clocks {pclk}]  8.000 [get_ports {cmos_vsync}]


    68. #**************************************************************
    69. # Set Output Delay
    70. #**************************************************************

    71. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_Blue[0]}]
    72. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_Blue[0]}]
    73. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_Blue[1]}]
    74. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_Blue[1]}]
    75. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_Blue[2]}]
    76. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_Blue[2]}]
    77. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_Blue[3]}]
    78. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_Blue[3]}]
    79. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_Blue[4]}]
    80. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_Blue[4]}]
    81. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_Blue[5]}]
    82. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_Blue[5]}]
    83. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_Blue[6]}]
    84. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_Blue[6]}]
    85. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_Blue[7]}]
    86. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_Blue[7]}]
    87. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_DE}]
    88. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_DE}]
    89. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_Green[0]}]
    90. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_Green[0]}]
    91. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_Green[1]}]
    92. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_Green[1]}]
    93. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_Green[2]}]
    94. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_Green[2]}]
    95. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_Green[3]}]
    96. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_Green[3]}]
    97. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_Green[4]}]
    98. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_Green[4]}]
    99. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_Green[5]}]
    100. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_Green[5]}]
    101. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_Green[6]}]
    102. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_Green[6]}]
    103. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_Green[7]}]
    104. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_Green[7]}]
    105. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_HS}]
    106. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_HS}]
    107. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_Red[0]}]
    108. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_Red[0]}]
    109. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_Red[1]}]
    110. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_Red[1]}]
    111. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_Red[2]}]
    112. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_Red[2]}]
    113. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_Red[3]}]
    114. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_Red[3]}]
    115. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_Red[4]}]
    116. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_Red[4]}]
    117. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_Red[5]}]
    118. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_Red[5]}]
    119. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_Red[6]}]
    120. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_Red[6]}]
    121. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_Red[7]}]
    122. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_Red[7]}]
    123. set_output_delay -add_delay -max -clock [get_clocks {Clk_TFT}]  0.200 [get_ports {Disp_VS}]
    124. set_output_delay -add_delay -min -clock [get_clocks {Clk_TFT}]  -1.500 [get_ports {Disp_VS}]


    125. #**************************************************************
    126. # Set Clock Groups
    127. #**************************************************************



    128. #**************************************************************
    129. # Set False Path
    130. #**************************************************************

    131. set_false_path -from [get_keepers {*rdptr_g*}] -to [get_keepers {*ws_dgrp|dffpipe_qe9:dffpipe16|dffe17a*}]
    132. set_false_path -from [get_keepers {*delayed_wrptr_g*}] -to [get_keepers {*rs_dgwp|dffpipe_pe9:dffpipe13|dffe14a*}]
    133. set_false_path -from [get_keepers {*rdptr_g*}] -to [get_keepers {*ws_dgrp|dffpipe_se9:dffpipe9|dffe10a*}]
    134. set_false_path -from [get_keepers {*delayed_wrptr_g*}] -to [get_keepers {*rs_dgwp|dffpipe_re9:dffpipe6|dffe7a*}]


    135. #**************************************************************
    136. # Set Multicycle Path
    137. #**************************************************************



    138. #**************************************************************
    139. # Set Maximum Delay
    140. #**************************************************************



    141. #**************************************************************
    142. # Set Minimum Delay
    143. #**************************************************************



    144. #**************************************************************
    145. # Set Input Transition
    146. #**************************************************************


    复制代码
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    慵懒
    2021-2-24 10:16
  • 431

    主题

    818

    帖子

    1万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    16150
    QQ
     楼主| 发表于 2019-4-22 23:08:19 | 显示全部楼层
    camera_sdram_display.rar (60.42 KB, 下载次数: 858)
    终于把一个大坑填完了,显示屏有好几种规格,摄像头也是,总共有9中硬件搭配,每个搭配都得提供至少一个应用工程,一旦哪天在某个地方有了更优化的设计方案,一次性得改最少9个工程,这还只是针对一个板卡的,如果要同时支持AC620、AC609、Starter的话,任务量再乘以三,一旦有个优化改动,就得修改27个工程文件,太痛苦了,所以直接做了个通杀工程,一个工程通杀所有配置。




    /*************【使用说明】***************************

    1、本工程可以通过简单的设置适配各种不同的硬件搭配,包括:

            --【OV7670】摄像头 + 【4.3寸/5寸/VGA输出】显示屏
            --【OV7725】摄像头 + 【4.3寸/5寸/VGA输出】显示屏
            --【OV5640】摄像头 + 【4.3寸/5寸/VGA输出】显示屏
    ---------------------------------------------------

    2、具体用户使用哪种硬件,在sys_cfg.v文件中,通过取消代码注
       释的方式使能该选项,总共有两个选项需要选择:

            --使用的的摄像头型号(OV7670、OV7725、OV5640)
            --使用的的显示设备型号(HW_TFT43、HW_TFT50、HW_VGA)
    ---------------------------------------------------

    3、本工程提供了三款FPGA开发板的引脚分配脚本文件,在工程目
       录的tcl文件夹下,支持AC620、AC609、Starter开发板,使
            用时请根据具体使用的FPGA硬件平台,先在引脚分配界面中删
            除所有引脚分配位置后,再在Quartus软件中运行对应板卡和
            对应显示设备的tcl脚本文件以完成引脚分配。每个板卡提供了
            2个脚本文件,分别为使用GM7123模块的VGA输出方式和使用
            4.3/5寸显示屏(两个屏引脚分配完全一样)的引脚分配,用户
            需要根据自己实际使用的硬件,选择相应的tcl脚本运行
    */


    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    擦汗
    2019-8-12 22:29
  • 5

    主题

    12

    帖子

    138

    积分

    初级会员

    Rank: 3Rank: 3

    积分
    138
    发表于 2019-6-20 09:58:27 | 显示全部楼层
    关于2019年4月12日OV7670_SDRAM_Display工程使用中遇到的问题:
    1、工程默认为4.3寸TFTLCD显示设备+OV7670,使用时硬件配置使用AC620+OV7670+4.3寸LCD显示屏幕(均为小梅哥店铺产品)
    2、编译器为Quartus 17.1
    3、压缩文件解压后对工程进行了一次全编译,Quartus提示IP需要升级
    4、编译完成后,PLL模块的clock_2,clock_3输出时钟均被设置为24M,(按照工程和代码注释,clock_3为LCD的驱动时钟,TFT模式下应该为9M)
    5、下载后LCD显示无图像
    6、PLL中无法通过设置分频出9MHZ的时钟
    希望小梅哥有时间解答一下
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    慵懒
    2021-2-24 10:16
  • 431

    主题

    818

    帖子

    1万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    16150
    QQ
     楼主| 发表于 2019-6-20 10:23:52 | 显示全部楼层
    萌萌的_X29uk 发表于 2019-6-20 09:58
    关于2019年4月12日OV7670_SDRAM_Display工程使用中遇到的问题:
    1、工程默认为4.3寸TFTLCD显示设备+OV7670 ...

    1、clock2和clock3都是24M,这没问题,因为LCD的时钟即使不准也能显示,不过就是帧率的变化,而VGA的时钟必须是准确的24M,所以为了兼容性统一设置的24M。
    2、下载后LCD无法显示,请检查你的引脚分配。使用对应的tcl文件重新执行一次
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2020-4-12 23:08
  • 0

    主题

    1

    帖子

    69

    积分

    初级会员

    Rank: 3Rank: 3

    积分
    69
    发表于 2019-9-6 16:01:43 | 显示全部楼层
    请问一下,有这方面相关的视频或文档吗
    回复 支持 反对

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|小黑屋|Archiver|芯路恒电子技术论坛 |鄂ICP备2021003648号

    GMT+8, 2024-12-22 19:50 , Processed in 0.078746 second(s), 37 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc. Template By 【未来科技】【 www.wekei.cn 】

    快速回复 返回顶部 返回列表