e5fadd7f81
It works by tainting memory sources with marker values, letting the data travel through the kernel, and scanning the kernel<->user frontier for these marker values. Combined with compiler instrumentation and rotation of the markers, it is able to yield relevant results with little effort. We taint the pools and the stack, and scan copyout/copyoutstr. KLEAK is supported on amd64 only for now, but it is not complicated to add more architectures (just a matter of having the address of .text, and a stack unwinder). A userland tool is provided, that allows to execute a command in rounds and monitor the leaks generated all the while. KLEAK already detected directly 12 kernel info leaks, and prompted changes that in total fixed 25+ leaks. Based on an idea developed jointly with Thomas Barabosch (of Fraunhofer FKIE).
15 lines
216 B
Makefile
15 lines
216 B
Makefile
# $NetBSD: Makefile,v 1.1 2018/12/02 21:00:13 maxv Exp $
|
|
|
|
NOMAN= # defined
|
|
|
|
PROG= kleak
|
|
SRCS= kleak.c
|
|
|
|
LDADD+= -lelf
|
|
LDADD+= -lutil
|
|
DPADD+= ${LIBELF}
|
|
DPADD+= ${LIBUTIL}
|
|
|
|
.include <bsd.own.mk>
|
|
.include <bsd.prog.mk>
|