File: README.rst

package info (click to toggle)
safeclib 3.9.1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 6,832 kB
  • sloc: ansic: 52,639; makefile: 1,271; perl: 528; sh: 518
file content (349 lines) | stat: -rw-r--r-- 13,235 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
Safe C Library - README
=======================

|safeclib|

Copying
-------

This project’s licensing restrictions are documented in the file
‘COPYING’ under the root directory of this release. Basically it’s MIT
licensed.

Overview
--------

This library implements the secure C11 Annex K [1]_ functions on top of
most libc implementations, which are missing from them.

The ISO TR24731 Bounds Checking Interface documents indicate that the
key motivation for the new specification is to help mitigate the ever
increasing security attacks, specifically the buffer overrun. [2]_

The rationale document says *“Buffer overrun attacks continue to be a
security problem. Roughly 10% of vulnerability reports cataloged by CERT
from 01/01/2005 to 07/01/2005 involved buffer overflows. Preventing
buffer overruns is the primary, but not the only, motivation for this
technical report.”*\  [3]_

The rationale document continues *“that these only mitigate, that is
lessen, security problems. When used properly, these functions decrease
the danger buffer overrun attacks. Source code may remain vulnerable due
to other bugs and security issues. The highest level of security is
achieved by building in layers of security utilizing multiple
strategies.”*\  [4]_

The rationale document lists the following key points for TR24731:

-  Guard against overflowing a buffer
-  Do not produce unterminated strings
-  Do not unexpectedly truncate strings
-  Provide a library useful to existing code
-  Preserve the zero terminated string datatype
-  Only require local edits to programs
-  Library based solution
-  Support compile-time checking
-  Make failures obvious
-  Zero buffers, null strings
-  Runtime-constraint handler mechanism
-  Support re-entrant code
-  Consistent naming scheme
-  Have a uniform pattern for the function parameters and return type
-  Deference to existing technology

and the following can be added…

-  provide a library of functions with like behavior
-  provide a library of functions that promote and increase code safety
   and security
-  provide a library of functions that are efficient

The C11 Standard adopted many of these points, and added some secure
``_s`` variants in the Annex K. The Microsoft Windows/MINGW secure API
did the same, but deviated in some functions from the standard. Besides
Windows (with its msvcrt, ucrt, reactos msvcrt and wine msvcrt variants)
only the unused stlport, Android’s Bionic, Huawei securec and
Embarcadero implemented this C11 secure Annex K API so far. They are
still missing from glibc, musl, FreeBSD, darwin and DragonFly libc,
OpenBSD libc, newlib, dietlibc, uClibc, minilibc.

Design Considerations
---------------------

This library implements since 3.0 all functions defined in the
specifications. [5]_ Included in the library are extensions to the
specification to provide a complementary set of functions with like
behavior.

This library is meant to be used on top of all the existing libc’s which
miss the secure C11 functions. Of course tighter integration into the
system libc would be better, esp. with the printf, scanf and IO
functions. See the seperate `libc-overview <doc/libc-overview.md>`__
document.

Austin Group Review of ISO/IEC WDTR 24731
http://www.open-std.org/jtc1/sc22/wg14/www/docs/n1106.txt

C11 standard (ISO/IEC 9899:2011) http://en.cppreference.com/w/c

CERT C Secure Coding Standard [6]_

Stackoverflow discussion:
https://stackoverflow.com/questions/372980/do-you-use-the-tr-24731-safe-functions

DrDobbs review [7]_
http://www.drdobbs.com/cpp/the-new-c-standard-explored/232901670

C17 reconsidered safeclib but looked only at the old incomplete Cisco
version, not our complete and fixed version.
http://www.open-std.org/jtc1/sc22/wg14/www/docs/n1967.htm

-  Use of errno

The TR24731 specification says an implementation may set errno for the
functions defined in the technical report, but is not required to. This
library does not set ``errno`` in most functions, only in ``bsearch_s``,
``fscanf_s``, ``fwscanf_s``, ``gets_s``, ``gmtime_s``, ``localtime_s``,
``scanf_s``, ``sscanf_s``, ``swscanf_s``, ``strtok_s``, ``vfscanf_s``,
``vfwscanf_s``, ``vsscanf_s``, ``vswscanf_s``, ``wcstok_s``,
``wscanf_s``.

