4周PADS强化班 HOT
林超文手把手教你学!
张飞暑期特训班
教你1000种电路设计思路
年度IP:PFC电源
张飞硬件电路之PFC全集
30天AD项目众筹
参与免费送VIP+原创视频
最全模电系列教程 NEW
运放、ADC、电磁兼容

[资料] FPGA MicroBalze嵌入式设计-----添加用户自定义IP,IP与MicroBlaze之间数据交互

[复制链接]

技术员

发表于 2018-1-9 14:53:42   1437 查看 0 回复 显示全部楼层 倒序浏览
分享
本帖最后由 何立立 于 2018-1-9 17:29 编辑

在Microblaze系统中添加用户自定义IP,可以使用Xilinx Platform Studio (XPS) Create/Import Peripheral Wizard向导进行配置。
如图添加一个Custom PWM IP挂在PLB总线上。
步骤如下:
(1)创建IP:
Step1:双击mb_system module 打开 XPS,在工具栏中中Hardware > Create or Import Peripheral… 点击 Next。
step2:确保Create templates for a new peripheral被选择中,然后继续点击Next,选择To an XPS project然后再点击Next。
step3:输入被创建的IP名字,比如: plb_pwm, 然后在点击Next。
step4:选择 Processor Local Bus (PLB v4.6) 总线协议,然后点击 Next。
step5:IPIF是用户自定义IP接口。包含了user_logic 用户逻辑,IPIF相当于MicroBlaze挂载的外设。可以选择通过软件寄存器来控制用户IP。点击Next可以选择寄存器位宽和个数。
            其中IPIC是user_logic 与PLC总线之间数据交互的一系列信号。
点击NEXT完成配置。
(2)设计编写IP逻辑,实现MicroBlaze与PWM IP之间的通信:
   生成IP 模块后,还需要根据用户需求编写IP的控制逻辑,实现相应的IP功能。打开工程pcores路劲目录会看到生成的用户定义的plb_pwm_v1_00_a模块。
打开hdl目录中的plb_pwm.vhd文件进行编写:
step1:添加端口声明
  1. <font face="宋体" size="4">-- ADD USER PORTS BELOW THIS LINE ------------------
  2. PWM_Out : out std_logic;
  3. -- ADD USER PORTS ABOVE THIS LINE--------------------</span> </font>
复制代码

step2:用户信号声明
  1. <font face="宋体" size="4">--USER signal declarations added here, as needed for user logic
  2. signal duty_cycle : std_logic_vector (11 downto 0);
  3. signal fcount : std_logic_vector (11 downto 0);</span>  </font>
复制代码

step3:编写用户控制逻辑
  1. <font face="宋体" size="4">--USER logic implementation added here
  2. -- Duty cycle is controlled by the software controlled register
  3. duty_cycle <= slv_reg0(20 to 31);
  4. -- 12-bit rollover counter
  5. counter : process (Bus2IP_Clk)
  6. begin
  7. if (Bus2IP_Clk'event and Bus2IP_Clk = '1') then
  8. if Bus2IP_Reset = '1' then
  9. fcount <= (others => '0');
  10. else fcount <= fcount + 1;
  11. end if;
  12. end if;
  13. end process counter;
  14. -- Enable the output for the duty cycle selected
  15. PWM_Out <= '1' when (fcount < duty_cycle) else '0';</span>  </font>
复制代码
slv_reg0是软件传输给IP的数据,即MicroBlaze通过PLB写入到PWM IP的数据,用来和12bit计数器fcout比较,从而决定何时PWM_Out产生脉冲。

step4:保存文件代码。
step5:打开plb_pwm_v1_00_a\data 文件, 添加PWM_OUT端口。
  1. <font face="宋体" size="4">## Ports
  2. PORT PWM_Out = "", DIR = O</span> </font>
复制代码
step6:保存文件,完成以后IP的创建,在xps中像调用其他IP一样即可,PWM_OUT端口链接设置外部输出,连接都FPGA外部控制LED。




高级模式
您需要登录后才可以回帖 登录 | 注册

4周PADS强化班 HOT
林超文手把手教你学!
张飞暑期特训班
教你1000种电路设计思路
年度IP:PFC电源
张飞硬件电路之PFC全集
30天AD项目众筹
参与免费送VIP+原创视频
最全模电系列教程 NEW
运放、ADC、电磁兼容
关闭

站长推荐 上一条 /9 下一条

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

推荐专区

技术干货集中营

专家问答

用户帮助┃咨询与建议┃版主议事

工程师杂谈

项目|工程师创意

招聘|求职}工程师职场

论坛电子赛事

社区活动专版

发烧友活动

-

嵌入式论坛

ARM技术论坛

Android论坛

Linux论坛

单片机/MCU论坛

MSP430技术论坛

FPGA|CPLD|ASIC论坛

STM32/STM8技术论坛

NXP MCU 技术论坛

PIC单片机论坛

DSP论坛

瑞萨单片机论坛

嵌入式系统论坛

-

电源技术论坛

电源技术论坛

无线充电技术

-

硬件设计论坛

PCB设计论坛

电路设计论坛

电子元器件论坛

控制|传感

总线技术|接口技术

-

测试测量论坛

LabVIEW论坛

Matlab论坛

测试测量技术专区

仪器仪表技术专区

-

EDA设计论坛

multisim论坛

PADS技术论坛

Protel|AD|DXP论坛

Allegro论坛

proteus论坛|仿真论坛

EasyEDA-中国人自已的EDA工具

Orcad论坛

-

综合技术与应用

电机控制

智能电网

光电及显示

工程资源中心

汽车电子技术论坛

医疗电子论坛

-

开源硬件

-

无线通信论坛

无线通信技术专区

天线|RF射频|微波|雷达技术

-

IC设计论坛

芯片测试与失效分析

Mixed Signal/SOC[数模混合芯片设计]

Analog/RF IC设计

设计与制造封装测试

-

厂商专区

TI论坛

TI Deyisupport社区

-

检测技术与质量

电磁兼容(EMC)设计与整改

安规知识论坛

检测与认证

-

消费电子论坛

手机技术论坛

平板电脑/mid论坛

音视/视频/机顶盒论坛

-

电子论坛综合区

聚丰众筹官方社区

新人报道区

聚丰供应链

-

论坛服务区

-

供求信息发布

供需广告

电子展览展会专区

芯片求购|供应发布区