OpenEdv-开源电子网

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

定时器捕获触发DMA传输io口的数据到定义的数组

[复制链接]

3

主题

18

帖子

0

精华

新手上路

积分
38
金钱
38
注册时间
2017-7-14
在线时间
9 小时
发表于 2017-7-17 09:57:00 | 显示全部楼层 |阅读模式
5金钱
1,想通过定时器捕获一个上升沿后触发DMA将IO口(pc0~7)的数据存入一个数组中,看过原子哥以前写的一个程序,但是移植后并没有实现该功能,现在一直在调。希望原子哥和网友们给点建议。
现在的现象是:1.debug调试,配置都是OK的但是就是没有进行传输,试过m2m,和外设到内存都没用,求原子大哥和广大网友相助。



正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

0

主题

145

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
366
金钱
366
注册时间
2017-6-19
在线时间
55 小时
发表于 2017-7-17 10:51:05 | 显示全部楼层
贴码、不知道你怎么配的
回复

使用道具 举报

3

主题

18

帖子

0

精华

新手上路

积分
38
金钱
38
注册时间
2017-7-14
在线时间
9 小时
 楼主| 发表于 2017-7-17 15:41:37 | 显示全部楼层
void TIM4_Init(void)
{
       
        TIM_ICInitTypeDef  TIM4_ICInitStructure;
        GPIO_InitTypeDef GPIO_InitStructure;


        RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM4, ENABLE);        //ê1ÄüTIM4ê±Öó
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);  //ê1ÄüGPIOBê±Öó
       
        GPIO_InitStructure.GPIO_Pin  = GPIO_Pin_7;  //PB7 Çå3y֮ǰéèÖà 
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPD; //PB7 êäèë  
        GPIO_Init(GPIOB, &GPIO_InitStructure);
        GPIO_ResetBits(GPIOB,GPIO_Pin_7);                                                 //PB7 ÏÂà-
       
        //3õê¼»ˉ¶¨ê±Æ÷4 TIM4
  
          //3õê¼»ˉTIM4êäèë2¶»ñ2Îêy
          TIM4_ICInitStructure.TIM_Channel = TIM_Channel_2; //CC1S=01         Ñ¡Ôñêäèë¶Ë IC2ó3éäμ½TI2éÏ
          TIM4_ICInitStructure.TIM_ICPolarity = TIM_ICPolarity_Rising;        //éÏéyÑØ2¶»ñ
          TIM4_ICInitStructure.TIM_ICSelection = TIM_ICSelection_DirectTI; //ó3éäμ½TI2éÏ
          TIM4_ICInitStructure.TIM_ICPrescaler = TIM_ICPSC_DIV1;         //ÅäÖÃêäèë·ÖÆμ,2»·ÖÆμ
          TIM4_ICInitStructure.TIM_ICFilter = 0x00;//IC1F=0000 ÅäÖÃêäèëÂË2¨Æ÷ 2»ÂË2¨
          TIM_ICInit(TIM4, &TIM4_ICInitStructure);
       
                 TIM_Cmd(TIM4,ENABLE );
        }
回复

使用道具 举报

3

主题

18

帖子

0

精华

新手上路

积分
38
金钱
38
注册时间
2017-7-14
在线时间
9 小时
 楼主| 发表于 2017-7-17 15:43:01 | 显示全部楼层
jokeym 发表于 2017-7-17 10:51
贴码、不知道你怎么配的

void MYDMA_Config(DMA_Channel_TypeDef* DMA_CHx,u32 cpar,u32 cmar,u16 cndtr)
{
        RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);        //ê1ÄüDMA′«êä
       
  DMA_DeInit(DMA_CHx);   //½«DMAμÄí¨μà1¼Ä′æÆ÷ÖØéèÎaè±ê¡Öμ

        DMA1_MEM_LEN=cndtr;
        DMA_InitStructure.DMA_PeripheralBaseAddr = cpar;  //DMAíaéè»ùμØÖ·
        DMA_InitStructure.DMA_MemoryBaseAddr = cmar;  //DMAÄú′æ»ùμØÖ·
        DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;  //êy¾Y′«êä·½Ïò£¬′óíaéè¶áè¡·¢Ëíμ½Äú′æ
        DMA_InitStructure.DMA_BufferSize = cndtr;  //DMAí¨μàμÄDMA»o′æμÄ′óD¡
        DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;  //íaéèμØÖ·¼Ä′æÆ÷2»±ä
        DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;  //Äú′æμØÖ·¼Ä′æÆ÷μYÔö
        DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_Word;  //êy¾Y¿í¶èÎa8λ
        DMA_InitStructure.DMA_MemoryDataSize = DMA_PeripheralDataSize_Word; //êy¾Y¿í¶èÎa8λ
        DMA_InitStructure.DMA_Mode = DMA_Mode_Normal;  //1¤×÷ÔúÕy3£Ä£ê½
        DMA_InitStructure.DMA_Priority = DMA_Priority_Medium; //DMAí¨μà xóμóDÖDóÅÏ輶
        DMA_InitStructure.DMA_M2M = DMA_M2M_Enable;  //DMAí¨μàxûóDéèÖÃÎaÄú′æμ½Äú′æ′«êä
        DMA_Init(DMA_CHx, &DMA_InitStructure);  //¸
        DMA_ITConfig(DMA1_Channel4,DMA_IT_TC,ENABLE);
       
  NVIC_InitStructure.NVIC_IRQChannel = DMA1_Channel4_IRQn;                        //ê1Äü°′¼üËùÔúμÄía2¿ÖD¶Ïí¨μà
  NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;        //ÇàÕ¼óÅÏ輶0
  NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;                                        //×óóÅÏ輶0
  NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;                                                                //ê1Äüía2¿ÖD¶Ïí¨μà
  NVIC_Init(&NVIC_InitStructure);            //¸ù¾YNVIC_InitStructÖDÖ¸¶¨μÄ2Îêy3õê¼»ˉíaéèNVIC¼Ä′æÆ÷          
}
//¿aÆôò»′ÎDMA′«êä

