mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-07-28 19:25:00 +00:00
Fixed subtle bug in Deserializer::JumpTo when jumping when the block-nesting
information matching did not exactly match the underlying stream's scoping information. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@44470 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -21,9 +21,8 @@ using namespace llvm;
|
||||
|
||||
Deserializer::Deserializer(BitstreamReader& stream)
|
||||
: Stream(stream), RecIdx(0), FreeList(NULL), AbbrevNo(0), RecordCode(0) {
|
||||
|
||||
AdvanceStream();
|
||||
if (!AtEnd()) StreamStart = BlockStack.back();
|
||||
|
||||
StreamStart = Stream.GetCurrentBitNo();
|
||||
}
|
||||
|
||||
Deserializer::~Deserializer() {
|
||||
@@ -165,12 +164,11 @@ bool Deserializer::JumpTo(const Location& Loc) {
|
||||
|
||||
assert (!inRecord());
|
||||
|
||||
// AdvanceStream();
|
||||
AdvanceStream();
|
||||
|
||||
// assert (AbbrevNo == bitc::ENTER_SUBBLOCK);
|
||||
assert (!BlockStack.empty() || AtEnd());
|
||||
|
||||
uint64_t LastBPos = StreamStart.BitNo;
|
||||
uint64_t LastBPos = StreamStart;
|
||||
|
||||
while (!BlockStack.empty()) {
|
||||
|
||||
@@ -183,8 +181,11 @@ bool Deserializer::JumpTo(const Location& Loc) {
|
||||
// destroy any accumulated context within the block scope. We then
|
||||
// jump to the position of the block and enter it.
|
||||
Stream.JumpToBit(LastBPos);
|
||||
|
||||
if (BlockStack.size() == Stream.BlockScope.size())
|
||||
Stream.PopBlockScope();
|
||||
|
||||
BlockStack.pop_back();
|
||||
Stream.PopBlockScope();
|
||||
|
||||
AbbrevNo = 0;
|
||||
AdvanceStream();
|
||||
@@ -195,14 +196,19 @@ bool Deserializer::JumpTo(const Location& Loc) {
|
||||
}
|
||||
|
||||
// This block does not contain the block we are looking for. Pop it.
|
||||
if (BlockStack.size() == Stream.BlockScope.size())
|
||||
Stream.PopBlockScope();
|
||||
|
||||
BlockStack.pop_back();
|
||||
Stream.PopBlockScope();
|
||||
|
||||
}
|
||||
|
||||
// Check if we have popped our way to the outermost scope. If so,
|
||||
// we need to adjust our position.
|
||||
if (BlockStack.empty()) {
|
||||
Stream.JumpToBit(Loc.BitNo < LastBPos ? StreamStart.BitNo : LastBPos);
|
||||
assert (Stream.BlockScope.empty());
|
||||
|
||||
Stream.JumpToBit(Loc.BitNo < LastBPos ? StreamStart : LastBPos);
|
||||
AbbrevNo = 0;
|
||||
AdvanceStream();
|
||||
}
|
||||
@@ -229,6 +235,18 @@ bool Deserializer::JumpTo(const Location& Loc) {
|
||||
return true;
|
||||
}
|
||||
|
||||
void Deserializer::Rewind() {
|
||||
while (!Stream.BlockScope.empty())
|
||||
Stream.PopBlockScope();
|
||||
|
||||
while (!BlockStack.empty())
|
||||
BlockStack.pop_back();
|
||||
|
||||
Stream.JumpToBit(StreamStart);
|
||||
AbbrevNo = 0;
|
||||
}
|
||||
|
||||
|
||||
unsigned Deserializer::getCurrentBlockID() {
|
||||
if (!inRecord())
|
||||
AdvanceStream();
|
||||
|
Reference in New Issue
Block a user