OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 2832|回复: 2

STM32F103+OV7670+FIFO问题

[复制链接]

2

主题

2

帖子

0

精华

新手上路

积分
43
金钱
43
注册时间
2016-6-23
在线时间
10 小时
发表于 2016-10-11 19:47:31 | 显示全部楼层 |阅读模式
1金钱
我先看的别人的代码,看到大概是这样一个流程,先初始化OV7670,再通过同步帧VSYNC来触发中断读取数据。我基本就是在别人的代码上作的修改,初始化也成功了,可VSYNC就是没信号输出,导致一直无法触发中断。
我的理解是,如果初始化成功了,FIFO就应该有数据,那么VSYNC也应该会有电平变化。不知道有没有大神帮忙解释一下。

int main (void)
{
        SystemInit();
        SysTick_Init();
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO, ENABLE);
        GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable,ENABLE);
        PB_GPIO_Init();
       
    GPIO_SetBits(GPIOB, GPIO_Pin_15);
        LCD_init( );       
    Lcd_Clear(0x001F);
        Delay(3);
        disp_hz(100,100,initok,0x001F,0xFFFF,0);
       
        FIFO_Set_GPIO_Config();
        FIFO_GPIO_INPUT();
        FIFO_CS_L();//×¼±¸¶áêy¾Y
        FIFO_WE_H();
        while(1!= (Sensor_init())){}//3õê¼»ˉCMOS Sensor
        Lcd_SetWindow(0,0,319,239);
        bn=0;
        ////////////////////////////////////////
  FIFO_RRST_L();
  FIFO_RD_L();
  FIFO_RD_H();
  FIFO_RD_L();
  FIFO_RRST_H();
  FIFO_RD_H();
  Delay_us(5000);
////////////////////////////////////////
  while(1)
  {

    if(bn==2)
    {
      LCD_open_windows(0,0,320,240);
                          //LCD_WR_CMD(0x03,0x1018);
                         LCD_WR_REG(0x2c);//×¼±¸D′GRAM
        FIFO_RRST_L();
        FIFO_RD_L();
        FIFO_RD_H();
        FIFO_RD_L();
        FIFO_RRST_H();
        FIFO_RD_H();
        for(a=0;a<9600;a++)
        {

             FIFO_RD_L();
             c_data=GPIOB->IDR&0xff00;//&#182;á&#184;&#223;&#206;&#187;
             FIFO_RD_H();
             FIFO_RD_L();
             c_data|=(GPIOB->IDR>>8)&0x00ff;//&#182;áμí&#206;&#187;
             FIFO_RD_H();  
            // LCD_WriteRAM(c_data);//D′RGBêy&#190;Yμ&#189;TFT GRAM
             LCD_WR_Data(c_data);

             FIFO_RD_L();
             c_data=GPIOB->IDR&0xff00;//&#182;á&#184;&#223;&#206;&#187;
             FIFO_RD_H();
             FIFO_RD_L();
             c_data|=(GPIOB->IDR>>8)&0x00ff;//&#182;áμí&#206;&#187;
             FIFO_RD_H();  
            // LCD_WriteRAM(c_data);//D′RGBêy&#190;Yμ&#189;TFT GRAM
           LCD_WR_Data(c_data);

             FIFO_RD_L();
             c_data=GPIOB->IDR&0xff00;//&#182;á&#184;&#223;&#206;&#187;
             FIFO_RD_H();
             FIFO_RD_L();
             c_data|=(GPIOB->IDR>>8)&0x00ff;//&#182;áμí&#206;&#187;
             FIFO_RD_H();  
            // LCD_WriteRAM(c_data);//D′RGBêy&#190;Yμ&#189;TFT GRAM
              LCD_WR_Data(c_data);

             FIFO_RD_L();
             c_data=GPIOB->IDR&0xff00;//&#182;á&#184;&#223;&#206;&#187;
             FIFO_RD_H();
             FIFO_RD_L();
             c_data|=(GPIOB->IDR>>8)&0x00ff;//&#182;áμí&#206;&#187;
             FIFO_RD_H();  
            // LCD_WriteRAM(c_data);//D′RGBêy&#190;Yμ&#189;TFT GRAM
              LCD_WR_Data(c_data);

             FIFO_RD_L();
             c_data=GPIOB->IDR&0xff00;//&#182;á&#184;&#223;&#206;&#187;
             FIFO_RD_H();
             FIFO_RD_L();
             c_data|=(GPIOB->IDR>>8)&0x00ff;//&#182;áμí&#206;&#187;
             FIFO_RD_H();  
            // LCD_WriteRAM(c_data);//D′RGBêy&#190;Yμ&#189;TFT GRAM
             LCD_WR_Data(c_data);

             FIFO_RD_L();
             c_data=GPIOB->IDR&0xff00;//&#182;á&#184;&#223;&#206;&#187;
             FIFO_RD_H();
             FIFO_RD_L();
             c_data|=(GPIOB->IDR>>8)&0x00ff;//&#182;áμí&#206;&#187;
             FIFO_RD_H();  
            // LCD_WriteRAM(c_data);//D′RGBêy&#190;Yμ&#189;TFT GRAM
             LCD_WR_Data(c_data);

             FIFO_RD_L();
             c_data=GPIOB->IDR&0xff00;//&#182;á&#184;&#223;&#206;&#187;
             FIFO_RD_H();
             FIFO_RD_L();
             c_data|=(GPIOB->IDR>>8)&0x00ff;//&#182;áμí&#206;&#187;
             FIFO_RD_H();  
            // LCD_WriteRAM(c_data);//D′RGBêy&#190;Yμ&#189;TFT GRAM
             LCD_WR_Data(c_data);

             FIFO_RD_L(); ;
             c_data=GPIOB->IDR&0xff00;//&#182;á&#184;&#223;&#206;&#187;
             FIFO_RD_H();
             FIFO_RD_L();
             c_data|=(GPIOB->IDR>>8)&0x00ff;//&#182;áμí&#206;&#187;
             FIFO_RD_H();  
            // LCD_WriteRAM(c_data);//D′RGBêy&#190;Yμ&#189;TFT GRAM
              LCD_WR_Data(c_data);

         }
         bn=0;
       }
     }
}


