aboutsummaryrefslogtreecommitdiffhomepage
path: root/lib
diff options
context:
space:
mode:
authorCristian Cadar <c.cadar@imperial.ac.uk>2022-06-25 21:02:58 +0100
committerMartinNowack <2443641+MartinNowack@users.noreply.github.com>2022-09-26 09:42:07 +0100
commit667ce0f1ef33c32fbe2d1836fc1b334066e244ca (patch)
treebc338c8c00a2adc7577366eba9cecdc7ee5b3e82 /lib
parent21146a3653cdb29790a9d0f557f0f1651befbe9e (diff)
downloadklee-667ce0f1ef33c32fbe2d1836fc1b334066e244ca.tar.gz
Improve the message for when large arrays become symbolic. Only print this warning once per array. Add test case.
Diffstat (limited to 'lib')
-rw-r--r--lib/Core/Memory.cpp32
1 files changed, 20 insertions, 12 deletions
diff --git a/lib/Core/Memory.cpp b/lib/Core/Memory.cpp
index f2f679ad..efc23612 100644
--- a/lib/Core/Memory.cpp
+++ b/lib/Core/Memory.cpp
@@ -375,19 +375,23 @@ ref<Expr> ObjectState::read8(unsigned offset) const {
}
ref<Expr> ObjectState::read8(ref<Expr> offset) const {
- assert(!isa<ConstantExpr>(offset) && "constant offset passed to symbolic read8");
+ assert(!isa<ConstantExpr>(offset) &&
+ "constant offset passed to symbolic read8");
unsigned base, size;
fastRangeCheckOffset(offset, &base, &size);
flushRangeForRead(base, size);
- if (size>4096) {
+ if (size > 4096) {
std::string allocInfo;
object->getAllocInfo(allocInfo);
- klee_warning_once(0, "flushing %d bytes on read, may be slow and/or crash: %s",
- size,
- allocInfo.c_str());
+ klee_warning_once(
+ nullptr,
+ "Symbolic memory access will send the following array of %d bytes to "
+ "the constraint solver -- large symbolic arrays may cause significant "
+ "performance issues: %s",
+ size, allocInfo.c_str());
}
-
+
return ReadExpr::create(getUpdates(), ZExtExpr::create(offset, Expr::Int32));
}
@@ -413,19 +417,23 @@ void ObjectState::write8(unsigned offset, ref<Expr> value) {
}
void ObjectState::write8(ref<Expr> offset, ref<Expr> value) {
- assert(!isa<ConstantExpr>(offset) && "constant offset passed to symbolic write8");
+ assert(!isa<ConstantExpr>(offset) &&
+ "constant offset passed to symbolic write8");
unsigned base, size;
fastRangeCheckOffset(offset, &base, &size);
flushRangeForWrite(base, size);
- if (size>4096) {
+ if (size > 4096) {
std::string allocInfo;
object->getAllocInfo(allocInfo);
- klee_warning_once(0, "flushing %d bytes on read, may be slow and/or crash: %s",
- size,
- allocInfo.c_str());
+ klee_warning_once(
+ nullptr,
+ "Symbolic memory access will send the following array of %d bytes to "
+ "the constraint solver -- large symbolic arrays may cause significant "
+ "performance issues: %s",
+ size, allocInfo.c_str());
}
-
+
updates.extend(ZExtExpr::create(offset, Expr::Int32), value);
}