gpt4 book ai didi

c++ - 如何在 C++ 中进行 SystemVerilog 风格的位 vector 切片赋值?

转载 作者:太空狗 更新时间:2023-10-29 20:15:26 28 4
gpt4 key购买 nike

我正在将一些 SystemVerilog 代码移植到 SystemC/C++。我正在使用 std::bitset 来表示位 vector ,但我已经看到它没有提供访问切片的方法。

例如,如果我想使用 SystemVerilog 代码将 reg1 设置为 reg2 的第 4-8 位:

bit [3:0] reg1;
bit [15:0] reg2;
reg1 = reg2[7:4];

我如何使用 std::bitset 做到这一点?

bitset<4> reg1;
bitset<16> reg2;
reg1[0] = reg2[4];
reg1[1] = reg2[5];
reg1[2] = reg2[6];
reg1[3] = reg2[7];

有没有更好的办法?

最佳答案

现在您正在使用 SystemC,为什么不使用 sc_bv<> 来原生表示 HDL 信号?由于 SystemC 有一组数据类型来表示 HDL 位/逻辑和字逻辑运算符,因此将 SystemVerilog/Verilog 数据类型映射到 C/C++ 代码应该更容易。

sc_bv<4> reg1;
sc_bv<16> reg2;
reg1 = reg2.range(7,4);

关于c++ - 如何在 C++ 中进行 SystemVerilog 风格的位 vector 切片赋值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13201507/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com