Man page - blhc(1)
Packages contains this manual
Manual
BLHC
NAMESYNOPSIS
DESCRIPTION
FALSE POSITIVES
OPTIONS
EXAMPLES
BUILDD TAGS
EXIT STATUS
AUTHOR
LICENSE AND COPYRIGHT
SEE ALSO
NAME
blhc - build log hardening check, checks build logs for missing hardening flags
SYNOPSIS
blhc [ options ] <dpkg-buildpackage build log file>..
DESCRIPTION
blhc is a small tool which checks build logs for missing hardening flags. Itās licensed under the GPL 3 or later.
Itās designed to check build logs generated by Debianās dpkg-buildpackage (or tools using dpkg-buildpackage like pbuilder or sbuild (which is used for the official buildd build logs)) to help maintainers detect missing hardening flags in their packages.
Only gcc is detected as compiler at the moment. If other compilers support hardening flags as well, please report them.
If thereās no output, no flags are missing and the build log is fine.
See README for details about performed checks, auto-detection and limitations.
FALSE POSITIVES
To suppress false positives you can embed the following string in the build log:
blhc: ignore-line-regexp: REGEXP
All lines fully matching REGEXP (see --ignore-line for details) will be ignored. The string can be embedded multiple times to ignore different regexps.
Please use this feature sparingly so that missing flags are not overlooked. If you find false positives which affect more packages please report a bug.
To generate this string simply use echo in "debian/rules"; make sure to use @ to suppress the echo command itself as it could also trigger a false positive. If the build process takes a long time edit the ".build" file in place and tweak the ignore string until blhc --all --debian package.build no longer reports any false positives.
OPTIONS
|
--all |
Force check for all +all (+pie, +bindnow) hardening flags. By default itās auto detected. |
--arch architecture
Set the specific architecture (e.g. amd64, armel, etc.), automatically disables hardening flags not available on this architecture. Is detected automatically if dpkg-buildpackage is used.
--bindnow
Force check for all +bindnow hardening flags. By default itās auto detected.
--buildd
Special mode for buildds when automatically parsing log files. The following changes are in effect:
|
⢠|
Print tags instead of normal warnings, see "BUILDD TAGS" for a list of possible tags. |
||
|
⢠|
Donāt check hardening flags in old log files (if dpkg-dev << 1.16.1 is detected). |
||
|
⢠|
Donāt require Term::ANSIColor. |
||
|
⢠|
Return exit code 0, unless there was a error (-I, -W messages donāt count as error). |
--debian
Apply Debian-specific settings. At the moment this only disables checking for PIE which is automatically applied by Debianās GCC and no longer requires a compiler command line argument.
|
--color |
Use colored (ANSI) output for warning messages. |
--line-numbers
Display line numbers.
--ignore-arch arch
Ignore build logs from architectures matching arch . arch is a string.
Used to prevent false positives. This option can be specified multiple times.
--ignore-arch-flag arch : flag
Like --ignore-flag , but only ignore flag on arch .
--ignore-arch-line arch : line
Like --ignore-line , but only ignore line on arch .
--ignore-flag flag
Donāt print an error when the specific flag is missing in a compiler line. flag is a string.
Used to prevent false positives. This option can be specified multiple times.
--ignore-line regex
Ignore lines matching the given Perl regex. regex is automatically anchored at the beginning and end of the line to prevent false negatives.
NOTE : Not the input lines are checked, but the lines which are displayed in warnings (which have line continuation resolved).
Used to prevent false positives. This option can be specified multiple times.
|
--pie |
Force check for all +pie hardening flags. By default itās auto detected. |
-h -? --help
Print available options.
--version
Print version number and license.
Auto detection for --pie and --bindnow only works if at least one command uses the required hardening flag (e.g. -fPIE). Then itās required for all other commands as well.
EXAMPLES
Normal usage, parse a single log file.
blhc path/to/log/file
If thereās no output, no flags are missing and the build log is fine.
Parse multiple log files. The exit code is ORed over all files.
blhc path/to/directory/with/log/files/*
Donāt treat missing "-g" as error:
blhc --ignore-flag -g path/to/log/file
Donāt treat missing "-pie" on kfreebsd-amd64 as error:
blhc --ignore-arch-flag kfreebsd-amd64:-pie path/to/log/file
Ignore lines consisting exactly of "./script gcc file" which would cause a false positive.
blhc --ignore-line '\./script gcc file' path/to/log/file
Ignore lines matching "./script gcc file" somewhere in the line.
blhc --ignore-line '.*\./script gcc file.*' path/to/log/file
Use blhc with pbuilder.
pbuilder
path/to/package.dsc | tee path/log/file
blhc path/to/file || echo flags missing
Assume this build log was created on a Debian system and thus donāt warn about missing PIE flags if the current architecture injects them automatically (this is enabled in buildd mode per default). "--arch" is necessary if the build log contains no architecture information as written by dpkg-buildpackage.
blhc --debian --all --arch=amd64 path/to/log/file
BUILDD TAGS
The following
tags are used in
--buildd
mode. In braces the
additional data which is displayed.
I-hardening-wrapper-used
The package uses hardening-wrapper which intercepts calls to gcc and adds hardening flags. The build log doesnāt contain any hardening flags and thus canāt be checked by blhc.
W-compiler-flags-hidden (summary of hidden lines)
Build log contains lines which hide the real compiler flags. For example:
CC test-a.c
CC test-b.c
CC test-c.c
LD test
Most of the time either "export V=1" or "export verbose=1" in debian/rules fixes builds with hidden compiler flags. Sometimes ".SILENT" in a Makefile must be removed. And as last resort the Makefile must be patched to remove the "@"s hiding the real compiler commands.
W-dpkg-buildflags-missing (summary of missing flags)
CPPFLAGS, CFLAGS, CXXFLAGS, LDFLAGS missing.
I-invalid-cmake-used (version)
By default CMake ignores CPPFLAGS thus missing those hardening flags. Debian patched CMake in versions 2.8.7-1 and 2.8.7-2 to respect CPPFLAGS, but this patch was rejected by upstream and later reverted in Debian. Thus those two versions show correct usage of CPPFLAGS even if the package doesnāt correctly handle them (for example by passing them to CFLAGS). To prevent false negatives just blacklist those two versions.
I-no-compiler-commands
No compiler commands were detected. Either the log contains none or they were not correctly detected by blhc (please report the bug in this case).
EXIT STATUS
The exit status is a "bit mask", each listed status is ORed when the error condition occurs to get the result.
|
0 |
Success. |
||
|
1 |
No compiler commands were found. |
||
|
2 |
Invalid arguments/options given to blhc. |
||
|
4 |
Non verbose build. |
||
|
8 |
Missing hardening flags. |
||
|
16 |
Hardening wrapper detected, no tests performed. |
||
|
32 |
Invalid CMake version used. See I-invalid-cmake-used under "BUILDD TAGS" for a detailed explanation. |
AUTHOR
Simon Ruderich, <simon@ruderich.org>
Thanks to to Bernhard R. Link <brlink@debian.org> and Jaria Alto <jari.aalto@cante.net> for their valuable input and suggestions.
LICENSE AND COPYRIGHT
Copyright (C) 2012-2024 by Simon Ruderich
This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
This program 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 General Public License for more details.
You should have received a copy of the GNU General Public License along with this program. If not, see <http://www.gnu.org/licenses/>.
SEE ALSO
hardening-check (1), dpkg-buildflags (1)