In most cases the safeclib extended ES\* errors do not set ``errno``,
only when the underlying insecure system call fails, errno is set. The
library does use ``errno`` return codes as required by functional APIs.
Specific Safe C String and Safe C Memory errno codes are defined in the
``safe_errno.h`` file.

-  Runtime-constraints

Per the spec, the library verifies that the calling program does not
violate the function’s runtime-constraints. If a runtime-constraint is
violated, the library calls the currently registered runtime-constraint
handler.

Per the spec, multiple runtime-constraint violations in the same call to
a library function result in only one call to the runtime-constraint
handler. The first violation encountered invokes the runtime-constraint
handler.

With ``--disable-constraint-handler`` calling the runtime-constraint
handler can be disabled, saving some memory, but not much run-time
performance.

With ``--with-default-handler=<abort|ignore>`` you may set the default
constraint handler at compile-time to ``abort_handler_s`` or
``ignore_handler_s``.

The runtime-constraint handler might not return. If the handler does
return, the library function whose runtime-constraint was violated
returns an indication of failure as given by the function’s return. With
valid dest and dmax values, dest is cleared. With the optional
``--disable-null-slack`` only the first value of dest is cleared,
otherwise the whole dest buffer.

``rsize_t`` The specification defines a new type. This type,
``rsize_t``, is conditionally defined in the ``safe_lib.h`` header file.

``RSIZE_MAX`` The specification defines the macro ``RSIZE_MAX`` which
expands to a value of type ``rsize_t``. The specification uses
``RSIZE_MAX`` for both the string functions and the memory functions.
This implementation defines two macros: ``RSIZE_MAX_STR`` and
``RSIZE_MAX_MEM``. ``RSIZE_MAX_STR`` defines the range limit for the
safe string functions. ``RSIZE_MAX_MEM`` defines the range limit for the
safe memory functions. The point is that string limits can and should be
different from memory limits. There also exist ``RSIZE_MAX_WSTR``,
``RSIZE_MAX_MEM16``, ``RSIZE_MAX_MEM32``.

-  Compile-time constraints

With supporting compilers the dmax overflow checks and several more are
performed at compile-time. Currently only since clang-5 with
``diagnose_if`` support. This checks similar to ``_FORTIFY_SOURCE=2`` if
the ``__builtin_object_size`` of the dest buffer is the same size as
dmax, and errors if dmax is too big. With the optional
``--enable-warn-dmax`` it prints a warning if the sizes are different,
which is esp. practical as compile-time warning. It can be promoted via
the optional ``--enable-error-dmax`` to be fatal. On unsupported
compilers, the overflow check and optional equality warn-dmax check is
deferred to run-time. This check is only possible with
``__builtin_object_size`` and ``-O2`` when the dest buffer size is known
at compile-time, otherwise only the simplier ``dest == NULL``,
``dmax == 0`` and ``dmax > RSIZE_MAX`` checks are performed.

-  Header Files

The specification states the various functions would be added to
existing Standard C header files: stdio.h, string.h, etc. This
implementation separates the memory related functions into the
``safe_mem_lib.h`` header, the string related functions into the
``safe_str_lib.h`` header, and the rest into the ``safe_lib.h`` header.
There are also the internal ``safe_compile.h``, ``safe_config.h``
``safe_lib_errno.h`` and ``safe_types.h`` headers, but they do not need
to be included. You can also include all safec API’s with ``<safec.h>``.

The make file builds a single library ``libsafec-VERSION.a`` and
``.so``. Built but not installed are also libmemprims, libsafeccore and
libstdunsafe.

It is possible to split the make such that a separate
``safe_mem_lib.so`` and ``safe_str_lib.so`` are built. It is also
possible to integrate the prototypes into the Standard C header files,
but that may require changes to your development tool chain.

Userspace Library
-----------------

The build system for the userspace library is the well known *GNU build
system*, a.k.a. Autotools. This system is well understood and supported
by many different platforms and distributions which should allow this
library to be built on a wide variety of platforms. See the `Tested
platforms <#tested-platforms>`__ section for details on what platforms
this library was tested on during its development.

-  Building

For those familiar with autotools you can probably skip this part. For
those not and want to get right to building the code see below. And, for
those that need additional information see the ``INSTALL`` file in the
same directory.

To build you do the following:

::

   ./build-aux/autogen.sh
   ./configure
   make

``autogen.sh`` only needs to be run if you are building from the git
repository. Optionally, you can do ``make check`` if you want to run the
unit tests.

On Apple M1-M3 hardware I was told to use this:

