搜索
bottom↓
回复: 7

一个EP4CE10F17c8的FPGA模块例化问题

[复制链接]

出0入115汤圆

发表于 2021-12-17 16:01:15 | 显示全部楼层 |阅读模式
本帖最后由 三年模拟 于 2021-12-17 16:05 编辑

目前做一个FPGA运动控制卡,16路步进电机输出,一个模块是步进电机的运动控制,如下,例化出16路控制
stepmotor                 uut_stepmotor1(
                                        .clk(clk_50m),                //时钟信号,50MHz
                                        .rst_n(sys_rst_n),        //复位信号,低电平有效
                                        .en(stepmotor1_start),
                                        .switch(stepmotor1_switch),
                                        .upos(stepmotor1_upos),
                                        .spos(stepmotor1_spos),
                                        .dpos(stepmotor1_dpos),//目标步数
                                        .vmax(stepmotor1_vmax[23:0]),//最大速度
                                        .running(stepmotor1_running),
                                        .pulse(stepmotor1_pulse)        //sin输出值
                                );
stepmotor                 uut_stepmotor2(.clk(clk_50m),                //时钟信号,50MHz
                                        .rst_n(sys_rst_n),        //复位信号,低电平有效
                                        .en(stepmotor2_start),
                                        .switch(stepmotor2_switch),
                                        .upos(stepmotor2_upos),
                                        .spos(stepmotor2_spos),
                                        .dpos(stepmotor2_dpos),//目标步数
                                        .vmax(stepmotor2_vmax[23:0]),//最大速度
                                        .running(stepmotor2_running),
                                        .pulse(stepmotor2_pulse)        //sin输出值);

....省略,同上类推
stepmotor                 uut_stepmotor6(.clk(clk_50m),                //时钟信号,50MHz
                                        .rst_n(sys_rst_n),        //复位信号,低电平有效
                                        .en(stepmotor6_start),
                                        .switch(stepmotor6_switch),
                                        .upos(stepmotor6_upos),
                                        .spos(stepmotor6_spos),
                                        .dpos(stepmotor6_dpos),//目标步数
                                        .vmax(stepmotor6_vmax[23:0]),//最大速度
                                        .running(stepmotor6_running),
                                        .pulse(stepmotor6_pulse)        //sin输出值);
....省略,同上类推
stepmotor                 uut_stepmotor16(.clk(clk_50m),                //时钟信号,50MHz
                                        .rst_n(sys_rst_n),        //复位信号,低电平有效
                                        .en(stepmotor16_start),
                                        .switch(stepmotor16_switch),
                                        .upos(stepmotor16_upos),
                                        .spos(stepmotor16_spos),
                                        .dpos(stepmotor16_dpos),//目标步数
                                        .vmax(stepmotor16_vmax[23:0]),//最大速度
                                        .running(stepmotor16_running),
                                        .pulse(stepmotor16_pulse)        //sin输出值);
其中running信号是输出,表示电机运动状态,0停止,1运动。
现在问题来了,16个模块中,第6和16的running输出一直是0,其余14个没问题,已经检查了,各种io配置,不是引脚配置问题,肯定是其他问题导致,这16路输出,除了第6和16模块的running不正常(16路电机都能动),其余都是正常工作的,有没有大佬帮忙看下,什么问题导致。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

出0入115汤圆

 楼主| 发表于 2021-12-17 17:24:06 | 显示全部楼层
已解决,资源到92%以上,就会有bug了,优化了寄存器数量,资源释放了些,就没问题了

出0入0汤圆

发表于 2021-12-17 17:51:38 | 显示全部楼层
fpga 的IP内部实现步进加减速?楼主牛X哦.

出0入442汤圆

发表于 2021-12-17 21:34:31 来自手机 | 显示全部楼层
三年模拟 发表于 2021-12-17 17:24
已解决,资源到92%以上,就会有bug了,优化了寄存器数量,资源释放了些,就没问题了
...

。。。。这不是bug,这是你时序没过。你左边的时序都报错了难道不处理好?

出0入115汤圆

 楼主| 发表于 2021-12-30 10:38:43 | 显示全部楼层
本帖最后由 三年模拟 于 2021-12-30 11:28 编辑

公司就我一个嵌入式,自学fpga一年左右,都是小打小闹,这段时间学习了时序约束,出现上面的问题的确不是约束的问题,而是步进电机加减速的步数计算模块一个启动使能没弄好,导致概率出问题,现在已经修复了,程序已经经过了测试,16路步进独立加减速稳如老狗。
等项目做好了,我计划开源部分,目前实现的功能有stm32-fsmc<->fpga->sdram,stm32能够通过fsmc读写fpga外挂的sdram,在非进行插补的时候,fpga可以独立进行加减速,接下来准备用stm32来实现简单的插补算法,而后fpga来运行。

出100入85汤圆

发表于 2021-12-30 11:39:43 | 显示全部楼层
三年模拟 发表于 2021-12-30 10:38
公司就我一个嵌入式,自学fpga一年左右,都是小打小闹,这段时间学习了时序约束,出现上面的问题的确不是约 ...

期待。。。。。

出100入85汤圆

发表于 2022-3-10 10:18:28 | 显示全部楼层
进展如何?

出100入85汤圆

发表于 2022-6-11 22:51:48 | 显示全部楼层
三年模拟 发表于 2021-12-30 10:38
公司就我一个嵌入式,自学fpga一年左右,都是小打小闹,这段时间学习了时序约束,出现上面的问题的确不是约 ...
(引用自5楼)

项目搞好了?
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-4-19 23:51

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

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