https://github.com/joyhou-hw updated https://github.com/llvm/llvm-project/pull/80401
>From e476b28fa123822c695beb5c0ba0f2c381df0e95 Mon Sep 17 00:00:00 2001 From: houzhenyu <houzhe...@huawei.com> Date: Fri, 2 Feb 2024 11:21:50 +0800 Subject: [PATCH] [X86] [iamcu] Fix wrong alignment value for attr (aligned) with -miamcu attribute ((aligned)) should be 4 for -miamcu. --- clang/lib/Basic/Targets/X86.h | 1 + clang/test/Sema/attr-aligned.c | 10 ++++++++++ 2 files changed, 11 insertions(+) diff --git a/clang/lib/Basic/Targets/X86.h b/clang/lib/Basic/Targets/X86.h index 1845f5a747af4..0026d8781c8fa 100644 --- a/clang/lib/Basic/Targets/X86.h +++ b/clang/lib/Basic/Targets/X86.h @@ -672,6 +672,7 @@ class LLVM_LIBRARY_VISIBILITY MCUX86_32TargetInfo : public X86_32TargetInfo { MCUX86_32TargetInfo(const llvm::Triple &Triple, const TargetOptions &Opts) : X86_32TargetInfo(Triple, Opts) { LongDoubleWidth = 64; + DefaultAlignForAttributeAligned = 32; LongDoubleFormat = &llvm::APFloat::IEEEdouble(); resetDataLayout("e-m:e-p:32:32-p270:32:32-p271:32:32-p272:64:64-i64:32-" "f64:32-f128:32-n8:16:32-a:0:32-S32"); diff --git a/clang/test/Sema/attr-aligned.c b/clang/test/Sema/attr-aligned.c index 130840d46650d..b285ce3d0ed78 100644 --- a/clang/test/Sema/attr-aligned.c +++ b/clang/test/Sema/attr-aligned.c @@ -1,4 +1,12 @@ // RUN: %clang_cc1 -triple x86_64-apple-darwin9 -fsyntax-only -verify %s +// RUN: %clang_cc1 -triple i586-intel-elfiamcu -fsyntax-only -verify %s + +#ifdef __iamcu +// expected-no-diagnostics +struct dummy { int x __attribute__((aligned)); }; +int m0[__alignof__(struct dummy) == 4 ? 1 : -1]; + +#else int x __attribute__((aligned(3))); // expected-error {{requested alignment is not a power of 2}} int y __attribute__((aligned(1ull << 33))); // expected-error {{requested alignment must be 4294967296 bytes or smaller}} @@ -60,3 +68,5 @@ array_with_overaligned_struct F2; char f2[__alignof__(F2) == 16 ? 1 : -1] = { 0 }; array_with_align_attr F3; char f3[__alignof__(F3) == 16 ? 1 : -1] = { 0 }; + +#endif _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits