diff options
author | Daniel Dunbar <daniel@zuster.org> | 2009-06-14 06:07:30 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2009-06-14 06:07:30 +0000 |
commit | 7c27c8a6a7c233c3c6162d9b86942351fe5f42b3 (patch) | |
tree | 876b610183e2e4d470139b8544cd6cdbf22a6982 /lib/Core/SpecialFunctionHandler.cpp | |
parent | d15a30cc0ce2579747ae4c2e919af54c6b06af70 (diff) | |
download | klee-7c27c8a6a7c233c3c6162d9b86942351fe5f42b3.tar.gz |
Add ConstantExpr::{getLimitedValue,getZExtValue}.
- For use in situations where the range of the constant is known to fit in a uint64 (or smaller), or the extra bits don't matter. - No (intended) functionality change. git-svn-id: https://llvm.org/svn/llvm-project/klee/trunk@73326 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Core/SpecialFunctionHandler.cpp')
-rw-r--r-- | lib/Core/SpecialFunctionHandler.cpp | 10 |
1 files changed, 5 insertions, 5 deletions
diff --git a/lib/Core/SpecialFunctionHandler.cpp b/lib/Core/SpecialFunctionHandler.cpp index 2ee73457..d2c68b77 100644 --- a/lib/Core/SpecialFunctionHandler.cpp +++ b/lib/Core/SpecialFunctionHandler.cpp @@ -198,7 +198,7 @@ SpecialFunctionHandler::readStringAtAddress(ExecutionState &state, cur = executor.toUnique(state, cur); assert(isa<ConstantExpr>(cur) && "hit symbolic char while reading concrete string"); - buf[i] = cast<ConstantExpr>(cur)->getConstantValue(); + buf[i] = cast<ConstantExpr>(cur)->getZExtValue(8); } buf[i] = 0; @@ -441,7 +441,7 @@ void SpecialFunctionHandler::handleSetForking(ExecutionState &state, ref<Expr> value = executor.toUnique(state, arguments[0]); if (ConstantExpr *CE = dyn_cast<ConstantExpr>(value)) { - state.forkDisabled = !CE->getConstantValue(); + state.forkDisabled = CE->isZero(); } else { executor.terminateStateOnError(state, "klee_set_forking requires a constant arg", @@ -607,7 +607,7 @@ void SpecialFunctionHandler::handleCheckMemoryAccess(ExecutionState &state, } else { ref<Expr> chk = op.first->getBoundsCheckPointer(address, cast<ConstantExpr>(size)->getConstantValue()); - if (!cast<ConstantExpr>(chk)->getConstantValue()) { + if (!chk->isTrue()) { executor.terminateStateOnError(state, "check_memory_access: memory error", "ptr.err", @@ -636,8 +636,8 @@ void SpecialFunctionHandler::handleDefineFixedObject(ExecutionState &state, assert(isa<ConstantExpr>(arguments[1]) && "expect constant size argument to klee_define_fixed_object"); - uint64_t address = cast<ConstantExpr>(arguments[0])->getConstantValue(); - uint64_t size = cast<ConstantExpr>(arguments[1])->getConstantValue(); + uint64_t address = cast<ConstantExpr>(arguments[0])->getZExtValue(); + uint64_t size = cast<ConstantExpr>(arguments[1])->getZExtValue(); MemoryObject *mo = executor.memory->allocateFixed(address, size, state.prevPC->inst); executor.bindObjectInState(state, mo, false); mo->isUserSpecified = true; // XXX hack; |