打印

gd32f303rct6,烧录后,只有在debug模式下,程序才能正常运行

[复制链接]
7957|19
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
194490490|  楼主 | 2023-2-28 14:30 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 194490490 于 2023-3-3 08:25 编辑

1,芯片:gd32f303rct62,boot0和boot1都接地。
3,同样的程序stm32f103rct6没有问题。
4,实验内容:通过dma+pwm,控制pb3,输出波形,从而控制rgb灯的点亮,熄灭和颜色。但是程序烧录后,只有在debug模式下程序才能正常运行(点击魔术棒,然后点debug,再点setting不做任何设置,直接退出,程序能自动正确运行)。如果拔除jlink与开发板连线,直接重启电源或按复位都不能正确运行程序。请哪位大佬能不能帮忙看看,我写的配置程序有没有问题,帮忙分析一下原因。
5,void vLED_init(void),为驱动配置程序。
6,void vSetLED(uint8_t (*color)[3],uint16_t len),为通过dma+pwm向rgb灯芯片发送数据


问题已经解决了,配置gpio remap时不仔细一个参数配置错了,正确的是(GPIO_SWJ_SWDPENABLE_REMAP)。
      \arg        GPIO_SWJ_NONJTRST_REMAP: full SWJ(JTAG-DP + SW-DP),but without NJTRST
      \arg        GPIO_SWJ_SWDPENABLE_REMAP: JTAG-DP disabled and SW-DP enabled
      \arg        GPIO_SWJ_DISABLE_REMAP: JTAG-DP disabled and SW-DP disabled
<div class="blockcode"><blockquote>/**************************************
/**************************************
功能描述:LED初始化,gpio,pwm,dma
入口参数:无
返回值:无
***************************************/

void vLED_init(void)
{         
    timer_oc_parameter_struct timer_ocintpara;
    timer_parameter_struct timer_initpara;
               
    /* PWM_DMA_channel configuration */
    dma_parameter_struct dma_data_parameter;               
        
    rcu_periph_clock_enable(RCU_TIMER1);//使能定时器1时钟
        
    rcu_periph_clock_enable(RCU_GPIOB);//使能GPIOB时钟
    gpio_pin_remap_config(GPIO_TIMER1_FULL_REMAP, ENABLE);//TIMER1 full remapping
    gpio_pin_remap_config(GPIO_SWJ_SWDPENABLE_REMAP, ENABLE);//下载口NJTRST引脚当做普通I/O口        
    /*Configure PB3(TIMER1  CH1) as remap function*/
    gpio_init(GPIOB, GPIO_MODE_AF_PP, GPIO_OSPEED_50MHZ, GPIO_PIN_3);//PB3配置成复用推挽输出
        
    timer_deinit(TIMER1);//复位定时器1
        
    /* TIMER1 configuration */
    timer_initpara.prescaler            = 0;                //0
    timer_initpara.alignedmode       = TIMER_COUNTER_EDGE;
    timer_initpara.counterdirection  = TIMER_COUNTER_UP;
    timer_initpara.period                = 150-1;                //800kHz频率  150-1
    timer_initpara.clockdivision       = TIMER_CKDIV_DIV1;
    timer_initpara.repetitioncounter  = 0;               
    timer_init(TIMER1,&timer_initpara);
               
    /* CH1 configuration in PWM mode0 */
    timer_ocintpara.outputstate  = TIMER_CCX_ENABLE;
    timer_ocintpara.outputnstate= TIMER_CCXN_DISABLE;
    timer_ocintpara.ocpolarity    = TIMER_OC_POLARITY_HIGH;
    timer_ocintpara.ocnpolarity  = TIMER_OCN_POLARITY_HIGH;
    timer_ocintpara.ocidlestate  = TIMER_OC_IDLE_STATE_LOW;
    timer_ocintpara.ocnidlestate= TIMER_OCN_IDLE_STATE_LOW;

    timer_channel_output_config(TIMER1,TIMER_CH_1,&timer_ocintpara);                //20230227

    /* CH1 configuration in PWM mode1,duty cycle 0% */
    timer_channel_output_pulse_value_config(TIMER1,TIMER_CH_1,0);               
    timer_channel_output_mode_config(TIMER1,TIMER_CH_1,TIMER_OC_MODE_PWM0);
    timer_channel_output_shadow_config(TIMER1,TIMER_CH_1,TIMER_OC_SHADOW_ENABLE);

    /* enable DMA0 clock */
    rcu_periph_clock_enable(RCU_DMA0);        
        
    /* ADC DMA_channel configuration */
    dma_deinit(DMA0, DMA_CH1);
   
    /* initialize DMA single data mode */
    dma_data_parameter.periph_addr  = (uint32_t)(&TIMER_CH1CV(TIMER1));
    dma_data_parameter.periph_inc   = DMA_PERIPH_INCREASE_DISABLE;
    dma_data_parameter.memory_addr  = (uint32_t)(LED_BYTE_Buffer);        
    dma_data_parameter.memory_inc   = DMA_MEMORY_INCREASE_ENABLE;
    dma_data_parameter.periph_width = DMA_PERIPHERAL_WIDTH_16BIT;
    dma_data_parameter.memory_width = DMA_MEMORY_WIDTH_16BIT;  
    dma_data_parameter.direction    = DMA_MEMORY_TO_PERIPHERAL;
    dma_data_parameter.number       = 4 * 3 * 8;  //4个RGB灯珠,3*8个数位
    dma_data_parameter.priority     = DMA_PRIORITY_ULTRA_HIGH;
    dma_init(DMA0, DMA_CH1, &dma_data_parameter);               

    /* TIMER0 primary output enable */
    timer_primary_output_config(TIMER1,ENABLE);
}

