Specman - 如何将struct转换为字符串列表

问题描述 投票:1回答:1

将struct转换为字符串列表的有效方法是什么(所有字段的列表 - 名称和值)?

例如以下结构:

struct spot_top_s {
   %D_LDO_SFS_EN : uint(bits:1);
   %D_COMP3P3_ACC_EN : uint(bits:1);
   %D_BGCOMP_TRIM : uint(bits:6);
   %spot_top_jtagtest_out : bit;
   %spot_top_jtagtest_in  : bit;

}; // spot_top_s
struct verification specman
1个回答
3
投票

实际上,可以使用反射来实现接受任何结构的通用代码。这是这种代码的一个例子。你可以修改它,例如 - 只添加列表物理字段(通过调用“if it.is_physical()”)等。

extend sys {
    get_fields(input_struct : any_struct) : list of string is {
        var struct_rf : rf_struct;
        struct_rf = rf_manager.get_struct_of_instance( input_struct);

        var struct_fields : list of rf_field;
        struct_fields = struct_rf.get_fields();

        var field_type_rf : rf_type;
        var field_value_unsafe : untyped;

        for each in struct_fields {
            result.add(it.get_name());
            var f:=  it.get_value_unsafe(input_struct);
            field_type_rf = it.get_type();
            field_value_unsafe = it.get_value_unsafe(input_struct);
            result.add(field_type_rf.value_to_string(field_value_unsafe));
        };
    };

    // usage example:
    my_spot_top : spot_top_s;
    post_generate() is also {
        print get_field(my_spot_top);
    };
};
© www.soinside.com 2019 - 2024. All rights reserved.