aclrtcCreateProg
产品支持情况
功能说明
通过给定的参数,创建编译程序的实例。
函数原型
aclError aclrtcCreateProg(aclrtcProg *prog, const char *src, const char *name, int numHeaders, const char **headers, const char **includeNames)
参数说明
表 1 接口参数说明
一个指向数组的指针,数组中的每个元素都是以'\0'结尾的字符串,表示头文件的源代码内容。当numHeaders为0时,此参数可以设置为nullptr。 |
||
返回值说明
aclError为int类型变量,详细说明请参考RTC错误码。
约束说明
无
调用示例
aclrtcProg prog;
const char *src = R""""(
#include "kernel_operator.h"
#include "my_const_a.h"
#include "my_const_b.h"
extern "C" __global__ __aicore__ void hello_world(GM_ADDR x)
{
KERNEL_TASK_TYPE_DEFAULT(KERNEL_TYPE_AIC_ONLY);
*x = *x + MY_CONST_A + MY_CONST_B;
}
)"""";
const char* headerSrcA = R"(
#ifndef CONST_A_H
#define CONST_A_H
const int MY_CONST_A = 100;
#endif // CONST_A_H
)";
const char* includeNameA = "my_const_a.h";
const char* headerSrcB = R"(
#ifndef CONST_B_H
#define CONST_B_H
const int MY_CONST_B = 50;
#endif // CONST_B_H
)";
const char* includeNameB = "my_const_b.h";
const char* headersArray[] = { headerSrcA, headerSrcB };
const char* includeNameArray[] = { includeNameA, includeNameB };
aclError result = aclrtcCreateProg(&prog, src, "hello_world", 2, headersArray, includeNameArray);