<div class="blockcode"><blockquote>/**************************************
功能描述:发送RGB数据
入口参数:(*color)[3]颜色RGB值   len灯珠个数
返回值:无
***************************************/
void vSetLED(uint8_t (*color)[3],uint16_t len)        
{
        uint8_t i,j;
        uint16_t memaddr;
        uint16_t buffersize;
        buffersize = len*24+225;                 // number of bytes needed is #LEDs * 24 bytes + 42 trailing bytes
        memaddr = 0;                                // reset buffer memory index

        for(j=0;j<len;j++)
        {        
                for(i=0; i<8; i++) // RED data
                {
                        LED_BYTE_Buffer[memaddr] = ((color[j][1]<<i) & 0x0080) ? TIMING_ONE:TIMING_ZERO;
                        memaddr++;
                }
                for(i=0; i<8; i++) // GREEN
                {
                        LED_BYTE_Buffer[memaddr] = ((color[j][0]<<i) & 0x0080) ? TIMING_ONE:TIMING_ZERO;
                        memaddr++;
                }
                for(i=0; i<8; i++) // BLUE
                {
                        LED_BYTE_Buffer[memaddr] = ((color[j][2]<<i) & 0x0080) ? TIMING_ONE:TIMING_ZERO;
                        memaddr++;
                }
        }        
        while(memaddr < buffersize)
        {
           LED_BYTE_Buffer[memaddr] = 0;
           memaddr++;
        }
                dma_transfer_number_config(DMA0, DMA_CH1, buffersize);
        
                /* enable the TIMER DMA */
                timer_dma_enable(TIMER1, TIMER_DMA_UPD);        //更新时请求DMA,注意对应的DMA0通道为CH1 -> TIMER1_UP                       
                timer_counter_value_config(TIMER1, 0x0000);
                timer_flag_clear(TIMER1,TIMER_FLAG_UP);         
                /* auto-reload preload enable */
                timer_auto_reload_shadow_enable(TIMER1);
                timer_enable(TIMER1);                                
                /* enable DMA channel */
                dma_channel_enable(DMA0, DMA_CH1);                                
                while(!dma_flag_get(DMA0, DMA_CH1, DMA_FLAG_FTF));
                dma_channel_disable(DMA0, DMA_CH1);        
                dma_flag_clear(DMA0, DMA_CH1, DMA_FLAG_FTF);
                timer_dma_disable(TIMER1, TIMER_DMA_UPD);        //更新时请求DMA,注意对应的DMA0通道为CH1 -> TIMER1_UP               
                timer_disable(TIMER1);
                timer_flag_clear(TIMER1,TIMER_FLAG_UP);               
}





