diff options
author | Dimitry Andric <dim@FreeBSD.org> | 2011-10-20 21:14:49 +0000 |
---|---|---|
committer | Dimitry Andric <dim@FreeBSD.org> | 2011-10-20 21:14:49 +0000 |
commit | 36981b17ed939300f6f8fc2355a255f711fcef71 (patch) | |
tree | ee2483e98b09cac943dc93a6969d83ca737ff139 /test/CodeGen/arm-vaarg-align.c | |
parent | 180abc3db9ae3b4fc63cd65b15697e6ffcc8a657 (diff) | |
download | src-36981b17ed939300f6f8fc2355a255f711fcef71.tar.gz src-36981b17ed939300f6f8fc2355a255f711fcef71.zip |
Notes
Diffstat (limited to 'test/CodeGen/arm-vaarg-align.c')
-rw-r--r-- | test/CodeGen/arm-vaarg-align.c | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/test/CodeGen/arm-vaarg-align.c b/test/CodeGen/arm-vaarg-align.c new file mode 100644 index 000000000000..1187c022914f --- /dev/null +++ b/test/CodeGen/arm-vaarg-align.c @@ -0,0 +1,33 @@ +// RUN: %clang_cc1 -triple arm -target-abi aapcs %s -emit-llvm -o - | FileCheck -check-prefix=AAPCS %s +// RUN: %clang_cc1 -triple arm -target-abi apcs-gnu %s -emit-llvm -o - | FileCheck -check-prefix=APCS-GNU %s +/* + * Check that va_arg accesses stack according to ABI alignment + * long long and double require 8-byte alignment under AAPCS + * however, they only require 4-byte alignment under APCS + */ +long long t1(int i, ...) { + // AAPCS: t1 + // APCS-GNU: t1 + __builtin_va_list ap; + __builtin_va_start(ap, i); + // AAPCS: add i32 %{{.*}} 7 + // AAPCS: and i32 %{{.*}} -8 + // APCS-GNU-NOT: add i32 %{{.*}} 7 + // APCS-GNU-NOT: and i32 %{{.*}} -8 + long long ll = __builtin_va_arg(ap, long long); + __builtin_va_end(ap); + return ll; +} +double t2(int i, ...) { + // AAPCS: t2 + // APCS-GNU: t2 + __builtin_va_list ap; + __builtin_va_start(ap, i); + // AAPCS: add i32 %{{.*}} 7 + // AAPCS: and i32 %{{.*}} -8 + // APCS-GNU-NOT: add i32 %{{.*}} 7 + // APCS-GNU-NOT: and i32 %{{.*}} -8 + double ll = __builtin_va_arg(ap, double); + __builtin_va_end(ap); + return ll; +} |