获取指向 LLVM-IR 中数组第一个元素的指针

Get pointer to first element of array in LLVM-IR

我想在LLVM-IR中实现一个字符串类型,我的计划如下:

声明字符串变量时,为i8*分配内存。

初始化变量时,将字符串存储在某处,将指向第一个元素的指针存储在先前分配的地址,并将字符串的长度保存在成员变量中。

问题是,我无法获得指向第一个元素的指针。 使用 IRBuilder (C++ API),我还创建了以下代码:

  %str2 = alloca i8*
  %1 = alloca [4 x i8]
  store [4 x i8] c"foo[=10=]", [4 x i8]* %1
  %2 = getelementptr [4 x i8], [4 x i8]* %1, i32 0
  store [4 x i8]* %2, i8** %str2

但是调用 llc 会出现以下错误:

error: stored value and pointer type do not match
  store [4 x i8]* %2, i8** %str2
        ^

当使用 clang 在相同的(char* 而不是字符串)代码上发出 llvm-ir 时,它发出以下内容:

%str2 = alloca i8*, align 8
store i8* %str, i8** %1, align 8
store i8* getelementptr inbounds ([4 x i8], [4 x i8]* @.str, i32 0, i32 0), i8** %str2, align 8

恕我直言,这看起来非常相似,但并不相同。

Clang 使字符串成为全局常量(希望这不是必需的),使用 getelementptr 的偏移量参数并将类型 i8* 赋予存储指令。

不幸的是,我无法找到任何 API 方法来显式地为存储指令指定类型,或使用偏移参数(我猜这甚至没有帮助)。

所以最后我的问题是:如何正确获取指向第一个数组元素的指针并存储它?

提前致谢

如评论中的link,解决方案是将[n x i8]* bitcast 为i8*

%str2 = alloca i8*
%1 = alloca [4 x i8]
store [4 x i8] c"foo[=10=]", [4 x i8]* %1
%2 = bitcast [4 x i8]* %1 to i8*
store i8* %2, i8** %str2