使用特权

评论回复

相关帖子

沙发
sagade| | 2023-2-28 21:24 | 只看该作者
感觉设置或电路哪里不对吧,其实可以百度stm32只能仿真运行找找相关的问题

使用特权

评论回复
板凳
zchong| | 2023-3-1 07:03 | 只看该作者
别搞那么复杂,从基本的入手,比如仅仅点个灯看看是否正常运行,排除一些基本的问题,然后再结合自己的程序看看上电过程可能出现哪些问题。

使用特权

评论回复
地板
玄德| | 2023-3-1 09:24 | 只看该作者

这问题有难度。关键是没法观察现场。
想办法解决这个问题,利用 LED、显示屏,针对“不正常”的具体情况,把要查看的内容显示出来,或者指示出来,一步一步查。
这一步没问题,再查下一步。




使用特权

评论回复
5
194490490|  楼主 | 2023-3-1 09:26 | 只看该作者
sagade 发表于 2023-2-28 21:24
感觉设置或电路哪里不对吧,其实可以百度stm32只能仿真运行找找相关的问题 ...

同样的板,只是把gd芯片换成stm芯片,stm程序能正常运行,与需求匹配。但是gd芯片上电灯不能直接启动,点不亮。但是把stm程序直接下载到gd芯片,上电自动能点亮,但是有一个灯颜色不对。所有判断电路没有问题,应该是配置程序有问题。

使用特权

评论回复
6
194490490|  楼主 | 2023-3-1 09:27 | 只看该作者
本帖最后由 194490490 于 2023-3-1 09:30 编辑
zchong 发表于 2023-3-1 07:03
别搞那么复杂,从基本的入手,比如仅仅点个灯看看是否正常运行,排除一些基本的问题,然后再结合自己的程序 ...

这个灯是rgb自带芯片,需要用pwm+dma才能点亮。同样的板,只是把gd芯片换成stm芯片,stm程序能正常运行,与需求匹配。但是gd芯片上电灯不能直接启动,点不亮。如果把stm程序直接下载到gd芯片,上电自动能点亮,但是有一个灯颜色不对。所有判断电路没有问题,应该是配置程序有问题。如果大佬有gd芯片pwm+dma的示例程序,就给一个呗。

使用特权

评论回复
7
194490490|  楼主 | 2023-3-1 11:02 | 只看该作者
本帖最后由 194490490 于 2023-3-1 11:25 编辑
玄德 发表于 2023-3-1 09:24
这问题有难度。关键是没法观察现场。
想办法解决这个问题,利用 LED、显示屏,针对“不正常”的具体情况, ...

大佬,这方面有没有经验,可否帮我们看看这个问题,可付费。我可以把stm和gd板都发给你,程序也给你。咋样?刚才把stm的程序改了一下,直接烧录到gd里,运行完全正常。

使用特权

评论回复
8
simon0000| | 2023-3-1 14:36 | 只看该作者
楼主是哪里的?

使用特权

评论回复
9
simon0000| | 2023-3-1 14:38 | 只看该作者
我们从st切换到gd,目前用的都正常的,中间出现过一次类似情况,模糊记得是时钟相关的,时间久了忘了,你这个情况不知道是不是差不多?

使用特权

评论回复
10
194490490|  楼主 | 2023-3-1 15:40 | 只看该作者

深圳

使用特权