unsigned char Sensor_init(void)
{
        unsigned char temp;
       
        unsigned int i=0;
         XCLK_init_ON();//??MCO?? ?????CMOS???
        //uchar ovidmsb=0,ovidlsb=0;
        Sensor_GPIO_Init();
        SCCB_GPIO_Config();//io init..

        temp=0x80;
        if(0==wr_Sensor_Reg(0x12, temp)) //Reset SCCB
        {
          return 0 ;//????
        }
        Delay(10);
        if(0==rd_Sensor_Reg(0x0b, &temp))//?ID
        {
                return 0 ;//????
        }

         if(temp==0x73)//OV7670
         {
           for(i=0;i<OV7670_REG_NUM;i++)
           {
                if( 0==wr_Sensor_Reg(OV7670_reg[i][0],OV7670_reg[i][1]))
                {
                        return 0;//????
                }
                }
             
        }
        else if(temp==0x21)//OV7725
        {
           for(i=0;i<OV7725_REG_NUM;i++)
           {
                if( 0==wr_Sensor_Reg(OV7725_reg[i][0],OV7725_reg[i][1]))
                {
                        return 0;//????
                }
           }
       
        }

        return 0x01; //ok

}



最佳答案

查看完整内容[请看2#楼]

7670都没初始化,有数据才怪。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2016-10-11 19:47:32 | 显示全部楼层
7670都没初始化,有数据才怪。
回复

使用道具 举报

34

主题

127

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1067
金钱
1067
注册时间
2012-1-7
在线时间
157 小时
发表于 2016-12-20 16:40:04 | 显示全部楼层
请问解决了吗?我的初始化了OV7670也是没有帧同步信号的
回复

使用道具 举报

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

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-5-26 08:43

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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