LIBSAFE
Section: LIBSAFE (8)
Updated: 12-JAN-2000
Index
- Name
-
- Introduction
-
- Where to get libsafe
-
- Installing libsafe
-
- Using libsafe
-
- How it works
-
- REPORTING BUGS
-
- SEE ALSO
-
- DISCLAIMER
-
Name
libsafe - detection and protection against stack smashing attacks
Introduction
The libsafe library protects a process against the exploitation of buffer
overflow vulnerabilities in process stacks. Libsafe works with any existing
pre-compiled executable and can be used transparently, even on a system-wide
basis. The method intercepts all calls to library functions that are known to
be vulnerable. A substitute version of the corresponding function implements
the original functionality, but in a manner that ensures that any buffer
overflows are contained within the current stack frame. Libsafe has been shown
to detect several known attacks and can potentially prevent yet unknown
attacks. Experiments indicate that the performance overhead of libsafe is
negligible.
The following unsafe functions are currently monitored by libsafe:
-
- strcpy(char *dest, const char *src)
-
May overflow the dest buffer.
- strcat(char *dest, const char *src)
-
May overflow the dest buffer.
- getwd(char *buf)
-
May overflow the buf buffer.
- gets(char *s)
-
May overflow the s buffer.
- [vf]scanf(const char *format, ...)
-
May overflow its arguments.
- realpath(char *path, char resolved_path[])
-
May overflow the path buffer.
- [v]sprintf(char *str, const char *format, ...)
-
May overflow the str buffer.
Where to get libsafe
The source code for libsafe can be found at
http://www.bell-labs.com/org/11356/libsafe.html.
Installing libsafe
- 1.
-
If you install libsafe on Linux, make sure that your shared loader
(ld-linux.so.1/ld.so) understands LD_PRELOAD. (Best if ld.so-1.8.5
or more recent)
- 2.
-
Change to the lib directory.
- 3.
-
Type make to compile and build libsafe.so.1.
- 4.
-
Type make install to install the libsafe library and associated
programs in their final destination locations.
- 5.
-
To use libsafe, set the environment variable LD_PRELOAD to
point to the libsafe library. Example (sh syntax):
-
LD_PRELOAD=/lib/libsafe.so.1
export LD_PRELOAD
-
or (csh syntax):
-
setenv LD_PRELOAD /lib/libsafe.so.1
-
You might want to put these lines in your .profile or
.cshrc in order to activate libsafe for all processes that you
initiate.
- 6.
-
Use your programs as you would normally. Libsafe will transparently check the
parameters for supported unsafe functions. If a violation is detected, the
following will occur:
-
- 1.
-
-
The entire process group will be sent a SIGKILL signal.
- 2.
-
An entry will be added to /var/log/secure. The following is an example of such
an entry:
-
Dec 21 13:57:40 denver libsafe[15704]: Detected an attempt to write across stack boundary.
Dec 21 13:57:40 denver libsafe[15704]: Terminating /users/ttsai/work/security.D0_2/test/t91
Dec 21 13:57:40 denver libsafe[15704]: scanf()
.PP
For security reasons, the dynamic loader disregards environmental
variables such as LD_PRELOAD when executing set-uid programs.
However, on Linux, you can use libsafe with set-uid programs too, by using
one of the two methods described below:
- 1.
-
You may append the path to libsafe.so.1 into
/etc/ld.so.preload instead of using
LD_PRELOAD.
-
WARNING: If you use /etc/ld.so.preload, be sure to
install libsafe.so.1 on your root filesystem, for
instance in /lib, as is done by the default installation. Using
a directory which is not available at boot time, such as /usr/local/lib will
cause trouble at the next reboot!
-
You should also be careful to remove libsafe from
/etc/ld.so.preload when installing a new version. First
test it out using LD_PRELOAD, and only if everything is ok, put it
back into /etc/ld.so.preload.
- 2.
-
If you have a version of ld.so which is more recent than
1.9.0, you can set LD_PRELOAD to just contain the
basename of libsafe.so.1 without the directory. In that
case, the file is found as long as it is in the shared library path (which
usually contains /lib and /usr/lib)).
Because the search is restricted to the library search path, this also works
for set-uid programs.
Example (sh syntax):
-
LD_PRELOAD=libsafe.so.1
export LD_PRELOAD
-
or (csh syntax):
-
setenv LD_PRELOAD libsafe.so.1
-
The advantage of this approach over ld.so.preload is that
libsafe can more easily be switched off in case something goes wrong.
Using libsafe
Once libsafe is installed and either LD_PRELOAD or /etc/ld.so.preload has been
appropriate configured, there is nothing else to do. The processes to be
monitored can be used with no changes.
If a process attempts to use one of the monitored functions to overflow a
buffer on the stack, then a violation will be declared. A message is output to
the standard error stream, and an entry is made in /var/log/secure. In
addition, if libsafe is compiled with NOTIFY_WITH_MAIL defined, then email will
be sent based on the following conditions:
- 1.
-
If the
LIBSAFE_NOTIFY_MAIL_ADDRESS
environment variable is set, then it contains the name of a file. Mail is sent
to the recipients listed in that file. The recipients are white-space
delimited.
- 2.
-
Otherwise, if the file
/etc/libsafe.notify
exists, then mail is sent to the recipients listed in that file.
- 3.
-
Otherwise, mail is sent to root@localhost.
How it works
Programs written in C have always been plagued with buffer overflows. Two
reasons contribute to this factor. First, the C programming language does not
automatically bounds-check array and pointer references. Second, and more
importantly, many of the functions provided by the standard C library, such as
those listed in the introduction, are unsafe. Therefore, it is up to the
programmers to check explicitly that the use of these functions cannot overflow
buffers. However, programmers often omit these checks. Consequently, many
programs are plagued with buffer overflows, which makes them vulnerable to
security attacks.
Libsafe uses a novel method for performing detection and handling of buffer
overflow attacks. Without requiring source code, it can transparently protect
processes against stack smashing attacks, even on a system-wide basis. The
method intercepts all calls to library functions that are known to be
vulnerable. A substitute version of the corresponding function implements the
original functionality, but in a manner that ensures that any buffer overflows
are contained within the current stack frame.
The key idea is the ability to estimate a safe upper limit on the size of
buffers automatically. This estimation cannot be performed at compile time
because the size of the buffer may not be known at that time. Thus, the
calculation of the buffer size must be made after the start of the function in
which the buffer is accessed. Our method is able to determine the maximum
buffer size by realizing that such local buffers cannot extend beyond the end
of the current stack frame. This realization allows the substitute version of
the function to limit buffer writes within the estimated buffer size. Thus,
the return address from that function, which is located on the stack, cannot be
overwritten and control of the process cannot be commandeered.
REPORTING BUGS
Report bugs to <libsafe@research.bell-labs.com>.
SEE ALSO
The home web page for libsafe is
http://www.bell-labs.com/org/11356/libsafe.html.
DISCLAIMER
Copyright (C) 1999 Bell Labs, Lucent Technologies.
Copyright (C) Arash Baratloo, Timothy Tsai, and Navjot Singh.
This file is part of the Libsafe library.
Libsafe version 1.2: protecting against stack smashing attacks.
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public
License as published by the Free Software Foundation; either
version 2 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Library General Public
License along with this library; if not, write to the
Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA.
For more information,
visit http://www.bell-labs.com/org/11356/libsafe.html
or email libsafe@research.bell-labs.com