diff options
| author | Sven van Haastregt <sven.vanhaastregt@arm.com> | 2019-09-25 09:12:59 +0000 |
|---|---|---|
| committer | Sven van Haastregt <sven.vanhaastregt@arm.com> | 2019-09-25 09:12:59 +0000 |
| commit | 2a69ed0bc87bb657b31aab5250f6dc158068d220 (patch) | |
| tree | 0195b510e5e0b787461b8f2c2d0fdc6352ea7980 | |
| parent | a3d337a9a7d00d82bb190c5e551181d3998f6b98 (diff) | |
| download | bcm5719-llvm-2a69ed0bc87bb657b31aab5250f6dc158068d220.tar.gz bcm5719-llvm-2a69ed0bc87bb657b31aab5250f6dc158068d220.zip | |
[OpenCL] Add image query builtin functions
Add the image query builtin functions from the OpenCL C specification.
Patch by Pierre Gondois and Sven van Haastregt.
Differential Revision: https://reviews.llvm.org/D67713
llvm-svn: 372833
| -rw-r--r-- | clang/lib/Sema/OpenCLBuiltins.td | 25 | ||||
| -rw-r--r-- | clang/test/SemaOpenCL/fdeclare-opencl-builtins.cl | 4 |
2 files changed, 29 insertions, 0 deletions
diff --git a/clang/lib/Sema/OpenCLBuiltins.td b/clang/lib/Sema/OpenCLBuiltins.td index 20b574e0a57..29861405946 100644 --- a/clang/lib/Sema/OpenCLBuiltins.td +++ b/clang/lib/Sema/OpenCLBuiltins.td @@ -593,6 +593,31 @@ foreach aQual = ["WO", "RW"] in { def : Builtin<"write_imagef", [Void, ImageType<Image2dArrayDepth, aQual>, VectorType<Int, 4>, Float]>; } +// --- Table 25: Image Query Functions --- +foreach aQual = ["RO", "WO", "RW"] in { + foreach imgTy = [Image1d, Image1dBuffer, Image2d, Image3d, + Image1dArray, Image2dArray, Image2dDepth, + Image2dArrayDepth] in { + foreach name = ["get_image_width", "get_image_channel_data_type", + "get_image_channel_order"] in { + def : Builtin<name, [Int, ImageType<imgTy, aQual>]>; + } + } + foreach imgTy = [Image2d, Image3d, Image2dArray, Image2dDepth, + Image2dArrayDepth] in { + def : Builtin<"get_image_height", [Int, ImageType<imgTy, aQual>]>; + } + def : Builtin<"get_image_depth", [Int, ImageType<Image3d, aQual>]>; + foreach imgTy = [Image2d, Image2dArray, Image2dDepth, + Image2dArrayDepth] in { + def : Builtin<"get_image_dim", [VectorType<Int, 2>, ImageType<imgTy, aQual>]>; + } + def : Builtin<"get_image_dim", [VectorType<Int, 4>, ImageType<Image3d, aQual>]>; + foreach imgTy = [Image1dArray, Image2dArray, Image2dArrayDepth] in { + def : Builtin<"get_image_array_size", [Size, ImageType<imgTy, aQual>]>; + } +} + // OpenCL extension v2.0 s5.1.9: Built-in Image Read Functions // --- Table 8 --- foreach aQual = ["RO"] in { diff --git a/clang/test/SemaOpenCL/fdeclare-opencl-builtins.cl b/clang/test/SemaOpenCL/fdeclare-opencl-builtins.cl index 6c32e125712..d8d37938414 100644 --- a/clang/test/SemaOpenCL/fdeclare-opencl-builtins.cl +++ b/clang/test/SemaOpenCL/fdeclare-opencl-builtins.cl @@ -71,6 +71,8 @@ kernel void basic_image_readonly(read_only image2d_t image_read_only_image2d) { resf = read_imagef(image_read_only_image2d, i2); res = read_imageh(image_read_only_image2d, i2); res = read_imageh(image_read_only_image2d, sampler, i2); + + int imgWidth = get_image_width(image_read_only_image2d); } #if __OPENCL_C_VERSION__ >= CL_VERSION_2_0 @@ -79,6 +81,8 @@ kernel void basic_image_readwrite(read_write image3d_t image_read_write_image3d) int4 i4; write_imageh(image_read_write_image3d, i4, h4); + + int imgDepth = get_image_depth(image_read_write_image3d); } #endif // __OPENCL_C_VERSION__ >= CL_VERSION_2_0 |

