微波EDA网,见证研发工程师的成长!
首页 > 研发问答 > 嵌入式设计讨论 > FPGA,CPLD和ASIC > 关于FPGA嵌入式中定制自己的ip核

关于FPGA嵌入式中定制自己的ip核

时间:10-02 整理:3721RD 点击:
我在xps中新建了一个工程,使用microblaze软核,然后添加了自定制的ip核,生成得user logic中有一个软件可寻址的寄存器,我想在软件代码中实现写这个寄存器,将这个寄存器各个位连接到板子外边的8个发光二极管上,实现对应位的亮和灭,但我不知道怎么用软件访问这个寄存器,谁有这方面的经验,请指点一下,我用的是Spartan3an starter kit开发板,我自己写的软件c代码如下:
#include "led_control.h"
#include"xparameters.h"
#include "xio.h"
/************************** Function Definitions ***************************/
#define delay 100000
#define led_control_DEVICE_ID  XPAR_LED_CONTROL_0_BASEADDR//base address
int main(void)
{
    Xuint32 value=0x00000fff ;
    Xuint32 addr= led_control_DEVICE_ID;
  unsigned offset=1;
     int i;
   
    while(1)
    {
         
    {
          LED_CONTROL_mWriteSlaveReg0(addr,offset , value);
    for (i=0; i<delay; i++);  
           }
    }
   
     
     
}
函数LED_CONTROL_mWriteSlaveReg0(addr,offset , value)是自制ip添加完毕后在工程目录下的driver文件夹中自动生成的,它的原型是
/**
*
* Write/Read 32 bit value to/from LED_CONTROL user logic slave registers.
*
* @param   BaseAddress is the base address of the LED_CONTROL device.
* @param   RegOffset is the offset from the slave register to write to or read from.
* @param   Value is the data written to the register.
*
* @return  Data is the data from the user logic slave register.
*
* @note
* C-style signature:
*  void LED_CONTROL_mWriteSlaveRegn(Xuint32 BaseAddress, unsigned RegOffset, Xuint32 Value)
*  Xuint32 LED_CONTROL_mReadSlaveRegn(Xuint32 BaseAddress, unsigned RegOffset)
*
*/
#define LED_CONTROL_mWriteSlaveReg0(BaseAddress, RegOffset, Value) \
  XIo_Out32((BaseAddress) + (LED_CONTROL_SLV_REG0_OFFSET) + (RegOffset), (Xuint32)(Value))
#define LED_CONTROL_mReadSlaveReg0(BaseAddress, RegOffset) \
  XIo_In32((BaseAddress) + (LED_CONTROL_SLV_REG0_OFFSET) + (RegOffset)),

下载到板子中二极管没有反应,不知什么原因,请指教

你这个driver生成的函数可以看出,跟你是不是自定义IP基本没关系,它还是用了EDK里提供的API,XIo_In32这些东西。
但是你在写寄存器前,没有对LED进行实例化,加上试试吧。
如果不行,换个简单的,用它自带的专门用于写GPIO的API来控制LED(Xgpio_Initialize什么的,记不太清了),这个通过了再说。
当然还有一种可能就是你这个程序根本没跑起来,比如说你根本没初始化到bram里之类的错误。

前面我已经实现了用gpio控制led,这次就是想用定制ip核的方式控制,
有一点我搞不懂,上面红色部分的函数中那个regoffset不知该怎么赋值

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top