问答

汇集网友智慧,解决技术难题

21ic问答首页 - TAG - 失败
  • GD32E230用捕获及485通讯,开启捕获就通讯卡死且初始化失败 sos

    GD32E230C8T6 用TIMER2_CH3进行频率捕获,同时用USART0进行485通讯,一开启捕获就通讯不了,且一点仿真DEBUG按钮就直接全速运行,然后就卡死在LDR R0, =SystemInit位置,无法初始化。具体代码如下: int main(void){ systick_config(); //滴答定时器初始化 Led_Gpio_Init(); //数码管引脚初始化 Key_Init(); //按键引脚初始化 Relay_GPIO_Init(); //继电器引脚初始化 Capture_Gpio_config(); //捕获引脚初始化 usart_config(9600); //串口配置 Para_Read(); //读取参数 LedPower = 1; //电源灯亮 Adc_gpio_config(); //ADC采样引脚初始化 Adc_Config(); //ADC参数配置初始化 Nvic_config(); //捕获中断 Timer2_config(); //Timer2配置 Timer5_Init(3600,40); //定时10ms = 3600/72M *200 Timer14_Init(36,625); //定时312.5us while(1) { Adc_Cal(); //ADC采样计算 fre_capture_cal(); KeyMake(); //按键动作 Protect(); Display(); //显示 UartDriver(); } } void Capture_Gpio_config(void) { /* 使能GPIOB时钟 */ rcu_periph_clock_enable(RCU_GPIOB); /* 配置PB1(TIMER2_CH3)为复用功能 */ gpio_mode_set(GPIOB, GPIO_MODE_AF, GPIO_PUPD_NONE, GPIO_PIN_1); gpio_output_options_set(GPIOB, GPIO_OTYPE_PP, GPIO_OSPEED_50MHZ, GPIO_PIN_1); gpio_af_set(GPIOB, GPIO_AF_1, GPIO_PIN_1); // 根据数据手册选择正确的AF } /* ********************************************************************************************************* * 函 数 名: nvic_config * 功能说明: 配置中断优先级 * 形 参:无 * 返 回 值: 无 ********************************************************************************************************* */ void Nvic_config(void) { nvic_irq_enable(TIMER2_IRQn,0); } /* ********************************************************************************************************* * 函 数 名: timer2_config * 功能说明: 定时器配置--捕获 * 形 参:无 * 返 回 值: 无 ********************************************************************************************************* */ void Timer2_config(void) { timer_ic_parameter_struct timer_icinitpara; timer_parameter_struct timer_initpara; /* enable the TIMER clock */ rcu_periph_clock_enable(RCU_TIMER2); /* disable a TIMER */ timer_deinit(TIMER2); /* initialize TIMER init parameter struct */ timer_struct_para_init(&timer_initpara); /* TIMER2 configuration */ timer_initpara.prescaler = 7199; timer_initpara.alignedmode = TIMER_COUNTER_EDGE; timer_initpara.counterdirection = TIMER_COUNTER_UP; timer_initpara.period = 65535; timer_initpara.clockdivision = TIMER_CKDIV_DIV1; timer_init(TIMER2, &timer_initpara); /* TIMER2 configuration */ /* initialize TIMER channel input parameter struct */ timer_channel_input_struct_para_init(&timer_icinitpara); /* TIMER2 CH3 input capture configuration */ timer_icinitpara.icpolarity = TIMER_IC_POLARITY_RISING; //此处采用下降沿捕获, TIMER_IC_POLARITY_RISING timer_icinitpara.icselection = TIMER_IC_SELECTION_DIRECTTI; timer_icinitpara.icprescaler = TIMER_IC_PSC_DIV1; timer_icinitpara.icfilter = 0x0; timer_input_capture_config(TIMER2,TIMER_CH_3,&timer_icinitpara); /* auto-reload preload enable */ timer_auto_reload_shadow_enable(TIMER2); /* clear channel 3 interrupt bit */ timer_interrupt_flag_clear(TIMER2,TIMER_INT_FLAG_CH3 ); /* clear channel 3 interrupt bit */ timer_interrupt_flag_clear(TIMER2,TIMER_INT_FLAG_UP ); /* channel 3 interrupt enable */ timer_interrupt_enable(TIMER2,TIMER_INT_CH3); /* channel 3 interrupt enable */ timer_interrupt_enable(TIMER2,TIMER_INT_UP); /* TIMER2 counter enable */ timer_enable(TIMER2); } /* ********************************************************************************************************* * 函 数 名: TIM2_IRQHandler * 功能说明: TIM2 中断服务程序 * 形 参:无 * 返 回 值: 无 1us ********************************************************************************************************* */ void TIMER2_IRQHandler(void) { if(timer_interrupt_flag_get(TIMER2,TIMER_INT_FLAG_CH3)) { timer_interrupt_flag_clear(TIMER2,TIMER_INT_FLAG_CH3); //清除TIMER2的中断标志 uint32_t currentCapture = timer_channel_capture_value_register_read(TIMER2,TIMER_CH_3); if(firstCapture) { lastCapture = currentCapture; firstCapture = 0; } else { capture_diff = (currentCapture - lastCapture) +(overflow_count * 65536); test_flag = 1; //置位测量标志 lastCapture = currentCapture; } overflow_count = 0; } if(timer_interrupt_flag_get(TIMER2,TIMER_INT_FLAG_UP)) { timer_interrupt_flag_clear(TIMER2,TIMER_INT_FLAG_UP); overflow_count ++; } } void fre_capture_cal(void) { if(test_flag) { test_flag = 0; frequency = 10000.0f/capture_diff; MeasData.freq = (uint32_t)(frequency*10); //频率转换 } if(MeasData.Uln < 50) //小于5V { MeasData.freq = 0; } } void usart_config(uint32_t band_rate) { rcu_periph_clock_enable(RCU_GPIOA); // 开启引脚端口时钟 PA9 TX PA10 RX rcu_periph_clock_enable(RCU_USART0); // 开启串口时钟 /* 配置GPIO复用功能 */ gpio_af_set(GPIOA, GPIO_AF_1, GPIO_PIN_9); gpio_af_set(GPIOA, GPIO_AF_1, GPIO_PIN_10); /* 配置PA9 TX为复用模式 上拉模式 */ gpio_mode_set(GPIOA, GPIO_MODE_AF, GPIO_PUPD_PULLUP, GPIO_PIN_9); /* 配置TX为推挽输出 50MHZ */ gpio_output_options_set(GPIOA, GPIO_OTYPE_PP, GPIO_OSPEED_50MHZ, GPIO_PIN_9); /* 配置PA10 RX为复用模式 无上拉下拉模式 */ gpio_mode_set(GPIOA, GPIO_MODE_AF, GPIO_PUPD_PULLUP, GPIO_PIN_10); /* 配置RX为浮空输入 50MHZ */ gpio_output_options_set(GPIOA, GPIO_OTYPE_PP, GPIO_OSPEED_50MHZ, GPIO_PIN_10); /* 配置DE为输出模式 无上拉下拉模式 */ gpio_mode_set(GPIOA, GPIO_MODE_OUTPUT, GPIO_PUPD_NONE, GPIO_PIN_11); //485 /* 配置DE为推挽输出 50MHZ */ gpio_output_options_set(GPIOA, GPIO_OTYPE_PP, GPIO_OSPEED_50MHZ, GPIO_PIN_11); //485 RS485_DE(0); //使能接收 485 usart_deinit(USART0); // 复位串口 usart_baudrate_set(USART0,band_rate); // 设置波特率 usart_parity_config(USART0,USART_PM_NONE); // 没有校验位 usart_word_length_set(USART0,USART_WL_8BIT); // 8位数据位 usart_stop_bit_set(USART0,USART_STB_2BIT); // 2位停止位 /* 使能串口 */ usart_receive_config(USART0,USART_RECEIVE_ENABLE); // 使能串口接收 usart_transmit_config(USART0,USART_TRANSMIT_ENABLE); // 使能串口发送 usart_receiver_timeout_threshold_config(USART0,100); //设置串口接收超时阈值,这个100是指100bit时间,如果按照10bit传输一个字节,那么就是10个字节时间 usart_receiver_timeout_enable(USART0); //超时使能 usart_enable(USART0); // 使能串口 nvic_irq_enable(USART0_IRQn,0); usart_interrupt_enable(USART0, USART_INT_RBNE); // 使能接收中断 usart_interrupt_enable(USART0, USART_INT_RT); //使能串口接收超时中断 } void usart_send(uint8_t *buf, uint8_t len) { uint8_t i; while(tx_busy); //等待上一个发送完成 tx_busy = 1; //准备发送 RS485_DE(1); //发送模式 usart_interrupt_disable(USART0, USART_INT_RBNE|USART_INT_RT); // 禁能接收中断(避免发送期间接收自己的数据) for(i=0; i= sizeof(g_recv_buff)) { g_recv_length = 0; } } else if(RESET != usart_interrupt_flag_get(USART0,USART_INT_FLAG_RT)) //接收中断超时标志 { usart_flag_clear(USART0,USART_FLAG_RT); g_recv_complete_flag = 1; } } void UartDriver(void) { uint8_t len; uint8_t buf[64] = {0x00}; //接收数据存放的数组 if(g_recv_complete_flag ==1) { g_recv_complete_flag = 0; process_modbus_request(); g_recv_length = 0; } } void process_modbus_request(void) { uint16_t i = 0; uint16_t j = 0; uint16_t crc = 0; //校验码 uint8_t crch = 0; //校验码高字节 uint8_t crcl = 0; //校验码低字节 uint16_t addr = 0; //寄存器地址 uint16_t cnt = 0; //数据量 uint16_t data = 0; //写入的数据 uint16_t addrtemp = 0; uint16_t index; if(g_recv_buff[0] != Para.Addr ) {return;} crc = usMBCRC16(g_recv_buff,g_recv_length-2); //校验码 crch = (uint8_t)(crc >>8); //取高8位 crcl = (uint8_t)crc; //取低位 if((g_recv_buff[g_recv_length-2]!=crch)||(g_recv_buff[g_recv_length-1]!=crcl)) //校验码不对 { return ; //返回空白值 } addr = ((uint16_t)g_recv_buff[2]<<8)|g_recv_buff[3]; //寄存器地址 switch(g_recv_buff[1]) { /*03功能码 读单个寄存器*/ case 0x03: cnt= ((uint16_t)g_recv_buff[4]<<8)|g_recv_buff[5]; if(cnt==0) //数据量=0 { Errcmd_addr_data(g_recv_buff,3); //返回数据错误码 03 return; } if((addr >= 0x0A00)&&(addr <= 0x0A04)) //地址范围0x0a00--0x0a06 { if((addr+cnt) > 0x0A05) { Errcmd_addr_data(g_recv_buff,3); //字节数超范围,报83错误码 return; } else { for(i=0;i>8); //取高8位数据 (uint8_t)强制转换为uint8_t类型的数据;*取后面括号里的数据 (uint32_t*)把Uln的地址强制转化为uint32_t类型指针 &取Uln的地址 txbuffer[4+i*2] = (uint8_t)(*((uint32_t*)& MeasData.Uln +(addr & 0x00FF)+i)); //取低8位数据 } } } else if((addr >= 0x0B00)&&(addr <= 0x0B13)) //地址范围0x0b00--0x0b07 { if(((addr+cnt) > 0x0B14)||(addr%2 !=0)) //超出地址、地址不等于8的倍数 则报错 { Errcmd_addr_data(g_recv_buff,3); //字节数超范围,报83错误码 return; } else { for(i=0;i>8); //取高8位数据 txbuffer[4+i*2] = (uint8_t)(*((uint32_t*)& Err_ASK.ErrType +((addr & 0x00FF)+i)%2)); //取低8位数据 } } } else if((addr >= 0x0C00)&&(addr <= 0x0C0B)) //地址范围0x0C00--0x0C0B { if((addr+cnt) > 0x0C0C) { Errcmd_addr_data(g_recv_buff,3); //字节数超范围,则报83错误码 return; } else { for(i=0;i>8); //取高8位数据 txbuffer[4+i*2] = (uint8_t)(*((uint32_t*)& Para.Mode +(addr & 0x00FF)+i)); //取低8位数据 } } } else //地址不在范围内,报82错误码 { Errcmd_addr_data(g_recv_buff,2); return; } txbuffer[0] = Para.Addr; //设备地址 txbuffer[1] = 0x03; //功能码 txbuffer[2] = cnt*2; //读出的字节数 crc = usMBCRC16(txbuffer,cnt*2+3); //CRC校验值计算 crch = (uint8_t)(crc >> 8); crcl = (uint8_t)crc; txbuffer[3 + cnt * 2] = crch; //CRC高位数据地址 txbuffer[4 + cnt * 2] = crcl; //CRC低位数据地址 usart_send(txbuffer,cnt*2+5); //发送 break; default: Errcmd_addr_data(g_recv_buff,1); //错误码01 break; } } 有类似遇到的问题吗?求解,谢谢

    失败 485 通讯 GD32E230 TI ar

    1222浏览量 0回复量 关注量
  • IIC接口搭载了了ADS1115但是读取到的数据一直是65535

    如标题所示,AD显示的值一直是65535,但是仿真里是对的,有没有大佬看看怎么回事,都不知道该给哪纠错图片一直上传失败,感兴趣的大佬可以留下联系方式我来加 救救孩子吧

    ADS1115 iic接口 读取 仿真 兴趣 失败

    928浏览量 3回复量 关注量
  • N32G430C8L7 用官方下载工具出错 sos

    N32G430C8L7单片机在使用官方下载工具Nations MCU Download Tool 通过串口下载程序时出现“获取选项字节失败”,哪位大佬帮忙看看,第一次用这个单片机。

    N32G430C8L7 单片机 AD 失败 获取 使用

    1188浏览量 0回复量 关注量
  • 【锦锐单片机】仿真下载器下载程序失败,求助

    [i=s] 本帖最后由 礦ision5 于 2025-5-7 12:58 编辑 [/i] [backcolor=rgb(255, 255, 255)][color=#252525]使用锦锐仿真下载器下载CA51M151N2程序失败。CACHIP TOOL版本V3.9.9。仿真下载器没有故障,试着下载CA51F3的程序能下载成功。 [/color][attach]2400388[/attach][color=#252525] 怀疑是仿真下载器固件版本不对,点击固件更新失败。 [/color][attach]2400390[/attach] [/backcolor][color=#252525][backcolor=rgb(255, 255, 255)][font=Tahoma, "]按照操作一直按着BOOT键插入电脑点击升级也没有用,还是这样提示。 [/font][/backcolor][/color][attach]2400392[/attach][color=#252525][backcolor=rgb(255, 255, 255)][font=Tahoma, "] [/font][/backcolor][/color][color=#252525][size=14px]我按着红框中的按键,不知道有没有理解错。[/size][/color][color=#252525][backcolor=rgb(255, 255, 255)][font=Tahoma, "] 现在不知道是什么问题,求帮助。 [/font][/backcolor][/color]

    单片机 国产芯片 仿真 失败 下载程序

    1668浏览量 3回复量 关注量
  • GD32E230K8U6 烧录第一次可以成功,之后就全部失败

    GD32E230K8U6 使用JLINK烧录第一次可以烧录成功,之后就不可以了。提示如下图所示[img][/img]

    GD32E230K8U6 JLINK 烧录 失败 成功

    5427浏览量 11回复量 关注量
  • STM32挂载FatFS系统写入SD卡,写入几十次左右一会就会失败 sos

    successNo.52 successNo.53 successNo.54 successNo.55 fiadNo.56 fiadNo.57 fiadNo.58 fiadNo.59 fiadNo.60 fiadNo.61 fiadNo.62 fiadNo.63 fiadNo.64 fiadNo.65 fiadNo.66 fiadNo.67 fiadNo.68 fiadNo.69 fiadNo.70 fiadNo.71 fiadNo.72 fiadNo.73 fiadNo.74 fiadNo.75 fiadNo.76 fiadNo.77 fiadNo.78 fiadNo.79 fiadNo.80 fiadNo.81 fiadNo.82 fiadNo.83 fiadNo.84 fiadNo.85 fiadNo.86 fiadNo.87 fiadNo.88 fiadNo.89 fiadNo.90 fiadNo.91 fiadNo.92 fiadNo.93 fiadNo.94 fiadNo.95 fiadNo

    单片机 嵌入式 FATFS SD卡 STM32 失败

    2280浏览量 0回复量 关注量
  • GD32F103C8T6,使用ST标准库,CAN初始化失败

    [i=s] 本帖最后由 fw19876311 于 2025-1-14 17:01 编辑 [/i] STM32F103C8T6正常运行的代码,直接平替GD32F103C8,CAN部分初始化异常,一直返回失败 [b]uint8_t CAN_Init(CAN_TypeDef* CANx, CAN_InitTypeDef* CAN_InitStruct)[/b][b]{[/b] [b]uint8_t InitStatus = CAN_InitStatus_Failed;[/b] [b] uint32_t wait_ack = 0x00000000;[/b][b] /* Check theparameters*/[/b][b]assert_param(IS_CAN_ALL_PERIPH(CANx));[/b][b]assert_param(IS_FUNCTIONAL_STATE(CAN_InitStruct->CAN_TTCM));[/b] [b]assert_param(IS_FUNCTIONAL_STATE(CAN_InitStruct->CAN_ABOM));[/b] [b]assert_param(IS_FUNCTIONAL_STATE(CAN_InitStruct->CAN_AWUM));[/b] [b]assert_param(IS_FUNCTIONAL_STATE(CAN_InitStruct->CAN_NART));[/b] [b]assert_param(IS_FUNCTIONAL_STATE(CAN_InitStruct->CAN_RFLM));[/b] [b]assert_param(IS_FUNCTIONAL_STATE(CAN_InitStruct->CAN_TXFP));[/b] [b]assert_param(IS_CAN_MODE(CAN_InitStruct->CAN_Mode));[/b] [b]assert_param(IS_CAN_SJW(CAN_InitStruct->CAN_SJW));[/b] [b]assert_param(IS_CAN_BS1(CAN_InitStruct->CAN_BS1));[/b] [b]assert_param(IS_CAN_BS2(CAN_InitStruct->CAN_BS2));[/b] [b] assert_param(IS_CAN_PRESCALER(CAN_InitStruct->CAN_Prescaler));[/b][b] /* Exit from sleep mode */[/b] [b]CANx->MCR &= (~(uint32_t)CAN_MCR_SLEEP);[/b][b] /* Request initialisation */[/b] [b]CANx->MCR |= CAN_MCR_INRQ ;[/b][b] /* Wait the acknowledge */[/b] [b]while (((CANx->MSR & CAN_MSR_INAK) != CAN_MSR_INAK) && (wait_ack != INAK_TIMEOUT))[/b][b] {[/b][b] wait_ack++;[/b][b] }[/b][b] /* Check acknowledge */[/b] [b]if ((CANx->MSR & CAN_MSR_INAK) != CAN_MSR_INAK)[/b] [b]{[/b][b] InitStatus = CAN_InitStatus_Failed;=====================卡在这个位置[/b][b] }[/b] [b]请教各位,有遇到过吗?麻烦指导下,谢谢大家![/b]

    gd32F103 国产芯片 ST 失败 CAN 使用

    5089浏览量 21回复量 关注量
  • 用的凌鸥07系列芯片烧录官方CAN例程输出数据失败

    [i=s] 本帖最后由 ZDRenlc 于 2024-12-21 16:13 编辑 [/i] 问题:用凌鸥LKS32MC071CBT8芯片配套的官方CAN例程,烧进去结果输出波形很乱,不知道该怎么解决? 描述: 1、板子和CAN模块的连线没有问题,已查看多次。 2、使用的是CAN外回环模式的代码烧录进芯片进行测试,用CAN盒接收数据,但在CANPro上未显示接收到数据。 3、在主函数中用变量接收发送函数的返回值,在窗口中显示的是0xff,其含义是错误。 4、用keil仿真下来,断点执行查看TBUF0发送缓冲寄存器也是空的(按理应该有数据)。 5、查看CAN_EALCAP寄存器又说有位错误,但是这是外回环模式按理说不该有这个问题啊。 6、对照手册看了一遍官方代码,感觉没啥问题,但是也找不到硬件的问题。 所以请各位帮忙找下解决问题的方向,感谢。

    凌鸥 CAN例程 失败 输出 系列芯片 烧录

    1944浏览量 3回复量 关注量
  • 21网站用家园币兑换物品,什么时候发货 赏100家园币

    事情是这样的,我12月3日兑换了一个物品,运费也付了,家园币显示扣除,但实际账号家园币还在,那我这物品是兑换成功还是失败?运费15元是扣除了,家园币还在,请问这是什么情况?有没有人兑换过,比较了解,求告知一下情况,谢谢!

    网站 失败 成功 实际

    7789浏览量 22回复量 关注量
  • AT32F407 SDIO接口进行1线IO通讯时写操作失败。 sos

    在使用AT32F407 SDIO接口进行IO通讯时(没有SD卡,只是IO通讯),进行写操作过程时,能够将数据传输到slaver且slaver端数据接收是正确的,但AT32F407端(host)报SD_DATA_FAIL这样的错误。 注:案例来自[color=#444444][font=Tahoma,] [/font][/color][color=#444444][font=Tahoma,]AT32F403A_407_Firmware_Library_V2.1.8[/font][/color]

    单片机 国产芯片 嵌入式 sd 失败 操作

    667浏览量 0回复量 关注量