0

我正在寻找一个 Verilog 函数来将我的 ASCII 输入字符串转换为十六进制输出。我不确定我是否可以在 C 中做到这一点并与 Verilog 一起使用。到目前为止,我能够使用以下方法将输入的 ASCII 字符串打印为十六进制值:

printf("Hexadecimal Output for <CALL-ID>: ");
for(c = 0; c < strlen(callid); c++)
{
  printf("TO: %x ", callid[c]);
}

有没有办法将输出保存在文本/csv 文件中,并使其可供我的 verilog 代码片段访问?

或者请让我知道 Verilog 本身是否有更简单的方法?

4

1 回答 1

1

要输出到文本文件,您可以执行以下操作:

static int string_to_hex_file(const char *filename, const char *string)
{
    FILE            *out;
    const char      *s;

    if((out = fopen(filename, "w")) == NULL)
      return 0;

    fprintf(out, "\"%s\", ", string);
    for(s = string; *s; s++)
    {
        if(s != string)
            fprintf(out, ", ");
        fprintf(out, "0x%02x", (unsigned char) *s);
    }
    fprintf(out, "\n");

    fclose(out);
    return 1;
}

示例输出string == "this is a test"

"this is a test", 0x74, 0x68, 0x69, 0x73, 0x20, 0x69, 0x73, 0x20, 0x61, 0x20, 0x74, 0x65, 0x73, 0x74

错误检查当然可以改进,您可能需要调整输出格式以满足您的需要。

于 2010-11-09T08:47:58.243 回答