nixpkgs/pkgs/build-support/cc-wrapper/add-hardening

59 lines
2.0 KiB
Plaintext
Raw Normal View History

hardeningFlags=(fortify stackprotector pic strictoverflow format relro bindnow)
hardeningFlags+=("${hardeningEnable[@]}")
hardeningCFlags=()
hardeningLDFlags=()
hardeningDisable=(${hardeningDisable[@]})
if [[ "$($LD -z 2>&1)" =~ "unknown option" ]]; then
hardeningDisable+=(bindnow relro)
fi
if [[ ! $hardeningDisable == "all" ]]; then
for flag in "${hardeningFlags[@]}"
do
if [[ ! "${hardeningDisable[@]}" =~ "$flag" ]]; then
case $flag in
fortify)
2016-03-09 01:08:07 -08:00
if [[ -n "$NIX_DEBUG" ]]; then echo HARDENING: enabling fortify; fi
hardeningCFlags+=('-O2' '-D_FORTIFY_SOURCE=2')
;;
stackprotector)
2016-03-09 01:08:07 -08:00
if [[ -n "$NIX_DEBUG" ]]; then echo HARDENING: enabling stackprotector; fi
hardeningCFlags+=('-fstack-protector-strong' '--param ssp-buffer-size=4')
;;
pie)
2016-03-09 01:08:07 -08:00
if [[ -n "$NIX_DEBUG" ]]; then echo HARDENING: enabling CFlags -fPIE; fi
2016-03-05 15:14:55 -08:00
hardeningCFlags+=('-fPIE')
if [[ ! ("$*" =~ " -shared " || "$*" =~ " -static ") ]]; then
2016-03-09 01:08:07 -08:00
if [[ -n "$NIX_DEBUG" ]]; then echo HARDENING: enabling LDFlags -pie; fi
hardeningLDFlags+=('-pie')
fi
;;
pic)
2016-03-09 01:08:07 -08:00
if [[ -n "$NIX_DEBUG" ]]; then echo HARDENING: enabling pic; fi
hardeningCFlags+=('-fPIC')
;;
strictoverflow)
2016-03-09 01:08:07 -08:00
if [[ -n "$NIX_DEBUG" ]]; then echo HARDENING: enabling strictoverflow; fi
hardeningCFlags+=('-fno-strict-overflow')
;;
format)
2016-03-09 01:08:07 -08:00
if [[ -n "$NIX_DEBUG" ]]; then echo HARDENING: enabling format; fi
hardeningCFlags+=('-Wformat' '-Wformat-security' '-Werror=format-security')
;;
relro)
2016-03-09 01:08:07 -08:00
if [[ -n "$NIX_DEBUG" ]]; then echo HARDENING: enabling relro; fi
hardeningLDFlags+=('-z relro')
;;
bindnow)
2016-03-09 01:08:07 -08:00
if [[ -n "$NIX_DEBUG" ]]; then echo HARDENING: enabling bindnow; fi
hardeningLDFlags+=('-z now')
;;
*)
echo "Hardening flag unknown: $flag"
;;
esac
fi
done
fi