aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorToni Uhlig <matzeton@googlemail.com>2023-10-01 17:47:25 +0200
committerToni Uhlig <matzeton@googlemail.com>2023-10-01 17:47:25 +0200
commit649eef78f8c06bb5275736f11434e4087392b8f5 (patch)
treeb81e7e841595c9323f0e9e6a463de8f1986bf21d
parent54f3087873fa1083c809939e74caf1ff29efc9d7 (diff)
Added custom linker script.
* discard .xdata section (unwind data for SEH will be done in another way) Signed-off-by: Toni Uhlig <matzeton@googlemail.com>
-rw-r--r--Makefile1
-rw-r--r--Makefile.deps1
-rw-r--r--Makefile.inc6
-rw-r--r--ld-script.txt395
4 files changed, 402 insertions, 1 deletions
diff --git a/Makefile b/Makefile
index 6a734fb..ea3c9c7 100644
--- a/Makefile
+++ b/Makefile
@@ -50,5 +50,6 @@ package:
help:
$(MAKE) -C $(DPP_ROOT) -f Makefile.deps help
+.NOTPARALLEL: examples-clean deps-clean deps-distclean
.PHONY: examples deps deps-distclean deps-clean help
.DEFAULT_GOAL := deps
diff --git a/Makefile.deps b/Makefile.deps
index 72d3e08..bfdfedc 100644
--- a/Makefile.deps
+++ b/Makefile.deps
@@ -236,5 +236,6 @@ help:
@echo -e '\tWERROR = $(WERROR)'
@echo -e '\tQ = $(Q)'
+.NOTPARALLEL: distclean clean
.PHONY: all deps-print-local-notice deps-build deps package distclean clean help
.DEFAULT_GOAL := all
diff --git a/Makefile.inc b/Makefile.inc
index 1689579..c4ac08d 100644
--- a/Makefile.inc
+++ b/Makefile.inc
@@ -59,6 +59,8 @@ ifneq ($(WERROR),)
CFLAGS += -Werror
endif
+#PRINT_LDSCRIPT = -Wl,--verbose
+
CXXFLAGS := -fno-exceptions -fno-rtti -fuse-cxa-atexit
EASTL_CXXFLAGS := -I$(DPP_ROOT)/EASTL/include -I$(DPP_ROOT)/EASTL/test/packages/EABase/include/Common \
-DEASTL_USER_CONFIG_HEADER="<eastl_user_config.hpp>" \
@@ -81,7 +83,9 @@ DRIVER_LDFLAGS := -shared \
-Wl,--gc-sections \
-Wl,--exclude-all-symbols \
-Wl,--entry,_CRT_DriverEntry \
- -nostartfiles -nodefaultlibs -nostdlib
+ $(PRINT_LDSCRIPT) \
+ -nostartfiles -nodefaultlibs -nostdlib \
+ -T$(DPP_ROOT)/ld-script.txt
DRIVER_LIBS := -lntoskrnl -lhal
USER_LDFLAGS := -Wl,--dynamicbase -Wl,--nxcompat -Wl,--gc-sections
USER_LIBS :=
diff --git a/ld-script.txt b/ld-script.txt
new file mode 100644
index 0000000..92633d1
--- /dev/null
+++ b/ld-script.txt
@@ -0,0 +1,395 @@
+OUTPUT_FORMAT(pei-x86-64)
+SEARCH_DIR("=/home/toni/git/mingw-w64-dpp/mingw-w64-sysroot/x86_64/x86_64-w64-mingw32/lib"); SEARCH_DIR("=/usr/local/lib"); SEARCH_DIR("=/lib"); SEARCH_DIR("=/usr/lib");
+SECTIONS
+{
+ /* Make the virtual address and file offset synced if the alignment is
+ lower than the target page size. */
+ . = SIZEOF_HEADERS;
+ . = ALIGN(__section_alignment__);
+ .text __image_base__ + ( __section_alignment__ < 0x1000 ? . : __section_alignment__ ) :
+ {
+ KEEP (*(SORT_NONE(.init)))
+ *(.text)
+ *(SORT(.text$*))
+ *(.text.*)
+ *(.gnu.linkonce.t.*)
+ *(.glue_7t)
+ *(.glue_7)
+ . = ALIGN(8);
+ /* Note: we always define __CTOR_LIST__ and ___CTOR_LIST__ here,
+ we do not PROVIDE them. This is because the ctors.o startup
+ code in libgcc defines them as common symbols, with the
+ expectation that they will be overridden by the definitions
+ here. If we PROVIDE the symbols then they will not be
+ overridden and global constructors will not be run.
+ See PR 22762 for more details.
+
+ This does mean that it is not possible for a user to define
+ their own __CTOR_LIST__ and __DTOR_LIST__ symbols; if they do,
+ the content from those variables are included but the symbols
+ defined here silently take precedence. If they truly need to
+ be redefined, a custom linker script will have to be used.
+ (The custom script can just be a copy of this script with the
+ PROVIDE() qualifiers added).
+ In particular this means that ld -Ur does not work, because
+ the proper __CTOR_LIST__ set by ld -Ur is overridden by a
+ bogus __CTOR_LIST__ set by the final link. See PR 46. */
+ ___CTOR_LIST__ = .;
+ __CTOR_LIST__ = .;
+ LONG (-1); LONG (-1);
+ KEEP (*(.ctors));
+ KEEP (*(.ctor));
+ KEEP (*(SORT_BY_NAME(.ctors.*)));
+ LONG (0); LONG (0);
+ /* See comment about __CTOR_LIST__ above. The same reasoning
+ applies here too. */
+ ___DTOR_LIST__ = .;
+ __DTOR_LIST__ = .;
+ LONG (-1); LONG (-1);
+ KEEP (*(.dtors));
+ KEEP (*(.dtor));
+ KEEP (*(SORT_BY_NAME(.dtors.*)));
+ LONG (0); LONG (0);
+ KEEP (*(SORT_NONE(.fini)))
+ /* ??? Why is .gcc_exc here? */
+ *(.gcc_exc)
+ PROVIDE (etext = .);
+ KEEP (*(.gcc_except_table))
+ }
+ /* The Cygwin32 library uses a section to avoid copying certain data
+ on fork. This used to be named ".data". The linker used
+ to include this between __data_start__ and __data_end__, but that
+ breaks building the cygwin32 dll. Instead, we name the section
+ ".data_cygwin_nocopy" and explicitly include it after __data_end__. */
+ .data BLOCK(__section_alignment__) :
+ {
+ __data_start__ = . ;
+ *(.data)
+ *(.data2)
+ *(SORT(.data$*))
+ KEEP(*(.jcr))
+ __data_end__ = . ;
+ *(.data_cygwin_nocopy)
+ }
+ .rdata BLOCK(__section_alignment__) :
+ {
+ *(.rdata)
+ *(SORT(.rdata$*))
+ . = ALIGN(4);
+ __rt_psrelocs_start = .;
+ KEEP(*(.rdata_runtime_pseudo_reloc))
+ __rt_psrelocs_end = .;
+ }
+ __rt_psrelocs_size = __rt_psrelocs_end - __rt_psrelocs_start;
+ ___RUNTIME_PSEUDO_RELOC_LIST_END__ = .;
+ __RUNTIME_PSEUDO_RELOC_LIST_END__ = .;
+ ___RUNTIME_PSEUDO_RELOC_LIST__ = . - __rt_psrelocs_size;
+ __RUNTIME_PSEUDO_RELOC_LIST__ = . - __rt_psrelocs_size;
+ .eh_frame BLOCK(__section_alignment__) :
+ {
+ KEEP (*(.eh_frame*))
+ }
+ .pdata BLOCK(__section_alignment__) :
+ {
+ KEEP(*(.pdata*))
+ }
+ .bss BLOCK(__section_alignment__) :
+ {
+ __bss_start__ = . ;
+ *(.bss)
+ *(COMMON)
+ __bss_end__ = . ;
+ }
+ .edata BLOCK(__section_alignment__) :
+ {
+ *(.edata)
+ }
+ /DISCARD/ :
+ {
+ *(.xdata*)
+ *(.debug$S)
+ *(.debug$T)
+ *(.debug$F)
+ *(.drectve)
+ *(.note.GNU-stack)
+ *(.gnu.lto_*)
+ }
+ .idata BLOCK(__section_alignment__) :
+ {
+ /* This cannot currently be handled with grouped sections.
+ See pep.em:sort_sections. */
+ KEEP (SORT(*)(.idata$2))
+ KEEP (SORT(*)(.idata$3))
+ /* These zeroes mark the end of the import list. */
+ LONG (0); LONG (0); LONG (0); LONG (0); LONG (0);
+ KEEP (SORT(*)(.idata$4))
+ __IAT_start__ = .;
+ SORT(*)(.idata$5)
+ __IAT_end__ = .;
+ KEEP (SORT(*)(.idata$6))
+ KEEP (SORT(*)(.idata$7))
+ }
+ .CRT BLOCK(__section_alignment__) :
+ {
+ ___crt_xc_start__ = . ;
+ KEEP (*(SORT(.CRT$XC*))) /* C initialization */
+ ___crt_xc_end__ = . ;
+ ___crt_xi_start__ = . ;
+ KEEP (*(SORT(.CRT$XI*))) /* C++ initialization */
+ ___crt_xi_end__ = . ;
+ ___crt_xl_start__ = . ;
+ KEEP (*(SORT(.CRT$XL*))) /* TLS callbacks */
+ /* ___crt_xl_end__ is defined in the TLS Directory support code */
+ ___crt_xp_start__ = . ;
+ KEEP (*(SORT(.CRT$XP*))) /* Pre-termination */
+ ___crt_xp_end__ = . ;
+ ___crt_xt_start__ = . ;
+ KEEP (*(SORT(.CRT$XT*))) /* Termination */
+ ___crt_xt_end__ = . ;
+ }
+ /* Windows TLS expects .tls$AAA to be at the start and .tls$ZZZ to be
+ at the end of the .tls section. This is important because _tls_start MUST
+ be at the beginning of the section to enable SECREL32 relocations with TLS
+ data. */
+ .tls BLOCK(__section_alignment__) :
+ {
+ ___tls_start__ = . ;
+ KEEP (*(.tls$AAA))
+ KEEP (*(.tls))
+ KEEP (*(.tls$))
+ KEEP (*(SORT(.tls$*)))
+ KEEP (*(.tls$ZZZ))
+ ___tls_end__ = . ;
+ }
+ .endjunk BLOCK(__section_alignment__) :
+ {
+ /* end is deprecated, don't use it */
+ PROVIDE (end = .);
+ PROVIDE ( _end = .);
+ __end__ = .;
+ }
+ .rsrc BLOCK(__section_alignment__) : SUBALIGN(4)
+ {
+ KEEP (*(.rsrc))
+ KEEP (*(.rsrc$*))
+ }
+ .reloc BLOCK(__section_alignment__) :
+ {
+ *(.reloc)
+ }
+ .stab BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.stab)
+ }
+ .stabstr BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.stabstr)
+ }
+ /* DWARF debug sections.
+ Symbols in the DWARF debugging sections are relative to the beginning
+ of the section. Unlike other targets that fake this by putting the
+ section VMA at 0, the PE format will not allow it. */
+ /* DWARF 1.1 and DWARF 2. */
+ .debug_aranges BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_aranges)
+ }
+ .zdebug_aranges BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.zdebug_aranges)
+ }
+ .debug_pubnames BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_pubnames)
+ }
+ .zdebug_pubnames BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.zdebug_pubnames)
+ }
+ /* DWARF 2. */
+ .debug_info BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_info .gnu.linkonce.wi.*)
+ }
+ .zdebug_info BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.zdebug_info .zdebug.gnu.linkonce.wi.*)
+ }
+ .debug_abbrev BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_abbrev)
+ }
+ .zdebug_abbrev BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.zdebug_abbrev)
+ }
+ .debug_line BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_line)
+ }
+ .zdebug_line BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.zdebug_line)
+ }
+ .debug_frame BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_frame*)
+ }
+ .zdebug_frame BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.zdebug_frame*)
+ }
+ .debug_str BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_str)
+ }
+ .zdebug_str BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.zdebug_str)
+ }
+ .debug_loc BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_loc)
+ }
+ .zdebug_loc BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.zdebug_loc)
+ }
+ .debug_macinfo BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_macinfo)
+ }
+ .zdebug_macinfo BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.zdebug_macinfo)
+ }
+ /* SGI/MIPS DWARF 2 extensions. */
+ .debug_weaknames BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_weaknames)
+ }
+ .zdebug_weaknames BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.zdebug_weaknames)
+ }
+ .debug_funcnames BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_funcnames)
+ }
+ .zdebug_funcnames BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.zdebug_funcnames)
+ }
+ .debug_typenames BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_typenames)
+ }
+ .zdebug_typenames BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.zdebug_typenames)
+ }
+ .debug_varnames BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_varnames)
+ }
+ .zdebug_varnames BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.zdebug_varnames)
+ }
+ /* DWARF 3. */
+ .debug_pubtypes BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_pubtypes)
+ }
+ .zdebug_pubtypes BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.zdebug_pubtypes)
+ }
+ .debug_ranges BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_ranges)
+ }
+ .zdebug_ranges BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.zdebug_ranges)
+ }
+ /* DWARF 4. */
+ .debug_types BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_types .gnu.linkonce.wt.*)
+ }
+ .zdebug_types BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.zdebug_types .gnu.linkonce.wt.*)
+ }
+ /* DWARF 5. */
+ .debug_addr BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_addr)
+ }
+ .zdebug_addr BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.zdebug_addr)
+ }
+ .debug_line_str BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_line_str)
+ }
+ .zdebug_line_str BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.zdebug_line_str)
+ }
+ .debug_loclists BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_loclists)
+ }
+ .zdebug_loclists BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.zdebug_loclists)
+ }
+ .debug_macro BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_macro)
+ }
+ .zdebug_macro BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.zdebug_macro)
+ }
+ .debug_names BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_names)
+ }
+ .zdebug_names BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.zdebug_names)
+ }
+ .debug_rnglists BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_rnglists)
+ }
+ .zdebug_rnglists BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.zdebug_rnglists)
+ }
+ .debug_str_offsets BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_str_offsets)
+ }
+ .zdebug_str_offsets BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.zdebug_str_offsets)
+ }
+ .debug_sup BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_sup)
+ }
+ /* For Go and Rust. */
+ .debug_gdb_scripts BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.debug_gdb_scripts)
+ }
+ .zdebug_gdb_scripts BLOCK(__section_alignment__) (NOLOAD) :
+ {
+ *(.zdebug_gdb_scripts)
+ }
+}