错误:表达式不可分配C ++结构

时间:2016-10-28 05:23:12

标签: c++ struct vivado-hls

我正在用C ++编写一个用于FPGA的普通带宽内核,它正在从主机内存读取内容并将其写回主机中的不同位置。 我使用结构,其中一个元素是输入和输出缓冲区的地址。高级综合工具为以下代码中的最后一行提供错误。

    struct addr_struct {
              ap_uint<64> address;
              ap_uint<32> size;
              ap_uint<16> type;
              ap_uint<16> flags;
      };
    struct addr_struct CA_INPUT;
    struct addr_struct CA_OUTPUT;
    din_mem = 0x00;
    dout_mem = 0x00;
    ap_uint<32> i;
    ap_uint<512> temp;
    ap_uint<512> *din_mem;
    ap_uint<512> *dout_mem; 
    for(i=0; i<2048; i++){
    temp= (ap_uint<512> *)(din_mem + CA_INPUT.address + i*64);
    (ap_uint<512> *)(dout_mem + CA_OUTPUT.address + i*64) = temp;}

1 个答案:

答案 0 :(得分:3)

我假设您要分配到dout_mem中的指针,因此在(ap_uint<512> *)之前缺少取消引用(请注意开头的星号):

*(ap_uint<512> *)(dout_mem + CA_OUTPUT.address + i*64) = temp;