forked from OSchip/llvm-project
[OpenCL] Do not generate "kernel_arg_type_qual" metadata for non-pointer args
Summary: "kernel_arg_type_qual" metadata should contain const/volatile/restrict tags only for pointer types to match the corresponding requirement of the OpenCL specification. OpenCL 2.0 spec 5.9.3 Kernel Object Queries: CL_KERNEL_ARG_TYPE_VOLATILE is returned if the argument is a pointer and the referenced type is declared with the volatile qualifier. [...] Similarly, CL_KERNEL_ARG_TYPE_CONST is returned if the argument is a pointer and the referenced type is declared with the restrict or const qualifier. [...] CL_KERNEL_ARG_TYPE_RESTRICT will be returned if the pointer type is marked restrict. Reviewers: Anastasia, cfe-commits Reviewed By: Anastasia Subscribers: bader, yaxunl Differential Revision: https://reviews.llvm.org/D31321 llvm-svn: 299192
This commit is contained in:
parent
2a7d39dfe8
commit
ba8b84d7fb
|
@ -610,11 +610,6 @@ static void GenOpenCLArgMetadata(const FunctionDecl *FD, llvm::Function *Fn,
|
||||||
|
|
||||||
argBaseTypeNames.push_back(llvm::MDString::get(Context, baseTypeName));
|
argBaseTypeNames.push_back(llvm::MDString::get(Context, baseTypeName));
|
||||||
|
|
||||||
// Get argument type qualifiers:
|
|
||||||
if (ty.isConstQualified())
|
|
||||||
typeQuals = "const";
|
|
||||||
if (ty.isVolatileQualified())
|
|
||||||
typeQuals += typeQuals.empty() ? "volatile" : " volatile";
|
|
||||||
if (isPipe)
|
if (isPipe)
|
||||||
typeQuals = "pipe";
|
typeQuals = "pipe";
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,7 +2,8 @@
|
||||||
// RUN: %clang_cc1 %s -cl-std=CL2.0 -emit-llvm -o - -triple spir-unknown-unknown -cl-kernel-arg-info | FileCheck %s -check-prefix ARGINFO
|
// RUN: %clang_cc1 %s -cl-std=CL2.0 -emit-llvm -o - -triple spir-unknown-unknown -cl-kernel-arg-info | FileCheck %s -check-prefix ARGINFO
|
||||||
|
|
||||||
kernel void foo(__global int * restrict X, const int Y,
|
kernel void foo(__global int * restrict X, const int Y,
|
||||||
volatile int anotherArg, __constant float * restrict Z) {
|
volatile int anotherArg, __constant float * restrict Z,
|
||||||
|
__global volatile int * V, __global const int * C) {
|
||||||
*X = Y + anotherArg;
|
*X = Y + anotherArg;
|
||||||
}
|
}
|
||||||
// CHECK: define spir_kernel void @foo{{[^!]+}}
|
// CHECK: define spir_kernel void @foo{{[^!]+}}
|
||||||
|
@ -60,11 +61,11 @@ kernel void foo5(myImage img1, write_only image1d_t img2) {
|
||||||
// CHECK-NOT: !kernel_arg_name
|
// CHECK-NOT: !kernel_arg_name
|
||||||
// ARGINFO: !kernel_arg_name ![[MD54:[0-9]+]]
|
// ARGINFO: !kernel_arg_name ![[MD54:[0-9]+]]
|
||||||
|
|
||||||
// CHECK: ![[MD11]] = !{i32 1, i32 0, i32 0, i32 2}
|
// CHECK: ![[MD11]] = !{i32 1, i32 0, i32 0, i32 2, i32 1, i32 1}
|
||||||
// CHECK: ![[MD12]] = !{!"none", !"none", !"none", !"none"}
|
// CHECK: ![[MD12]] = !{!"none", !"none", !"none", !"none", !"none", !"none"}
|
||||||
// CHECK: ![[MD13]] = !{!"int*", !"int", !"int", !"float*"}
|
// CHECK: ![[MD13]] = !{!"int*", !"int", !"int", !"float*", !"int*", !"int*"}
|
||||||
// CHECK: ![[MD14]] = !{!"restrict", !"const", !"volatile", !"restrict const"}
|
// CHECK: ![[MD14]] = !{!"restrict", !"", !"", !"restrict const", !"volatile", !"const"}
|
||||||
// ARGINFO: ![[MD15]] = !{!"X", !"Y", !"anotherArg", !"Z"}
|
// ARGINFO: ![[MD15]] = !{!"X", !"Y", !"anotherArg", !"Z", !"V", !"C"}
|
||||||
// CHECK: ![[MD21]] = !{i32 1, i32 1, i32 1, i32 1}
|
// CHECK: ![[MD21]] = !{i32 1, i32 1, i32 1, i32 1}
|
||||||
// CHECK: ![[MD22]] = !{!"read_only", !"read_only", !"write_only", !"read_write"}
|
// CHECK: ![[MD22]] = !{!"read_only", !"read_only", !"write_only", !"read_write"}
|
||||||
// CHECK: ![[MD23]] = !{!"image1d_t", !"image2d_t", !"image2d_array_t", !"image1d_t"}
|
// CHECK: ![[MD23]] = !{!"image1d_t", !"image2d_t", !"image2d_array_t", !"image1d_t"}
|
||||||
|
|
Loading…
Reference in New Issue