200-add_libssp_nonshared.patch 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. From 7ec87fbbc3cac99b4173d082dd6195f47c9a32e7 Mon Sep 17 00:00:00 2001
  2. From: Steven Barth <steven@midlink.org>
  3. Date: Mon, 22 Jun 2015 11:01:56 +0200
  4. Subject: [PATCH] Add libssp_nonshared.a so GCC's is not needed
  5. Signed-off-by: Steven Barth <steven@midlink.org>
  6. ---
  7. Makefile | 10 ++++++++--
  8. libssp_nonshared/__stack_chk_fail_local.c | 2 ++
  9. 2 files changed, 10 insertions(+), 2 deletions(-)
  10. create mode 100644 libssp_nonshared/__stack_chk_fail_local.c
  11. --- a/Makefile
  12. +++ b/Makefile
  13. @@ -48,7 +48,7 @@ CRT_LIBS = lib/crt1.o lib/Scrt1.o lib/rc
  14. STATIC_LIBS = lib/libc.a
  15. SHARED_LIBS = lib/libc.so
  16. TOOL_LIBS = lib/musl-gcc.specs
  17. -ALL_LIBS = $(CRT_LIBS) $(STATIC_LIBS) $(SHARED_LIBS) $(EMPTY_LIBS) $(TOOL_LIBS)
  18. +ALL_LIBS = $(CRT_LIBS) $(STATIC_LIBS) $(SHARED_LIBS) $(EMPTY_LIBS) $(TOOL_LIBS) lib/libssp_nonshared.a
  19. ALL_TOOLS = tools/musl-gcc
  20. WRAPCC_GCC = gcc
  21. @@ -106,7 +106,8 @@ NOSSP_SRCS = $(wildcard crt/*.c) \
  22. src/env/__libc_start_main.c src/env/__init_tls.c \
  23. src/thread/__set_thread_area.c src/env/__stack_chk_fail.c \
  24. src/string/memset.c src/string/memcpy.c \
  25. - src/ldso/dlstart.c src/ldso/dynlink.c
  26. + src/ldso/dlstart.c src/ldso/dynlink.c \
  27. + libssp_nonshared/__stack_chk_fail_local.c
  28. $(NOSSP_SRCS:%.c=%.o) $(NOSSP_SRCS:%.c=%.lo): CFLAGS += $(CFLAGS_NOSSP)
  29. $(CRT_LIBS:lib/%=crt/%): CFLAGS += -DCRT
  30. @@ -147,6 +148,11 @@ lib/libc.a: $(OBJS)
  31. $(AR) rc $@ $(OBJS)
  32. $(RANLIB) $@
  33. +lib/libssp_nonshared.a: libssp_nonshared/__stack_chk_fail_local.o
  34. + rm -f $@
  35. + $(AR) rc $@ $<
  36. + $(RANLIB) $@
  37. +
  38. $(EMPTY_LIBS):
  39. rm -f $@
  40. $(AR) rc $@
  41. --- /dev/null
  42. +++ b/libssp_nonshared/__stack_chk_fail_local.c
  43. @@ -0,0 +1,2 @@
  44. +#include "atomic.h"
  45. +void __attribute__((visibility ("hidden"))) __stack_chk_fail_local(void) { a_crash(); }