Skip to content

Commit a96f846

Browse files
committedJan 21, 2019
[AArch64] Use LL for 64-bit intrinsic arguments
The ACLE states that 64-bit crc32, wsr, rsr and rbit operands are uint64_t so we should have the clang builtin match this description - which is what we already do for AArch32. Differential Revision: https://reviews.llvm.org/D56852 llvm-svn: 351740
1 parent 4e4c066 commit a96f846

File tree

3 files changed

+20
-15
lines changed

3 files changed

+20
-15
lines changed
 

‎clang/include/clang/Basic/BuiltinsAArch64.def

+5-5
Original file line numberDiff line numberDiff line change
@@ -32,7 +32,7 @@ BUILTIN(__builtin_arm_clrex, "v", "")
3232

3333
// Bit manipulation
3434
BUILTIN(__builtin_arm_rbit, "UiUi", "nc")
35-
BUILTIN(__builtin_arm_rbit64, "LUiLUi", "nc")
35+
BUILTIN(__builtin_arm_rbit64, "LLUiLLUi", "nc")
3636

3737
// HINT
3838
BUILTIN(__builtin_arm_nop, "v", "")
@@ -49,8 +49,8 @@ BUILTIN(__builtin_arm_crc32h, "UiUiUs", "nc")
4949
BUILTIN(__builtin_arm_crc32ch, "UiUiUs", "nc")
5050
BUILTIN(__builtin_arm_crc32w, "UiUiUi", "nc")
5151
BUILTIN(__builtin_arm_crc32cw, "UiUiUi", "nc")
52-
BUILTIN(__builtin_arm_crc32d, "UiUiLUi", "nc")
53-
BUILTIN(__builtin_arm_crc32cd, "UiUiLUi", "nc")
52+
BUILTIN(__builtin_arm_crc32d, "UiUiLLUi", "nc")
53+
BUILTIN(__builtin_arm_crc32cd, "UiUiLLUi", "nc")
5454

5555
// Memory barrier
5656
BUILTIN(__builtin_arm_dmb, "vUi", "nc")
@@ -62,10 +62,10 @@ BUILTIN(__builtin_arm_prefetch, "vvC*UiUiUiUi", "nc")
6262

6363
// System Registers
6464
BUILTIN(__builtin_arm_rsr, "UicC*", "nc")
65-
BUILTIN(__builtin_arm_rsr64, "LUicC*", "nc")
65+
BUILTIN(__builtin_arm_rsr64, "LLUicC*", "nc")
6666
BUILTIN(__builtin_arm_rsrp, "v*cC*", "nc")
6767
BUILTIN(__builtin_arm_wsr, "vcC*Ui", "nc")
68-
BUILTIN(__builtin_arm_wsr64, "vcC*LUi", "nc")
68+
BUILTIN(__builtin_arm_wsr64, "vcC*LLUi", "nc")
6969
BUILTIN(__builtin_arm_wsrp, "vcC*vC*", "nc")
7070

7171
// MSVC

‎clang/test/CodeGen/arm64-crc32.c

+11-8
Original file line numberDiff line numberDiff line change
@@ -1,54 +1,57 @@
11
// REQUIRES: aarch64-registered-target
22
// RUN: %clang_cc1 -triple arm64-none-linux-gnu \
33
// RUN: -disable-O0-optnone -S -emit-llvm -o - %s | opt -S -mem2reg | FileCheck %s
4+
// RUN: %clang_cc1 -triple aarch64-windows \
5+
// RUN: -disable-O0-optnone -S -emit-llvm -o - %s | opt -S -mem2reg | FileCheck %s
6+
#include <stdint.h>
47

5-
int crc32b(int a, char b)
8+
uint32_t crc32b(uint32_t a, uint8_t b)
69
{
710
return __builtin_arm_crc32b(a,b);
811
// CHECK: [[T0:%[0-9]+]] = zext i8 %b to i32
912
// CHECK: call i32 @llvm.aarch64.crc32b(i32 %a, i32 [[T0]])
1013
}
1114

