1

我正在使用 IBM 的 XL C 编译器在 AIX 上工作。我遇到了一个编译错误,我不确定如何继续:

$ xlc -g3 -O0 -qarch=pwr8 -qaltivec fips197-p8.c -o fips197-p8.exe
"fips197-p8.c", line 59.16: 1506-754 (W) The parameter type is not valid for a function of this linkage type.

相关源代码如下所示。完整的源代码可在fips197-p8.c. 源代码是 Power 8__cipher__vcipherlast. 它有一个主函数和几个 C 函数。Effectively 是 Power 8 AES 的最小完整工作示例。

$ cat -n fips197-p8.c
...

11  #if defined(__xlc__) || defined(__xlC__)
12  // #include <builtins.h>
13  #include <altivec.h>
14  typedef vector unsigned char uint8x16_p8;
15  typedef vector unsigned int uint64x2_p8;
16  #else
17  #include <altivec.h>
18  typedef vector unsigned char uint8x16_p8;
19  typedef vector unsigned long long uint64x2_p8;
20  #endif
...

52  uint8x16_p8 Load8x16(const uint8_t src[16])
53  {
54  #if defined(__xlc__) || defined(__xlC__)
55          /* IBM XL C/C++ compiler */
56  # if defined(__LITTLE_ENDIAN__)
57          return vec_xl_be(0, src);
58  # else
59          return vec_xl(0, src);
60  # endif
61  #else
62          /* GCC, Clang, etc */
63
64  #endif
65  }

编译器版本如下所示。我们不控制编译器,所以这就是我们所拥有的:

$ xlc -qversion
IBM XL C/C++ for AIX, V13.1.3 (5725-C72, 5765-J07)
Version: 13.01.0003.0000

vec_xl在 little-endian 上很好。vec_xl因为 big-endian 给我们带来了麻烦。

有什么问题,我该如何解决?

4

1 回答 1

2

因此,一些猜测(由 OP 评论确认,因为它有效)让我认为这种神秘而晦涩的“参数类型对于这种链接类型的函数无效”。消息(谷歌第一个匹配是这个问题!)可能是一个限定符问题。

由于您的合同是

uint8x16_p8 Load8x16(const uint8_t src[16])

考虑到选项和当前字节顺序,编译器/原型可能认为vec_xl_be需要一个非常量参数为src.

所以通过 aconst违反了合同(这是通知你的最好方法xlc

所以要么更改为

uint8x16_p8 Load8x16(uint8_t src[16])

(有放弃对所有调用者的恒定约束的风险)

const通过非常量强制转换(就像我们在原型缺少时所做的那样const,但数据实际上并未在函数中修改):

vec_xl_be(0,(uint8_t*)src);
于 2017-09-09T07:52:02.233 回答