基于SmartFusion2系列FPGA SOC的开发1——概要说明

在中科院XX所的时候,就从SRAM型FPGA,切换到Flash型FPGA的编程和调试。

最近几年,因为工作关系,需要找到一款类似于Zynq,但性能可以略低,并且货期和价格较为美丽(担心美帝断供,但这款不是很高端,不会有太大风险),但也要有ARM+FPGA架构的SOC芯片,可以方便的在嵌入式领域快速实现编程。

发现,Microsemi公司的FPGA SOC芯片SmartFusion2系列,其FPGA部分继承了之前A3PExxx系列的特性(Flash编程不用额外Flash芯片,同时兼顾超低功耗和高速特性),同时其包含了ARM部分(M3主频最高到166MHz),如此这般,正好可以更新下这段时间的所得所感所想。

 上表中,有不同的资源选项可供选择,资源比Spartan6相当,速度也相当吧(感觉)。

后面将以M2S010芯片为蓝本,进行进一步的介绍。

 上图是SmartFusion2芯片内部的结构框图,可以明显看到,该SOC结构上和Zynq很像。FPGA编程依然在Libero上用Block的方式拖拽,很方便,ARM端可以用它自己的SoftConsole或者直接用Keil开发,库什么的都是自动生成的,只需要完整导入即可。ARM和FPGA端的通信是重点,这里面也有几种方式,包括了高速和低速的方式。

上图中,可以看出ARM内部的工作框图,其可完全支持在线调试,加减断点,大大简化了调试过程。 

上2个图中,稍微对SOC内部的总线AHB、APB等做个介绍。各个外设分别挂在 不同的总线上,SOC内部完成了不同的配置,用户只需要在GUI端配置即可。

这个图是AHB总线的时序图,因为是公开的,可以从网上查阅到。

 

上图是AXI总线的时序图。(读操作)

 

上图是Fabric部分的结构,其包括了大量的LE,IO簇,Mathblocks, CCC,SRAM和Interface簇。 

如果关心片上存储,那么除了SOC内部的RAM资源外,还需要用到外部DDR部分。要说的是,这块芯片DDR既可以从Fabric端控制,也可以从ARM控制,灵活性很高,可以支持到DDR3,速度最快到333MHz.

未完待续~~~~~

************************************************************************************************************

大家有兴趣,可以光顾我的淘宝店,有现成的开发板和响应的例程供学习和使用。

SmartFusion2开发板含ARM核金手指DDR3以太网USB入门首选赠送例程

也可以直接给我发邮件 

johnrita@163.com

欢迎加入QQ群(656353231)一起交流技术和开发合作。

  • 6
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
SmartFusion是一款集成了FPGA和ARM处理器的可编程逻辑器件。在使用SmartFusion进行FPGA到ARM的衔接过程中,首先我们可以通过MSS(Microcontroller Subsystem)模块的GPIO(General Purpose Input/Output)功能来实现点灯。 MSS是SmartFusion芯片中的一个微控制器子系统,它包含了ARM Cortex-M3处理器以及与之相关的外设。GPIO是MSS提供的一种功能,它允许我们通过配置相关引脚的输入输出状态来进行数字信号的输入输出。 在使用MSS_GPIO点灯的过程中,首先我们需要使用SmartFusion的设计工具进行硬件电路的设计。接着,我们需要在软件开发环境中编写ARM处理器的代码来控制MSS_GPIO。 在代码中,我们需要进行以下步骤来实现点灯功能: 1. 配置MSS_GPIO控制的引脚作为输出引脚。我们可以通过设置相应的寄存器来实现这一步骤。例如,我们可以将寄存器的特定位设置为1来将某个引脚设置为输出模式。 2. 设置输出引脚的电平状态。通过编写相应的代码,我们可以将输出引脚的电平配置为高电平或低电平。这将决定LED是否点亮。 3. 可以加入延时函数来控制点亮和熄灭的时间间隔,以及闪烁的频率。 以上就是使用SmartFusion的MSS_GPIO模块实现点灯的简要过程。通过编写ARM处理器的代码,配置相关的寄存器,我们可以通过控制MSS_GPIO模块的引脚状态来实现LED的点亮和熄灭。这个简单的示例展示了SmartFusion芯片中FPGA和ARM之间的协同工作能力,为我们实现更复杂的功能提供了基础。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值