12-
int crc32cb(int a, char b)
15+
uint32_t crc32cb(uint32_t a, uint8_t b)
1316
{
1417
return __builtin_arm_crc32cb(a,b);
1518
// CHECK: [[T0:%[0-9]+]] = zext i8 %b to i32
1619
// CHECK: call i32 @llvm.aarch64.crc32cb(i32 %a, i32 [[T0]])
1720
}
1821

19-
int crc32h(int a, short b)
22+
uint32_t crc32h(uint32_t a, uint16_t b)
2023
{
2124
return __builtin_arm_crc32h(a,b);
2225
// CHECK: [[T0:%[0-9]+]] = zext i16 %b to i32
2326
// CHECK: call i32 @llvm.aarch64.crc32h(i32 %a, i32 [[T0]])
2427
}
2528

26-
int crc32ch(int a, short b)
29+
uint32_t crc32ch(uint32_t a, uint16_t b)
2730
{
2831
return __builtin_arm_crc32ch(a,b);
2932
// CHECK: [[T0:%[0-9]+]] = zext i16 %b to i32
3033
// CHECK: call i32 @llvm.aarch64.crc32ch(i32 %a, i32 [[T0]])
3134
}
3235

33-
int crc32w(int a, int b)
36+
uint32_t crc32w(uint32_t a, uint32_t b)
3437
{
3538
return __builtin_arm_crc32w(a,b);
3639
// CHECK: call i32 @llvm.aarch64.crc32w(i32 %a, i32 %b)
3740
}
3841

39-
int crc32cw(int a, int b)
42+
uint32_t crc32cw(uint32_t a, uint32_t b)
4043
{
4144
return __builtin_arm_crc32cw(a,b);
4245
// CHECK: call i32 @llvm.aarch64.crc32cw(i32 %a, i32 %b)
4346
}
4447

45-
int crc32d(int a, long b)
48+
uint32_t crc32d(uint32_t a, uint64_t b)
4649
{
4750
return __builtin_arm_crc32d(a,b);
4851
// CHECK: call i32 @llvm.aarch64.crc32x(i32 %a, i64 %b)
4952
}
5053

51-
int crc32cd(int a, long b)
54+
uint32_t crc32cd(uint32_t a, uint64_t b)
5255
{
5356
return __builtin_arm_crc32cd(a,b);
5457
// CHECK: call i32 @llvm.aarch64.crc32cx(i32 %a, i64 %b)

‎clang/test/CodeGen/builtins-arm64.c

+4-2
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,6 @@
11
// RUN: %clang_cc1 -triple arm64-unknown-linux -disable-O0-optnone -emit-llvm -o - %s | opt -S -mem2reg | FileCheck %s
2+
// RUN: %clang_cc1 -triple aarch64-windows -disable-O0-optnone -emit-llvm -o - %s | opt -S -mem2reg | FileCheck %s
3+
#include <stdint.h>
24

35
void f0(void *a, void *b) {
46
__clear_cache(a,b);
@@ -55,7 +57,7 @@ unsigned rsr() {
5557
return __builtin_arm_rsr("1:2:3:4:5");
5658
}
5759

58-
unsigned long rsr64() {
60+
uint64_t rsr64() {
5961
// CHECK: call i64 @llvm.read_register.i64(metadata ![[M0:[0-9]]])
6062
return __builtin_arm_rsr64("1:2:3:4:5");
6163
}
@@ -72,7 +74,7 @@ void wsr(unsigned v) {
7274
__builtin_arm_wsr("1:2:3:4:5", v);
7375
}
7476

75-
void wsr64(unsigned long v) {
77+
void wsr64(uint64_t v) {
7678
// CHECK: call void @llvm.write_register.i64(metadata ![[M0:[0-9]]], i64 %v)
7779
__builtin_arm_wsr64("1:2:3:4:5", v);
7880
}

0 commit comments

Comments
 (0)
Please sign in to comment.