1

我一直在尝试使用 -pg 编译我的代码以在模拟器中启用分析,一旦我这样做,它就会给我链接器错误。

编译命令

hexagon-clang++ main.cpp -o hello -mv62 -pg

错误

hexagon-clang++  main.cpp -o hello -mv62 -pg
Error: /tmp/main-924ac3.o(.text+0x30): undefined reference to `mcount'
Error: /tmp/main-924ac3.o(.text+0x130): undefined reference to `mcount'
Fatal: Linking had errors.

这是我第一次为 DSP 芯片,特别是六边形 682 编写代码。除了程序员参考手册之外,还有其他教程或参考资料,因为它们在帮助我理解事情如何工作方面并不是很有用。特别是我不明白 SIMD 编程是如何工作的。我不确定 SIMD 寄存器的大小。此外,在 DSP 芯片中使用浮点似乎不是一个好主意。那么如果我将我的代码转换为使用定点会更好。

4

1 回答 1

2

您可以使用它hexagon-sim来生成分析数据,而无需重新构建已检测的二进制文件。

hexagon-sim --profile ./hello将生成消费gmon所需的输入文件。hexagon-gprof

例如(取自 SDK 3.3.3 Examples/

hexagon-clang -O2 -g -mv5   -c -o mandelbrot.o mandelbrot.c
hexagon-clang -O2 -g -mv5 mandelbrot.o -o mandelbrot -lhexagon
hexagon-sim -mv5 --timing --profile mandelbrot
hexagon-gprof mandelbrot gmon.t*

另请注意,SDK 附带了hexagon-profiler一个更丰富的工具,可让您深入查看性能计数器——除了执行哪些代码和执行频率之外的信息。

有关详细信息,请参阅“Hexagon Profiler 用户指南”(文档号 80-N2040-10 A)。

除了程序员参考手册之外,是否还有其他教程或参考资料,因为它们在帮助我理解事物的工作方式方面并不是很有用。

特别是我不明白 SIMD 编程是如何工作的。我不确定 SIMD 寄存器的大小。

Hexagon 的矢量编程扩展名为“HVX”。https://developer.qualcomm.com/software/hexagon-dsp-sdk/tools提供了一个特定于 HVX 的 PRM——它描述了不同的 512 位和 1024 位矢量模式。

于 2018-05-02T01:33:06.263 回答