[Stack Alignment] emit warning instead of a hard error

Per discussion in rdar://13127907, we should emit a hard error only if
people write code where the requested alignment is larger than achievable
and assumes the low bits are zeros. A warning should be good enough when
we are not sure if the source code assumes the low bits are zeros.

rdar://13127907

llvm-svn: 174336
This commit is contained in:
Manman Ren 2013-02-04 23:45:08 +00:00
parent 56aecccee0
commit 86b1d868ba
2 changed files with 5 additions and 5 deletions

View File

@ -479,11 +479,11 @@ static inline unsigned clampStackAlignment(bool ShouldClamp, unsigned PrefAlign,
if (!ShouldClamp || PrefAlign <= StackAlign) if (!ShouldClamp || PrefAlign <= StackAlign)
return PrefAlign; return PrefAlign;
if (Alloca && MinAlign > StackAlign) if (Alloca && MinAlign > StackAlign)
Alloca->getParent()->getContext().emitError(Alloca, Alloca->getParent()->getContext().emitWarning(Alloca,
"Requested Minimal Alignment exceeds the Stack Alignment!"); "Requested alignment exceeds the stack alignment!");
else else
assert(MinAlign <= StackAlign && assert(MinAlign <= StackAlign &&
"Requested Minimal Alignment exceeds the Stack Alignment!"); "Requested alignment exceeds the stack alignment!");
return StackAlign; return StackAlign;
} }

View File

@ -6,10 +6,10 @@
; If alignment for alloc is smaller than or equal to stack alignment, but the ; If alignment for alloc is smaller than or equal to stack alignment, but the
; preferred type alignment is bigger, the alignment will be clamped. ; preferred type alignment is bigger, the alignment will be clamped.
; If alignment for alloca is bigger than stack alignment, the compiler ; If alignment for alloca is bigger than stack alignment, the compiler
; will emit an error. ; will emit a warning.
define void @test(<16 x float>* noalias sret %agg.result) nounwind ssp { define void @test(<16 x float>* noalias sret %agg.result) nounwind ssp {
entry: entry:
; CHECK: Requested Minimal Alignment exceeds the Stack Alignment! ; CHECK: warning: Requested alignment exceeds the stack alignment!
%retval = alloca <16 x float>, align 16 %retval = alloca <16 x float>, align 16
%0 = load <16 x float>* @T3_retval, align 16 %0 = load <16 x float>* @T3_retval, align 16
store <16 x float> %0, <16 x float>* %retval store <16 x float> %0, <16 x float>* %retval