void DMA1_Channel4_IRQHandler(void)
{
    if(DMA_GetITStatus(DMA1_IT_TC2))
    {
                          HREF_Cnt++;
                        if(HREF_Cnt!=59)
                                {
            MYDMA_Enable(DMA1_Channel4);
                                }
        DMA_ClearITPendingBit(DMA1_IT_GL4); //
                          LED1=!LED1;
               
   
}
}
void MYDMA_Enable(DMA_Channel_TypeDef*DMA_CHx)
{
        DMA_Cmd(DMA_CHx, DISABLE );  //1رÕTIM4 êäèë2¶»ñ2 DMA1 ËùÖ¸ê¾μÄí¨μà      
        DMA_SetCurrDataCounter(DMA_CHx,DMA1_MEM_LEN);//DMAí¨μàμÄDMA»o′æμÄ′óD¡
        DMA_Cmd(DMA_CHx, ENABLE);  //ê1ÄüTIM4 êäèë2¶»ñ2 ËùÖ¸ê¾μÄí¨μà
}          
          MYDMA_Config(DMA1_Channel4,(u32)&GPIOC->IDR,(u32)OV7620_BUF[HREF_Cnt],1);
回复

使用道具 举报

0

主题

145

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
366
金钱
366
注册时间
2017-6-19
在线时间
55 小时
发表于 2017-7-17 16:32:13 | 显示全部楼层
寄存器的飘过、这库函数看着头痛……
回复

使用道具 举报

0

主题

145

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
366
金钱
366
注册时间
2017-6-19
在线时间
55 小时
发表于 2017-7-17 17:01:26 | 显示全部楼层
没清中断标志位吧
回复

使用道具 举报

3

主题

18

帖子

0

精华

新手上路

积分
38
金钱
38
注册时间
2017-7-14
在线时间
9 小时
 楼主| 发表于 2017-7-19 12:52:22 | 显示全部楼层
jokeym 发表于 2017-7-17 17:01
没清中断标志位吧

程序的整体思路。main函数-->dma初始化,定时器4通道2的输入捕获初始化,使能捕获触发dma请求,·外部中断初始化检测帧信号-->中断函数里开启dma使能-->.
dma的初始化中cmar为定义的数组,cpar为GPIOC->IDR,传输的方向cp  to  cm。
不知道这样对不对,主要是想实现将GPIOC->IDR上的数据通过dma传输到数组中。
回复

使用道具 举报

0

主题

145

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
366
金钱
366
注册时间
2017-6-19
在线时间
55 小时
发表于 2017-7-19 14:59:29 | 显示全部楼层
不是IDR、是ODR吧
回复

使用道具 举报

14

主题

112

帖子

0

精华

高级会员

Rank: 4

积分
500
金钱
500
注册时间
2017-4-25
在线时间
110 小时
发表于 2017-7-19 15:29:13 | 显示全部楼层
不造大大
回复

使用道具 举报

3

主题

18

帖子

0

精华

新手上路

积分
38
金钱
38
注册时间
2017-7-14
在线时间
9 小时
 楼主| 发表于 2017-7-19 16:16:16 | 显示全部楼层
jokeym 发表于 2017-7-19 14:59
不是IDR、是ODR吧

ODR是输出的,IDR是输入,这里pc0~pc7作为接收摄像头的数据。因为32的dma的请求只能是外设(硬件请求),然后还有一个mtom情况下的软件请求不知道是什么个意思???
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-4-6 12:02

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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