MC CFG: Remap enough for data too, analoguous to r188873.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@188925 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Ahmed Bougacha 2013-08-21 19:40:28 +00:00
parent 2172767491
commit b2fdd9ee45
2 changed files with 49 additions and 1 deletions

View File

@ -44,7 +44,7 @@ void MCAtom::remapForSplit(uint64_t SplitPt,
void MCDataAtom::addData(const MCData &D) {
Data.push_back(D);
if (Data.size() > Begin - End)
if (Data.size() > Begin - End - 1)
remap(Begin, End + 1);
}

View File

@ -0,0 +1,48 @@
# RUN: yaml2obj -format=elf %s | llvm-objdump -d -yaml-cfg=%t - && FileCheck --check-prefix=CFG < %t %s
# REQUIRES: shell
#
# Generated from:
# main:
# .LBL0_1:
# movq 8(%rsi), %rax
# <invalid opcode: 06>
!ELF
FileHeader:
Class: ELFCLASS64
Data: ELFDATA2LSB
Type: ET_REL
Machine: EM_X86_64
Sections:
- Name: .text
Type: SHT_PROGBITS
Flags: [ SHF_ALLOC, SHF_EXECINSTR ]
Content: "488B460806"
## 0000000000000000 <main>:
#CFG: Atoms:
#CFG: - StartAddress: 0x0000000000000000
#CFG: Size: 4
#CFG: Type: Text
## 0: 48 8b 46 08 mov 0x8(%rsi),%rax
#CFG: - Inst: MOV64rm
#CFG: Size: 4
#CFG: Ops: [ RRAX, RRSI, I1, R, I8, R ]
#CFG: - StartAddress: 0x0000000000000004
#CFG: Size: 1
#CFG: Type: Data
## 4: 06 (bad)
#CFG: Content: 06
Symbols:
Global:
- Name: main
Type: STT_FUNC
Section: .text
Value: 0x0
Size: 5