评论回复
11
194490490|  楼主 | 2023-3-1 15:41 | 只看该作者
本帖最后由 194490490 于 2023-3-1 15:51 编辑
simon0000 发表于 2023-3-1 14:38
我们从st切换到gd,目前用的都正常的,中间出现过一次类似情况,模糊记得是时钟相关的,时间久了忘了,你这 ...

能不能回忆一下具体情况?帮我做个参考。时钟怎么个相关法?目前我还没有找到具体问题点,能想到的一个笨办法是,把stm库函数配置文件,转成寄存器配置,再一条一条用相同的gd寄存器配置替换,因为我怀疑还是哪个地方配置错了,但是这个寄存器的方法耗时,容易出错。请大佬帮我想想有没有更具体简单一点的方法解决问题。

使用特权

评论回复
12
aguijie| | 2023-3-1 20:38 | 只看该作者
只能在debug模式运行,网上搜索了下,可能有如下原因:
1. boot模式不对,boot0应该外部接地。 楼主说已经接地,最好是用表测下。
2. 程序中如果使用了printf,就需要MicroLib的支持,在MDK中需要勾选Use MicroLib
3. 没有正确烧录

使用特权

评论回复
13
aguijie| | 2023-3-1 20:43 | 只看该作者
GD32/STM32的一些差异点:
https://www.findic.com/article/96472.html

使用特权

评论回复
14
194490490|  楼主 | 2023-3-1 22:25 | 只看该作者
aguijie 发表于 2023-3-1 20:38
只能在debug模式运行,网上搜索了下,可能有如下原因:
1. boot模式不对,boot0应该外部接地。 楼主说已经 ...

1点,用表笔测了都是0V。
2点,代码后面有把printf删除也没有用。
3点,确定烧录成功。

我用寄存器的方法把配置做得跟stm配置信息一样,也没有用。

使用特权

评论回复
15
aguijie| | 2023-3-1 23:03 | 只看该作者
7楼说改一下就正常了?

使用特权

评论回复
16
194490490|  楼主 | 2023-3-1 23:43 | 只看该作者
aguijie 发表于 2023-3-1 23:03
7楼说改一下就正常了?

7楼是把stm程序直接烧录到gd芯片,程序能正常运行。但是用gd自己的库函数,写的程序,运行不正常。

使用特权

评论回复
17
194490490|  楼主 | 2023-3-1 23:45 | 只看该作者
本帖最后由 194490490 于 2023-3-1 23:50 编辑
aguijie 发表于 2023-3-1 20:43
GD32/STM32的一些差异点:
https://www.findic.com/article/96472.html

这个差异点好像对没有看到可能与我的问题点相关。头疼。
1,现在能确定的是电路肯定没有问题,因为把gd芯片换成stm芯片程序能正常跑起来。
2,我还做了一个事情,把stm配置程序用寄存器重写,然后把gd配置程序参照stm寄存器配置程序一一对应重写。stm的也能正常在gd上跑,但是用gd自己寄存器写的跑不起来。我可以确定相关对应的寄存器配置是一样的。我的判断是配置好像也没有问题,所有有点莫名其妙。。

使用特权

评论回复
18
194490490|  楼主 | 2023-3-2 08:43 | 只看该作者
aguijie 发表于 2023-3-1 20:43
GD32/STM32的一些差异点:
https://www.findic.com/article/96472.html

我刚看到你的好友请求,但是我级别不够加不了。

使用特权

评论回复
19
aguijie| | 2023-3-2 09:17 | 只看该作者
楼主,在私信里讨论吧,方便点

使用特权

评论回复
20
194490490|  楼主 | 2023-3-2 09:46 | 只看该作者
本帖最后由 194490490 于 2023-3-3 17:54 编辑
aguijie 发表于 2023-3-2 09:17
楼主,在私信里讨论吧,方便点

还是级别不够,发不了私信。

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

1

主题

16

帖子

0

粉丝