hardening.mk 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. #
  2. # Copyright (C) 2015 OpenWrt.org
  3. #
  4. # This is free software, licensed under the GNU General Public License v2.
  5. # See /LICENSE for more information.
  6. #
  7. PKG_CHECK_FORMAT_SECURITY ?= 1
  8. PKG_ASLR_PIE ?= 1
  9. PKG_ASLR_PIE_REGULAR ?= 0
  10. PKG_SSP ?= 1
  11. PKG_FORTIFY_SOURCE ?= 1
  12. PKG_RELRO ?= 1
  13. ifdef CONFIG_PKG_CHECK_FORMAT_SECURITY
  14. ifeq ($(strip $(PKG_CHECK_FORMAT_SECURITY)),1)
  15. TARGET_CFLAGS += -Wformat -Werror=format-security
  16. endif
  17. endif
  18. ifdef CONFIG_PKG_ASLR_PIE_ALL
  19. ifeq ($(strip $(PKG_ASLR_PIE)),1)
  20. TARGET_CFLAGS += $(FPIC)
  21. TARGET_LDFLAGS += $(FPIC) -specs=$(INCLUDE_DIR)/hardened-ld-pie.specs
  22. endif
  23. endif
  24. ifdef CONFIG_PKG_ASLR_PIE_REGULAR
  25. ifeq ($(strip $(PKG_ASLR_PIE_REGULAR)),1)
  26. TARGET_CFLAGS += $(FPIC)
  27. TARGET_LDFLAGS += $(FPIC) -specs=$(INCLUDE_DIR)/hardened-ld-pie.specs
  28. endif
  29. endif
  30. ifdef CONFIG_PKG_CC_STACKPROTECTOR_REGULAR
  31. ifeq ($(strip $(PKG_SSP)),1)
  32. TARGET_CFLAGS += -fstack-protector
  33. endif
  34. endif
  35. ifdef CONFIG_PKG_CC_STACKPROTECTOR_STRONG
  36. ifeq ($(strip $(PKG_SSP)),1)
  37. TARGET_CFLAGS += -fstack-protector-strong
  38. endif
  39. endif
  40. ifdef CONFIG_PKG_FORTIFY_SOURCE_1
  41. ifeq ($(strip $(PKG_FORTIFY_SOURCE)),1)
  42. TARGET_CFLAGS += -D_FORTIFY_SOURCE=1
  43. endif
  44. endif
  45. ifdef CONFIG_PKG_FORTIFY_SOURCE_2
  46. ifeq ($(strip $(PKG_FORTIFY_SOURCE)),1)
  47. TARGET_CFLAGS += -D_FORTIFY_SOURCE=2
  48. endif
  49. endif
  50. ifdef CONFIG_PKG_RELRO_PARTIAL
  51. ifeq ($(strip $(PKG_RELRO)),1)
  52. TARGET_CFLAGS += -Wl,-z,relro
  53. TARGET_LDFLAGS += -zrelro
  54. endif
  55. endif
  56. ifdef CONFIG_PKG_RELRO_FULL
  57. ifeq ($(strip $(PKG_RELRO)),1)
  58. TARGET_CFLAGS += -Wl,-z,now -Wl,-z,relro
  59. TARGET_LDFLAGS += -znow -zrelro
  60. endif
  61. endif