diff options
| author | Diogo N. Sampaio <diogo.sampaio@arm.com> | 2019-07-08 08:47:47 +0000 |
|---|---|---|
| committer | Diogo N. Sampaio <diogo.sampaio@arm.com> | 2019-07-08 08:47:47 +0000 |
| commit | 4ec445b813a1d479e3d9f9226c265fad66fd8f8c (patch) | |
| tree | bbd6a0ec8778b557c0a0b29e7b2625418c716b42 /clang/test/CodeGen/aarch64-neon-vuqadd-float-conversion-warning.c | |
| parent | 7d63be09b6a6ee8b940a15bf823bf2f90d34c18e (diff) | |
| download | bcm5719-llvm-4ec445b813a1d479e3d9f9226c265fad66fd8f8c.tar.gz bcm5719-llvm-4ec445b813a1d479e3d9f9226c265fad66fd8f8c.zip | |
[AArch64] Fix scalar vuqadd intrinsics operands
Summary:
Change the vuqadd scalar instrinsics to have the second argument as unsigned values, not signed,
accordingly to https://developer.arm.com/architectures/instruction-sets/simd-isas/neon/intrinsics
So now the compiler correctly warns that a undefined negative float conversion is being done.
Reviewers: LukeCheeseman, john.brawn
Reviewed By: john.brawn
Subscribers: john.brawn, javed.absar, kristof.beyls, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D64242
llvm-svn: 365300
Diffstat (limited to 'clang/test/CodeGen/aarch64-neon-vuqadd-float-conversion-warning.c')
| -rw-r--r-- | clang/test/CodeGen/aarch64-neon-vuqadd-float-conversion-warning.c | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/clang/test/CodeGen/aarch64-neon-vuqadd-float-conversion-warning.c b/clang/test/CodeGen/aarch64-neon-vuqadd-float-conversion-warning.c new file mode 100644 index 00000000000..0d66b6df358 --- /dev/null +++ b/clang/test/CodeGen/aarch64-neon-vuqadd-float-conversion-warning.c @@ -0,0 +1,26 @@ +// RUN: %clang_cc1 -triple arm64-none-linux-gnu -target-feature +neon \ +// RUN: -S -disable-O0-optnone -emit-llvm -o - %s 2>&1 | FileCheck %s + +#include <arm_neon.h> + +// Check float conversion is not accepted for unsigned int argument +int8_t test_vuqaddb_s8(){ + return vuqaddb_s8(1, -1.0f); +} + +int16_t test_vuqaddh_s16() { + return vuqaddh_s16(1, -1.0f); +} + +int32_t test_vuqadds_s32() { + return vuqadds_s32(1, -1.0f); +} + +int64_t test_vuqaddd_s64() { + return vuqaddd_s64(1, -1.0f); +} +// CHECK: warning: implicit conversion of out of range value from 'float' to 'uint8_t' (aka 'unsigned char') is undefined +// CHECK: warning: implicit conversion of out of range value from 'float' to 'uint16_t' (aka 'unsigned short') is undefined +// CHECK: warning: implicit conversion of out of range value from 'float' to 'uint32_t' (aka 'unsigned int') is undefined +// CHECK: warning: implicit conversion of out of range value from 'float' to 'uint64_t' (aka 'unsigned long') is undefined + |

