## Test that "llvm-objdump --traceback-table" decodes the ControlledStorageInfo, ## AllocaRegister, and extension table of the traceback table. # RUN: yaml2obj %s -o %t.o # RUN: llvm-objdump -d --traceback-table --symbol-description %t.o | \ # RUN: FileCheck --match-full-lines --strict-whitespace %s ## Show that --traceback-table implies --disassemble. # RUN: llvm-objdump --traceback-table --symbol-description %t.o | \ # RUN: FileCheck --match-full-lines --strict-whitespace %s --- !XCOFF FileHeader: MagicNumber: 0x1DF Sections: - Name: .text Flags: [ STYP_TEXT ] SectionData: "9421ffc0000000000000204080000201000000000000000400064164644e756d0000000093e1fffc0000000000002a6080c202072c90000000000004000000036f0000010000000a000001000003666f6f1f0203c000000000002000000000000000000000000000010000000000000100000000000000000000000000123400000000" Symbols: - Name: .AddNum Value: 0 Section: .text Type: 0x20 StorageClass: C_EXT AuxEntries: - Type: AUX_CSECT SectionOrLength: 0x24 SymbolAlignmentAndType: 0x21 StorageMappingClass: XMC_PR - Name: .foo Value: 0x24 Section: .text Type: 0x20 StorageClass: C_EXT AuxEntries: - Type: AUX_CSECT SectionOrLength: 0x5F SymbolAlignmentAndType: 0x21 StorageMappingClass: XMC_PR ## The above .text section data is generated using the compiler command: ## xlc -o test.o -c test.c ## We also modified the binary content of the traceback table in the object file to add vector information ## for function "foo", including ControlledStorageInfo, AllocaRegister, and ExtensionTable. ## test.c: ## int AddNum(int i,intj) { ## return i+j; ## } ## float foo(int i1,float f1,double d1,int i2, float f2) { ## return i1+f1+d1+i2+f2; ## } # CHECK:00000000 (idx: 0) .AddNum[PR]: # CHECK-NEXT: 0: 94 21 ff c0 stwu 1, -64(1) # CHECK-NEXT: 4: 00 00 00 00 # Traceback table start # CHECK-NEXT: 8: 00 # Version = 0 # CHECK-NEXT: 9: 00 # Language = C # CHECK-NEXT: a: 20 # -isGlobalLinkage, -isOutOfLineEpilogOrPrologue # CHECK-NEXT: +hasTraceBackTableOffset, -isInternalProcedure # CHECK-NEXT: -hasControlledStorage, -isTOCless # CHECK-NEXT: -isFloatingPointPresent # CHECK-NEXT: -isFloatingPointOperationLogOrAbortEnabled # CHECK-NEXT: b: 40 # -isInterruptHandler, +isFuncNamePresent, -isAllocaUsed # CHECK-NEXT: OnConditionDirective = 0, -isCRSaved, -isLRSaved # CHECK-NEXT: c: 80 # +isBackChainStored, -isFixup, NumOfFPRsSaved = 0 # CHECK-NEXT: d: 00 # -hasExtensionTable, -hasVectorInfo, NumOfGPRsSaved = 0 # CHECK-NEXT: e: 02 # NumberOfFixedParms = 2 # CHECK-NEXT: f: 01 # NumberOfFPParms = 0, +hasParmsOnStack # CHECK-NEXT: 10: 00 00 00 00 # ParmsType = i, i # CHECK-NEXT: 14: 00 00 00 04 # TraceBackTableOffset = 4 # CHECK-NEXT: 18: 00 06 # FunctionNameLen = 6 # CHECK-NEXT: 1a: 41 64 64 4e # FunctionName = AddNum # CHECK-NEXT: 1e: 75 6d # CHECK-NEXT: 20: 00 00 00 00 # Padding # CHECK:00000024 (idx: 2) .foo[PR]: # CHECK-NEXT: 24: 93 e1 ff fc stw 31, -4(1) # CHECK-NEXT: 28: 00 00 00 00 # Traceback table start # CHECK-NEXT: 2c: 00 # Version = 0 # CHECK-NEXT: 2d: 00 # Language = C # CHECK-NEXT: 2e: 2a # -isGlobalLinkage, -isOutOfLineEpilogOrPrologue # CHECK-NEXT: +hasTraceBackTableOffset, -isInternalProcedure # CHECK-NEXT: +hasControlledStorage, -isTOCless # CHECK-NEXT: +isFloatingPointPresent # CHECK-NEXT: -isFloatingPointOperationLogOrAbortEnabled # CHECK-NEXT: 2f: 60 # -isInterruptHandler, +isFuncNamePresent, +isAllocaUsed # CHECK-NEXT: OnConditionDirective = 0, -isCRSaved, -isLRSaved # CHECK-NEXT: 30: 80 # +isBackChainStored, -isFixup, NumOfFPRsSaved = 0 # CHECK-NEXT: 31: c2 # +hasExtensionTable, +hasVectorInfo, NumOfGPRsSaved = 2 # CHECK-NEXT: 32: 02 # NumberOfFixedParms = 2 # CHECK-NEXT: 33: 07 # NumberOfFPParms = 3, +hasParmsOnStack # CHECK-NEXT: 34: 2c 90 00 00 # ParmsType = i, f, d, i, f, v # CHECK-NEXT: 38: 00 00 00 04 # TraceBackTableOffset = 4 # CHECK-NEXT: 3c: 00 00 00 03 # NumOfCtlAnchors = 3 # CHECK-NEXT: 40: 6f 00 00 01 # ControlledStorageInfoDisp[0] = 1862270977 # CHECK-NEXT: 44: 00 00 00 0a ControlledStorageInfoDisp[1] = 10 # CHECK-NEXT: 48: 00 00 01 00 ControlledStorageInfoDisp[2] = 256 # CHECK-NEXT: 4c: 00 03 # FunctionNameLen = 3 # CHECK-NEXT: 4e: 66 6f 6f # FunctionName = foo # CHECK-NEXT: 51: 1f # AllocaRegister = 31 # CHECK-NEXT: 52: 02 # NumberOfVRSaved = 0, +isVRSavedOnStack, -hasVarArgs # CHECK-NEXT: 53: 03 # NumberOfVectorParms = 1, +hasVMXInstruction # CHECK-NEXT: 54: c0 00 00 00 # VectorParmsInfoString = vf # CHECK-NEXT: 58: 00 00 # Padding # CHECK-NEXT: 5a: 20 # ExtensionTable = TB_SSP_CANARY # CHECK-NEXT: 5b: 00 # Padding # CHECK-NEXT: ... # CHECK-NEXT: 68: 01 00 00 00 # CHECK-NEXT: 6c: 00 00 00 01 # CHECK-NEXT: 70: 00 00 00 00 # CHECK-NEXT: ... # CHECK-NEXT: 7c: 00 12 34 00 # CHECK-NEXT: 80: 00 00 00 00