在vitis中bit位赋值如何优化到一拍完成

使用vitis实现硬件代码时,经常遇到不是整拍对齐的情况,比如:

ap_uint<128> a;

ap_uint<64> b10;

int pad,pos;

/// 计算pos,pad .....

a(pos-1,0) = bpad(63,pos);

a(63+pos,pos) = bpad+1;

a(127,64+pos)=bpad+2;

上述代码要3拍才能完成,如果做到1拍需要做以下优化

ap_uint<64>& get_one_pad(ap_uint<64>& data1,ap_uint<64>& data2,int pos)

{

ap_uint<64> data;

data(63-pos,0) = data1(63,pos);

data(63,64-pos)=data2(pos-1,0);

return data;

}

///**************************************************************************************

ap_uint<128> a;

ap_uint<64> b10;

int pad,pos;

/// 计算pos,pad .....

/// 1 这块代码的目的是将b中需要用到的数据copy出来,copy两份是为了后面赋值避免冲突

ap_uint<64> x13;

ap_uint<64> x23;

for( int i=0;i<2;i++)

{

x1i = bpad;

x2i = bpad;

}

/// 2这块代码的目的是将数据分别放到两个64bit区域

ap_uint<64> d2;

d0 = get_one_pad(x10,x21,pos);

d1 = get_one_pad(x11,x22,pos);

/// 3最终赋值

a(63,0) = d0;

a(127,64)=d1;

上述代码通过三步解决了每次数据操作都是整拍的问题,这样后续即使一拍无法完成,也可以流水打拍完成,比如a如果是ram,就可以方便的流水打拍了。

ps:在实现上述功能的时候发现vitis对函数inline是在verilog层次的,就是说它先把c代码编译成verilog在inline,这样导致本来函数在从c到verilog过程中可以优化的地方无法优化了。比如:get_one_pad函数如果inline就无法一拍完成了,这种情况也不能用pipeline,只能让编译器自动生成

相关推荐
rqtz18 分钟前
【机器人】ROS结合Qt开发上位机软件工作空间配置
开发语言·qt·ros
代码中介商11 小时前
C++左值与右值:核心判断法则详解
开发语言·c++
JAVA96511 小时前
JAVA面试-并发篇 05-并发包AQS队列实现原理是什么
java·开发语言·面试
Halo_tjn11 小时前
反射与设计模式1
java·开发语言·算法
珊瑚里的鱼12 小时前
手撕单例模式中的饿汉模式和懒汉模式,懒汉模式还要再多加一个C++11版本的
开发语言·c++·单例模式
_不会dp不改名_12 小时前
python-opencv环境搭建
开发语言·python·opencv
HappyAcmen12 小时前
9.复盘API全套流程
开发语言·python
charlie11451419112 小时前
通用GUI编程技术——图形渲染实战(四十五)——D3D12资源与堆管理:从上传到驻留
开发语言·3d·图形渲染·win32
不会C语言的男孩12 小时前
C++ Primer 第12章:动态内存
开发语言·c++
踏着七彩祥云的小丑13 小时前
Go学习第1天:入门
开发语言·学习·golang·go