Daniel Liew
2013-Aug-15  11:44 UTC
[LLVMdev] Clarification between <type> and <ty> for alloca instruction
Hi,
This is quite a simple question so hopefully it's easy to answer.
I was looking at the documentation for the alloca instruction (
http://llvm.org/docs/LangRef.html#alloca-instruction ) and something is
unclear to me. The given syntax is...
<result> = alloca <type>[, <ty> <NumElements>][, align
<alignment>]
; yields {type*}:result
And the documentation states "The ‘alloca‘ instruction allocates
sizeof(<type>)*NumElements bytes of memory on the runtime stack".
It is not stated how the "<ty>" type is used as we are told the
type of
result is type* and sizeof(<type>)*NumElements is the amount of memory
so from my perspective it looks like <ty> is never used which would seem
to make stating i32 twice in the following example redundant
%ptr = alloca i32, i32 4
My guess is that if <NumElements> is specified then the amount of memory
actually allocated would be sizeof(<ty>)*NumElements (instead of
sizeof(<type>)*NumElements) but the pointer type of result is
<type>. Is
that correct?
If not could someone please clarify this?
Thanks,
Dan Liew.
Tim Northover
2013-Aug-15  11:58 UTC
[LLVMdev] Clarification between <type> and <ty> for alloca instruction
Hi Dan,> It is not stated how the "<ty>" type is used as we are told the type of > result is type* and sizeof(<type>)*NumElements is the amount of memory > so from my perspective it looks like <ty> is never used which would seem > to make stating i32 twice in the following example redundant > > %ptr = alloca i32, i32 4 > > My guess is that if <NumElements> is specified then the amount of memory > actually allocated would be sizeof(<ty>)*NumElements (instead of > sizeof(<type>)*NumElements) but the pointer type of result is <type>. Is > that correct?It doesn't really affect the output at all. If NumElements doesn't overflow <ty> then the semantics don't depend on it at all. In C-like code it's sort of the difference between these two functions: void ty_is_i16(unsigned short NumElements) { int arr[NumElements]; use_array(arr); } void ty_is_i32(unsigned int NumElements) { int arr[NumElements]; use_array(arr); } you might compile them to define void @ty_is_i16(i16 %NumElements) { %arr = alloca i32, i16 %NumElements call void @use_array(i32* %arr) ret void } define void @ty_is_i32(i32 %NumElements) { %arr = alloca i32, i32 %NumElements call void @use_array(i32* %arr) ret void } Of course, if NumElements *does* overflow they're different: alloca i32, i8 257 will allocate 1 i32, but alloca i32, i32 257 will allocate 257 of them. It's mostly there because when NumElements is a run-time value (as in the C examples) it has to have *some* type in LLVM IR. Cheers. Tim.
Reasonably Related Threads
- [LLVMdev] Clarification between <type> and <ty> for alloca instruction
- [LLVMdev] Clarification between <type> and <ty> for alloca instruction
- [LLVMdev] Clarification between <type> and <ty> for alloca instruction
- RFC: alloca -- specify address space for allocation
- RFC: alloca -- specify address space for allocation