Fix padding for variables allocated on stack.

llvm-svn: 1969
This commit is contained in:
Vikram S. Adve 2002-03-24 03:39:26 +00:00
parent dc96167e00
commit 377646fcfd
1 changed files with 18 additions and 13 deletions

View File

@ -134,49 +134,54 @@ MachineCodeForMethod::MachineCodeForMethod(const Method* _M,
int
MachineCodeForMethod::computeOffsetforLocalVar(const TargetMachine& target,
const Value* val,
unsigned int size)
unsigned int& getPaddedSize,
unsigned int sizeToUse = 0)
{
bool growUp;
int firstOffset =target.getFrameInfo().getFirstAutomaticVarOffset(*this,
growUp);
unsigned char align;
if (size == 0)
if (sizeToUse == 0)
{
size = target.findOptimalStorageSize(val->getType());
sizeToUse = target.findOptimalStorageSize(val->getType());
// align = target.DataLayout.getTypeAlignment(val->getType());
}
align = SizeToAlignment(size, target);
align = SizeToAlignment(sizeToUse, target);
int offset = getAutomaticVarsSize();
if (! growUp)
offset += size;
offset += sizeToUse;
if (unsigned int mod = offset % align)
{
offset += align - mod;
size += align - mod;
offset += align - mod;
getPaddedSize = sizeToUse + align - mod;
}
else
getPaddedSize = sizeToUse;
offset = growUp? firstOffset + offset
: firstOffset - offset;
return offset;
}
int
MachineCodeForMethod::allocateLocalVar(const TargetMachine& target,
const Value* val,
unsigned int size)
unsigned int sizeToUse = 0)
{
// Check if we've allocated a stack slot for this value already
//
int offset = getOffset(val);
if (offset == INVALID_FRAME_OFFSET)
{
offset = this->computeOffsetforLocalVar(target, val, size);
unsigned int getPaddedSize;
offset = this->computeOffsetforLocalVar(target, val, getPaddedSize,
sizeToUse);
offsets[val] = offset;
incrementAutomaticVarsSize(size);
incrementAutomaticVarsSize(getPaddedSize);
}
return offset;
}