::

   ./configure --disable-hardening CC="clang -arch arm64 -arch x86_64" \
     CXX="clang -arch arm64 -arch x86_64" CPP="clang -E" CXXCPP="clang -E"

This builds safeclib as a fat lib for macOS arm64 + X86-64 using clang.

-  Installing

Installation must be preformed by ``root``, an ``Administrator`` on most
systems. The following is used to install the library.

::

   sudo make install

Safe Linux Kernel Module
------------------------

The build for the kernel module has not been integrated into the
autotools build infrastructure. Consequently, you have to run a
different makefile to build the kernel module.

-  Building

.To build do the following:

::

   ./configure --disable-wchar
   make -f Makefile.kernel

This assumes you are compiling on a Linux box and this makefile supports
the standard kernel build system infrastructure documented in:
``/usr/src/linux-kernel/Documentation/kbuild/modules.txt``

NOTE: If you build the kernel module then wish to build the userspace
library or vice versa you will need to do a ``make clean`` otherwise a
``make check`` will fail to build.

-  Installing

The kernel module will be found at the root of the source tree called
``slkm.ko``. The file ``testslkm.ko`` are the unit tests run on the
userspace library but in Linux kernel module form to verify
functionality within the kernel.

Tested Platforms
----------------

The library has been tested on the following systems:

-  Linux Fedora core 31 - 41 amd64/i386 glibc 2.28 - 2.40 (all gcc’s +
   clang’s)
-  Mac OS X 10.6-12 w/ Apple developer tools and macports (all gcc’s +
   clang’s)
-  Linux Debian/Ubuntu since Debian 9 amd64/i386 glibc 2.24 - 2.40 (all
   gcc’s + clang’s)
-  Linux centos 7 amd64
-  Linux Void amd64 musl-1.1.16
-  x86_64-w64-mingw32 native and cross-compiled
-  i686-w64-mingw32 native, and cross-compiled and tested under wine
-  i386-mingw32 cross-compiled
-  cygwin32 gcc (newlib)
-  cygwin64 gcc -std=c99 (newlib)
-  freebsd 10 - 13 amd64
-  linux docker images under qemu: i386/debian, x86_64/rhel,
   arm32v7/debian, aarch64: arm64v8/{debian,centos,rhel,fedora},
   s390x/fedora (the only big endian test I could find),
   ppc64le/{debian,ubuntu,fedora,centos,rhel}
-  User Mode Linux (UML), Linux kernel version v3.5.3 w/ Debian Squeeze
   rootfs

with most available compilers. See ``build-aux/smoke.sh`` and the
various CI configs.

-  https://github.com/rurban/safeclib/actions
-  https://travis-ci.org/github/rurban/safeclib/
-  https://ci.appveyor.com/project/rurban/safeclib/
-  https://cirrus-ci.com/github/rurban/safeclib
-  https://cloud.drone.io/rurban/safeclib/

Known Issues
------------

1. If you are building the library from the git repository you will have
   to first run ``build-aux/autogen.sh`` which runs autoreconf to
   ``install`` the autotools files and create the configure script.

2. If you use cmake, you’d need to add
   ``-DCMAKE_APPLE_SILICON_PROCESSOR=$(uname -m)`` for Apple Silicon M1
   or M2 processors.

References
----------

.. [1]
   C11 Standard (ISO/IEC 9899:2011) Annex K

.. [2]
   Programming languages, their environments and system software
   interfaces, Extensions to the C Library, Part I: Bounds-checking
   interfaces, ISO/IEC TR 24731-1.

.. [3]
   Rationale for TR 24731 Extensions to the C Library Part I:
   Bounds-checking interfaces, ISO/IEC JTC1 SC22 WG14 N1225.

.. [4]
   Rationale for TR 24731 Extensions to the C Library Part I:
   Bounds-checking interfaces, ISO/IEC JTC1 SC22 WG14 N1225.

.. [5]
   The Open Group Base Specifications Issue 7
   http://pubs.opengroup.org/onlinepubs/9699919799/functions/contents.html

.. [6]
   CERT C Secure Coding Standard
   https://www.securecoding.cert.org/confluence/display/seccode/CERT+C+Secure+Coding+Standard

.. [7]
   DrDobbs review
   http://www.drdobbs.com/cpp/the-new-c-standard-explored/232901670

.. |safeclib| image:: doc/safeclib-banner.png
   :target: https://github.com/rurban/safeclib/issues