ZHCUA98E january   2018  – march 2023 TDA4VM , TDA4VM-Q1

 

  1.   摘要
  2. 1关于本文档
    1. 1.1 相关文档
    2. 1.2 商标
  3. 2将 C 源代码从 C6000 迁移到 C7000
    1. 2.1  编译器选项
    2. 2.2  原生矢量数据类型
    3. 2.3  类型限定符:near 和 far
    4. 2.4  64 位 long 类型
    5. 2.5  对控制寄存器的引用
    6. 2.6  存储器映射外设
    7. 2.7  运行时支持
    8. 2.8  迁移头文件 c6x_migration.h 的内容
      1. 2.8.1 支持的宏
      2. 2.8.2 不受支持的宏
      3. 2.8.3 传统数据类型
      4. 2.8.4 传统内在函数
    9. 2.9  伽罗瓦域乘法指令
    10. 2.10 有关迁移代码的性能注意事项
      1. 2.10.1 UNROLL Pragma
      2. 2.10.2 子矢量访问
      3. 2.10.3 16x16 和 16x32 位乘法
      4. 2.10.4 __x128_t 类型
      5. 2.10.5 无符号数组偏移
      6. 2.10.6 流引擎和流地址生成器
      7. 2.10.7 其他优化指南
  4. 3主机仿真
  5. 4修订历史记录
    1.     29
    2.     30

16x16 和 16x32 位乘法

C7000 不支持访问源字(MPYH、MPYHL 等)的高 16 位的 16 位 x 16 位乘法。模拟可能进行右移的此类访问运算。请注意,访问和乘法可以由编译器矢量化。

C7000 使用 C6MPYHIR 和 C6MPYLIR 指令执行 16 位 x 32 位乘法(MPYHI、MPYLI 等)。这些指令没有矢量形式,因此在循环中使用这些指令可能会限制或消除编译器的矢量化。

旧文本:C7000 不支持访问源字(MPYH、MPYHL 等)的高 16 位的 16 位 x 16 位乘法。在乘法之前使用右移来模拟此类运算。同样,不支持 16 位 x 32 位乘法(MPYHI、MPYLI 等)。在乘法运算之前使用符号扩展来模拟此类运算。