[cfe-dev] [LLVMdev] Odd PPC inline asm constraint
Jakob Stoklund Olesen
stoklund at 2pi.dk
Sat May 12 08:54:49 PDT 2012
On May 12, 2012, at 6:44 AM, Peter Bergner <bergner at vnet.ibm.com> wrote:
> On Sat, 2012-05-12 at 00:47 -0500, Hal Finkel wrote:
>> On Tue, 01 May 2012 21:25:29 -0500
>> Peter Bergner <bergner at vnet.ibm.com> wrote:
>>> By the strict letter of the 32-bit ABI, the save and restore of
>>> r31 at a negative offset of r1 is verboten. The ABI states the
>>> the stack space below the stack pointer is declared as volatile.
>>> I actually debugged a similar problem way back in my Blue Gene/L
>>> days, where gcc had a bug and was doing the same thing. We ended
>>> up taking a signal between the restore of the stack pointer and
>>> the restore of the nonvolatile reg and the BGL compute node kernel
>>> trashed the stack below the stack pointer.
>>
>> Just to confirm, this is an issue specific to the 32-bit ABI, correct?
>> gcc (4.4.6) seems to do the same thing for PPC64.
>
> Correct, this is a specific 32-bit ABI issue. The 64-bit ABI allows
> some access below the stack pointer. From the 64-bit ABI:
>
> The 288 bytes below the stack pointer is available as volatile
> storage which is not preserved across function calls. Interrupt
> handlers and any other functions that might run without an explicit
> call must take care to preserve this region. If a function does not
> need more stack space than is available in this area, it does not
> need to have a stack frame.
The Darwin ppc32 ABI also has a 224 byte red zone, see https://developer.apple.com/library/mac/#documentation/DeveloperTools/Conceptual/LowLevelABI/100-32-bit_PowerPC_Function_Calling_Conventions/32bitPowerPC.html
I don't know if LLVM knows about other 32-bit ABIs.
/jakob
More information about the cfe-dev
mailing list