首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >KLEE未发现未初始化的变量错误

KLEE未发现未初始化的变量错误
EN

Stack Overflow用户
提问于 2017-01-17 20:31:30
回答 1查看 187关注 0票数 0

我现在正在学习KLEE,我写了一个简单的代码:

代码语言:javascript
运行
复制
#include "klee/klee.h"
#include <stdio.h>
#include <stdlib.h>

int test(int *p)
{
    int *q = (int *) malloc(sizeof(int));

    if ((*p) == (*q)) {
       printf("reading uninitialized heap memory");
    }
    return 0;
}


int main()
{
    int *p = (int *) malloc(sizeof(int));
    test(p);
    return 0;
}

首先,我生成LLVM bitcode,然后执行KLEE to the bitcode。以下是所有输出:

代码语言:javascript
运行
复制
KLEE: output directory is "/Users/yjy/WorkSpace/Test/klee-out-13"
Using STP solver backend
KLEE: WARNING: undefined reference to function: printf
KLEE: WARNING ONCE: calling external: printf(140351601907424)
reading uninitialized heap memory
KLEE: done: total instructions = 61
KLEE: done: completed paths = 4
KLEE: done: generated tests = 4

我想KLEE应该给我一个Q指针没有初始化的错误,但是它没有,为什么KLEE不给我一个错误或者警告呢?KLEE不能检测到这个错误吗?提前感谢!

EN

回答 1

Stack Overflow用户

发布于 2017-04-21 15:26:19

TLTR:KLEE尚未实现此功能。Clang可以直接检查这一点。

KLEE目前支持add/sub/mul/div溢出检查。要使用此功能,您必须使用clang -fsanitize=signed-integer-overflow或clang -fsanitize=unsigned-integer-overflow编译源代码。

这个想法是,当你使用clang杀菌器时,一个函数调用被插入到字节码(例如__ubsan_handle_add_overflow)中。然后,一旦遇到函数调用,KLEE将处理溢出检查。

Clang support MemorySanitizerAddressSanitizer UndefinedBehaviorSanitizer。它们在项目/编译器-rt/lib目录中定义。MemorySanitizer就是你要找的那个,它是一个未初始化读取的检测器。

您可以删除KLEE函数调用,并直接使用clang进行检查。

代码语言:javascript
运行
复制
➜  ~ clang -g -fsanitize=memory st.cpp
➜  ~ ./a.out
==16031==WARNING: MemorySanitizer: use-of-uninitialized-value
    #0 0x490954  (/home/hailin/a.out+0x490954)
    #1 0x7f21b72f382f  (/lib/x86_64-linux-gnu/libc.so.6+0x2082f)
    #2 0x41a1d8  (/home/hailin/a.out+0x41a1d8)

SUMMARY: MemorySanitizer: use-of-uninitialized-value (/home/hailin/a.out+0x490954)
Exiting
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41697254

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档