llvm-6502/lib/Support/MemoryObject.cpp
Benjamin Kramer f66f76c1a3 Report failure if there are less bytes than requested in a MemoryObject.
Before we just left the remaining bytes uninitialized. This is another step in making llvm valgrind-clean again.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@138705 91177308-0d34-0410-b5e6-96231b3b80d8
2011-08-27 07:45:46 +00:00

38 lines
946 B
C++

//===- MemoryObject.cpp - Abstract memory interface -----------------------===//
//
// The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
#include "llvm/Support/MemoryObject.h"
using namespace llvm;
MemoryObject::~MemoryObject() {
}
int MemoryObject::readBytes(uint64_t address,
uint64_t size,
uint8_t* buf,
uint64_t* copied) const {
uint64_t current = address;
uint64_t limit = getBase() + getExtent();
if (current + size > limit)
return -1;
while (current - address < size) {
if (readByte(current, &buf[(current - address)]))
return -1;
current++;
}
if (copied)
*copied = current - address;
return 0;
}