山疯子 2023-05-15 08:38 采纳率: 50%
浏览 65
已结题

开发microblaze,怎么让M_AXI_DC的128数据通道传输128的数据。

在我使用zynq7000开发板进行开发时候,用到microbalze软核,配置该软核使用M_AXI_DC接口。且该接口数据宽度如图为128位。

img

我希望能在进行软件开发的时候,能定义一个数组,把该数据的128位数据一次性 通过mb的AXI_DC接口写入到block design的ip核中。
现在问题是mb的AXI_DC接口写的数据宽度是128位,但是只能一次性写32为。然后再配合字节
有效通道(strob)进行数据传输。

这是用于测试的c语言代码。

#include <stdio.h>

#include "xil_printf.h"
#include "string.h"
#include "xil_io.h"
#include "xil_cache.h"
#include "xbasic_types.h"

typedef unsigned   int    u32_t;

#define word_length 8
//#define buf_len     4
#define axi_data_baseaddr ((u32_t *) 0x77000000 )

u32_t sent_data_buf[]={0x0011,0x2233,0x4455,0x6677,0x8899,0xaabb,0xccdd,0xeeff};


int main()
{
    while (1){
        memcpy(axi_data_baseaddr,sent_data_buf,word_length);
    }
    return 0;
}

这是观察到的现象。

img

img


这里一直重复传sent_data_buf的前32位数据,而且还高低字节乱序了。
怎么样才能让数据通道一次性传输的是我想要的sent_data_buf全部数据。

  • 写回答

5条回答 默认 最新

  • yy64ll826 2023-05-16 11:13
    关注

    MicroBlaze最小系统+UART/CAN/GPIO

    可以借鉴下
    https://blog.csdn.net/liuhandd/article/details/123899620

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

问题事件

  • 系统已结题 5月24日
  • 已采纳回答 5月16日
  • 创建了问题 5月15日

悬赏问题

  • ¥15 校内二手商品转让网站
  • ¥20 高德地图聚合图层MarkerCluster聚合多个点,但是ClusterData只有其中部分数据,原因应该是有经纬度重合的地方点,现在我想让ClusterData显示所有点的信息,如何实现?
  • ¥100 求Web版SPC控制图程序包调式
  • ¥20 指导如何跑通以下两个Github代码
  • ¥15 大家知道这个后备文件怎么删吗,为啥这些文件我只看到一份,没有后备呀
  • ¥15 C++为什么这个代码没报错运行不出来啊
  • ¥15 一道ban了很多东西的pyjail题
  • ¥15 关于#r语言#的问题:如何将生成的四幅图排在一起,且对变量的赋值进行更改,让组合的图漂亮、美观@(相关搜索:森林图)
  • ¥15 C++识别堆叠物体异常
  • ¥15 微软硬件驱动认证账号申请