昨天我问了一个关于stackoverflow的问题,但是我没有清楚地描述它,所以我改变了提问的方式,也许可以把问题说清楚。首先,我修改了klee提供的示例get_sign.c,将unistd.h包含在程序中,并调用函数sleep()使线程暂停,如下所示
/*
* First KLEE tutorial: testing a small function
*/
#include <unistd.h>
int get_sign(int x) {
if (x == 0)
return 0;
if (x < 0)
return -1;
else
return 1;
}
int main() {
int a;
klee_make_symbolic(&a, sizeof(a), "a");
sleep(10);
return get_sign(a);
} 我使用"llvm-gcc“编译get_sign.c,然后使用klee get_sign.o执行目标文件,线程没有暂停,这意味着sleep()不工作。所以我在执行get_sign.o时添加了一个参数,像这样的klee --libc=uclibc get_sign.o,不幸的是,线程仍然没有挂起,而且,klee报告了一个错误,
KLEE: ERROR: /home/lab/work/klee-uclibc/libc/signal/sigaction.c:58: failed external call: __syscall_rt_sigaction
KLEE: NOTE: now ignoring this error at this location我能做些什么来解决这个问题?谢谢!
发布于 2014-03-07 11:29:31
看起来klee使用了可以使sleep比预期更早返回的信号,如http://www.delorie.com/gnu/docs/glibc/libc_445.html中所示。此参考还提供了绕过限制的方法。
https://stackoverflow.com/questions/22240052
复制相似问题