summaryrefslogtreecommitdiffstats
path: root/lib/csu (follow)
Commit message (Collapse)AuthorAgeFilesLines
* Use a trap instruction that unconditionally terminates the process.visa2020-10-201-2/+2
| | | | OK deraadt@
* replace ad-hoc illegal instruction with the architecturally defined onenaddy2020-10-192-4/+4
| | | | | ("permanently undefined") ok deraadt@ kettenis@
* crt0 MD _dl_exit() performs syscall to SYS_exit directly, but thenderaadt2020-10-1512-30/+24
| | | | | | | | | | | some of these functions were returning. That makes the +1word address a fairly strong and easily located gadget. Put a hard-trap instruction after the syscall. This remains a gadget for 'terminal system' calls (such as execve), but hey that's why we have pledge w/o "exec" throughout the tree. Quite surprisingly, hppa's delay-slot load of SYS_exit makes it the safest of the bunch, not that this helps anyone. ok kettenis
* use symbolic SYS_exit rather than 1, and skip usingderaadt2020-10-141-4/+2
| | | | | the 0x400 %g2 syscall method ok kettenis
* use symbolic SYS_exit instead of the value 1deraadt2020-10-1412-31/+24
| | | | ok kettenis
* Prevent the use of jump tables on powerpc64 as well.kettenis2020-06-271-2/+3
| | | | ok patrick@, drahn@
* Fix powerpc64 pie binraries, in register renumbering one line was missed.drahn2020-06-261-2/+2
|
* disable altivec and vsx as it causes issues in qemu testing.drahn2020-06-251-1/+5
| | | | | This probably should be backed out after fully debugged, vector instructions caused problems with debug configuration.
* PowerPC64 startup code.drahn2020-06-251-0/+124
| | | | Determine location of toc based on PC relative location and load into %r2
* Disable builtins on ppc in order to prevent the compiler from optimizing inmortimer2020-05-191-2/+2
| | | | | | | calls to libc in the process boot code that might not work before things like the GOT are set up. Suggested by deraadt@ ok visa@
* Anthony Steinhauser reports that 32-bit arm cpus have the same speculationderaadt2020-03-131-3/+3
| | | | | | | | | | | problems as 64-bit models. To resolve the syscall speculation, as a first step "nop; nop" was added after all occurances of the syscall ("swi 0") instruction. Then the kernel was changed to jump over the 2 extra instructions. In this final step, those pair of nops are converted into the speculation-blocking sequence ("dsb nsh; isb"). Don't try to build through these multiple steps, use a snapshot instead. Packages matching the new ABI will be out in a while... ok kettenis
* Anthony Steinhauser reports that 32-bit arm cpus have the same speculationderaadt2020-03-111-1/+3
| | | | | problems as 64-bit models. For the syscall instruction issue, add nop;nop after swi 0, in preparation for jumping over a speculation barrier here later.
* Now that the kernel skips the two instructions immediately followingkettenis2020-02-181-3/+3
| | | | | | | | a syscall, replace the double nop with a dsb nsh; isb; sequence which stops the CPU from speculating any further. This fix was suggested by Anthony Steinhauser. ok deraadt@
* Insert two nop instructions after each svc #0 instruction in userland.kettenis2020-01-261-1/+3
| | | | | | | | The will be replaced by a speculation barrier as soon as we teach the kernel to skip over these two instructions when returning from a system call. ok patrick@, deraadt@
* Need to compile rcrt0.o with -fno-jump-tables on powerpc as well.kettenis2019-07-011-3/+8
| | | | ok visa@
* Since clang only supports the "secure" PLT ABI for "big" PIC/PIE on powerpc,kettenis2019-06-281-9/+1
| | | | | | stop building the csu code with -fpie on that platform. ok guenther@, visa@
* ld.so boot cleanup support:guenther2019-05-103-6/+18
| | | | | | | | | | | | | | | | | - put functions and data which are only used before calling the executable's start function into their own page-aligned segments for unmapping (only done on amd64, arm64, armv7, powerpc, and sparc64 so far) - pass .init_array and .preinit_array functions an addition argument which is a callback to get a structure which includes a function that frees the boot text and data - sometimes delay doing RELRO processing: for a shared-object marked DF_1_INITFIRST do it after the object's .init_array, for the executable do it after the .preinit_array - improve test-ld.so to link against libpthread and trigger its initialization late libc changes to use this will come later ok kettenis@
* Call _csu_finish() before {pre,}init_array functions so that in staticguenther2019-05-081-3/+3
| | | | | | | executables the TIB and __progname are set up before they can be used. problem noted by ori@ ok millert@ kettenis@
* Work around a limitation of clang integrated assembler on mips64.visa2019-04-191-1/+4
| | | | | | | | | The assembler does not handle undeclared local symbols properly and generates R_MIPS_CALL16 relocations where it should generate local GOT references. For now, get along with the problem by declaring local symbols where necessary. OK kettenis@ guenther@
* Prevent clang from using builtins and jump tables in _dl_boot_bind()visa2019-04-191-1/+6
| | | | | | | on mips64. They need relocation and consequently cannot be used in that function. OK kettenis@
* Separate symbol name and type with a comma for consistency andvisa2019-03-231-2/+2
| | | | | | to make clang happier. No binary change with gas.
* Remove -S from install commandskn2019-02-241-2/+2
| | | | | | | | As of usr.bin/xinstall/install.c revision 1.68, -S is a no-op and install(1) will always create files safely, thus clean the option usage from the tree. Diff from Lauri Tirkkonen <lotheac at iki dot fi>, thanks.
* Use static consistently with definitions of functions that have beenvisa2019-01-093-8/+8
| | | | | | declared static. OK guenther@
* Add support for {preinit,init,fini}_array sections in static binariesguenther2018-12-213-2/+34
| | | | ok kettenis@
* Make alpha less special: _dl_boot_bind() is written to completeguenther2018-11-222-41/+7
| | | | | | | | | relocation of ld.so's GOT without using it, so _reloc_alpha_got() merely made the call to _dl_boot_bind() from asm simpler...while itself being a call that required special handling. diff and muild baking by miod@ ok guenther@
* Insert definitions of environ and __progname in MD_CRT0_START again.aoyama2018-10-061-1/+5
| | | | | | | | | | That part is not needed with a PIE toolchain, but until gcc 4 on m88k receives enough fixes to produce as good code as gcc 3, the bits in r1.5 are still required. This fixes miniperl does not work correctly while building perl on m88k. Diff is suggested by Miod Vallat, tested by him and me, ok guenther@
* Fix address calculation for _DYNAMIC. We want to address of _DYNAMIC itself,kettenis2018-07-241-2/+2
| | | | | | | | | not the address of its GOT entry. The current code mixed the high bits of the GOT entry address with the low bits of the true address. This only worked by accident for small binaries where _DYNAMIC and its GOT entry happen to reside on the same page. ok guenther@, mortimer@
* Add add PIE support for m88k (requires gcc4 toolchain)guenther2018-06-161-5/+37
| | | | | | Convert __cerror to hidden visibility. from miod@
* Fix dependency generation: pass ${DFLAGS} and -MF explicitlyguenther2017-08-121-8/+11
| | | | | problem noted by deraadt@ ok espie@
* _dl_printf is no longer referenced by RELOC_{JMPREL,DYN,GOT}; delete the stubguenther2017-08-119-61/+9
| | | | ok kettenis@
* remove misc. depend and yacc nits that no longer matter.espie2017-07-101-4/+1
| | | | okay millert@
* Our certbegin/certend is always PIC, so remove the non-PIC MD_SECT_CALL_FUNC()kettenis2017-02-262-30/+2
| | | | | | implementations. ok guenther@
* Use a long branch (using movw/movt) to implement MD_SECT_CALL_FUNC.kettenis2017-02-261-15/+5
| | | | | | Necessary (but perhaps not suffcient) to build large binaries on arm. ok guenther@
* Move static variables from .data to .bss by not initializing them to zeroguenther2017-02-192-6/+6
| | | | ok kettenis@
* remove unused variableschl2017-01-291-3/+1
| | | | ok krw@ guenther@
* Fix passing &_DYNAMIC to _dl_boot_bind; makes -static -pie work.kettenis2017-01-241-2/+3
|
* Make crtbegin.c and crtbeginS.c consistent on stylistic pointsguenther2017-01-212-20/+16
| | | | ok kettenis@
* Pull in declarations for main() and __init() to make clang happy.guenther2017-01-212-6/+4
| | | | | | Mark __init() as hidden ok kettenis@ deraadt@
* Fix misspelling in commentguenther2017-01-211-2/+2
|
* amd64 can build rcrt0.o with the stack-protectorguenther2017-01-211-3/+10
| | | | ok kettenis@ deraadt@
* Declare the symbols that label the .ctors, .dtors, .eh_frame, and .jcrguenther2017-01-217-39/+95
| | | | | | | | | | sections as extern hidden arrays of indefinite size, so that the compiler (well, clang) doesn't believe it knows the exact contents and thus optimize things into infinite loops. Actually set the symbols to be in the sections and insert the leading and trailing values via __asm(). Problem pointed out by patrick@ testing and ok kettenis@
* MD_START is now always ___start, so expand and eliminate itguenther2017-01-193-11/+4
| | | | ok phessler@ deraadt@
* Add support for AArch64.patrick2017-01-111-0/+130
|
* Remove the (now unused) code to determine the page size. Also get rid ofkettenis2017-01-021-10/+1
| | | | | | the extern declaration of __got_{start,end}. ok guenther@
* Replace return by break; requested by guenther@kettenis2016-12-241-2/+2
|
* Remove code that reprotects the GOT based on the __got_start and __got_endkettenis2016-12-241-11/+1
| | | | | | | | | symbols. Either the PT_LOAD RWX->RX case ot PT_GNU_RELRO should cover this already for anything we care about. And lld, the llvm linker, doesn't emit the __got_start and __got_end symbols and there are good reasons to leave it that way. ok guenther@
* Don't make __CTOR_LIST__ and __DTOR_LIST__ const. This makes the .ctors andkettenis2016-12-221-3/+3
| | | | | | | | .dtors sections writable just like they are in crtend.o and code generated by compilers. This is necessary to make sure that linkers that respect the ELF spec a bit better (such as lld) correctly concatenate the secttions. ok deraadt@
* A couple more unused variables.krw2016-12-191-3/+2
| | | | tweak & ok kettenis@
* Use sed -i to post-process .depend. This avoids permission issues causednatano2016-11-081-8/+2
| | | | | | by the file being created in /tmp. tweaks and ok tb
* unify tmp depend generation.espie2016-10-151-5/+8
| | | | | | | | - simpler uniform pattern - put the tmpfile in OBJDIR, so that mv doesn't whine about groups when using a separate builduser. okay millert@