From 5f36d741db0d0e06c80a59827d9805ecb73e3a1b Mon Sep 17 00:00:00 2001 From: "Vikram S. Adve" Date: Sun, 25 May 2003 21:59:09 +0000 Subject: [PATCH] Bug fix: padding bytes within a structure should go after each field! llvm-svn: 6333 --- llvm/lib/Target/Sparc/EmitAssembly.cpp | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/llvm/lib/Target/Sparc/EmitAssembly.cpp b/llvm/lib/Target/Sparc/EmitAssembly.cpp index 523e21e16425..1509fdbb94ee 100644 --- a/llvm/lib/Target/Sparc/EmitAssembly.cpp +++ b/llvm/lib/Target/Sparc/EmitAssembly.cpp @@ -544,7 +544,7 @@ private: void printGlobalVariable (const GlobalVariable *GV); void PrintZeroBytesToPad (int numBytes); void printSingleConstantValue (const Constant* CV); - void printConstantValueOnly (const Constant* CV, int numPadBytes = 0); + void printConstantValueOnly (const Constant* CV, int numPadBytesAfter = 0); void printConstant (const Constant* CV, string valID = ""); static void FoldConstants (const Module &M, @@ -786,13 +786,10 @@ SparcModuleAsmPrinter::PrintZeroBytesToPad(int numBytes) // Uses printSingleConstantValue() to print each individual value. void SparcModuleAsmPrinter::printConstantValueOnly(const Constant* CV, - int numPadBytes /* = 0*/) + int numPadBytesAfter /* = 0*/) { const ConstantArray *CVA = dyn_cast(CV); - if (numPadBytes) - PrintZeroBytesToPad(numPadBytes); - if (CVA && isStringCompatible(CVA)) { // print the string alone and return toAsm << "\t" << ".ascii" << "\t" << getAsCString(CVA) << "\n"; @@ -829,6 +826,9 @@ SparcModuleAsmPrinter::printConstantValueOnly(const Constant* CV, } else printSingleConstantValue(CV); + + if (numPadBytesAfter) + PrintZeroBytesToPad(numPadBytesAfter); } // Print a constant (which may be an aggregate) prefixed by all the