1. 05 10月, 2012 6 次提交
    • R
      fix race condition in dlopen · 642b7593
      Rich Felker 提交于
      orig_tail was being saved before the lock was obtained, allowing
      dlopen failure to roll-back other dlopens that had succeeded.
      642b7593
    • R
      dynamic-linked TLS support for everything but dlopen'd libs · 9c74856a
      Rich Felker 提交于
      currently, only i386 is tested. x86_64 and arm should probably work.
      the necessary relocation types for mips and microblaze have not been
      added because I don't understand how they're supposed to work, and I'm
      not even sure if it's defined yet on microblaze. I may be able to
      reverse engineer the requirements out of gcc/binutils output.
      9c74856a
    • R
      remove freeing of dynamic linker data when dlopen/dlsym are not used · c91aa03d
      Rich Felker 提交于
      this was an optimization to save/recover a minimal amount of extra
      memory for use by malloc, that's becoming increasingly costly to keep
      around. freeing this data:
      
      1. breaks debugging with gdb (it can't find library symbols)
      2. breaks thread-local storage in shared libraries
      
      it would be possible to disable freeing when TLS is used, but in
      addition to the above breakages, tracking whether dlopen/dlsym is used
      adds a cost to every symbol lookup, possibly making program startup
      slower for large programs. combined with the complexity, it's not
      worth it. we already save/recover plenty of memory in the dynamic
      linker with reclaim_gaps.
      c91aa03d
    • R
      beginnings of full TLS support in shared libraries · 9b153c04
      Rich Felker 提交于
      this code will not work yet because the necessary relocations are not
      supported, and cannot be supported without some internal changes to
      how relocation processing works (coming soon).
      9b153c04
    • R
      partial TLS support for dynamic-linked programs · bc6a35fb
      Rich Felker 提交于
      only TLS in the main program is supported so far; TLS defined in
      shared libraries will not work yet.
      bc6a35fb
    • R
      TLS (GNU/C11 thread-local storage) support for static-linked programs · 8431d797
      Rich Felker 提交于
      the design for TLS in dynamic-linked programs is mostly complete too,
      but I have not yet implemented it. cost is nonzero but still low for
      programs which do not use TLS and/or do not use threads (a few hundred
      bytes of new code, plus dependency on memcpy). i believe it can be
      made smaller at some point by merging __init_tls and __init_security
      into __libc_start_main and avoiding duplicate auxv-parsing code.
      
      at the same time, I've also slightly changed the logic pthread_create
      uses to allocate guard pages to ensure that guard pages are not
      counted towards commit charge.
      8431d797
  2. 01 10月, 2012 4 次提交
    • R
      add getopt reset support · 030e5263
      Rich Felker 提交于
      based on proposed patches by Daniel Cegiełka, with minor changes:
      - use a weak symbol for optreset so it doesn't clash with namespace
      - also reset optpos (position in multi-option arg like -lR)
      - also make getopt_long support reset
      030e5263
    • R
      protect sem_open against cancellation · e44849f5
      Rich Felker 提交于
      also fix one minor bug: failure to free the early-reserved slot when
      the semaphore later found to already be mapped.
      e44849f5
    • R
      overhaul sem_open · bf258341
      Rich Felker 提交于
      this function was overly complicated and not even obviously correct.
      avoid using openat/linkat just like in shm_open, and instead expand
      pathname using code shared with shm_open. remove bogus (and dangerous,
      with priorities) use of spinlocks.
      
      this commit also heavily streamlines the code and ensures there are no
      failure cases that can happen after a new semaphore has been created
      in the filesystem, since that case is unreportable.
      bf258341
    • R
      clean up, bugfixes, and general improvement for shm_open/shm_unlink · 6e2372a8
      Rich Felker 提交于
      1. don't make non-cloexec file descriptors
      2. cancellation safety (cleanup handlers were missing, now unneeded)
      3. share name validation/mapping code between open/unlink functions
      4. avoid wasteful/slow syscalls
      6e2372a8
  3. 30 9月, 2012 7 次提交
  4. 29 9月, 2012 2 次提交
  5. 28 9月, 2012 3 次提交
  6. 26 9月, 2012 1 次提交
  7. 25 9月, 2012 1 次提交
    • R
      fix handling of EINTR during close() · 82dc1e2e
      Rich Felker 提交于
      austin group interpretation for defect #529
      (http://austingroupbugs.net/view.php?id=529) tightens the
      requirements on close such that, if it returns with EINTR, the file
      descriptor must not be closed. the linux kernel developers vehemently
      disagree with this, and will not change it. we catch and remap EINTR
      to EINPROGRESS, which the standard allows close() to return when the
      operation was not finished but the file descriptor has been closed.
      82dc1e2e
  8. 23 9月, 2012 2 次提交
    • R
      fix getaddrinfo to accept port 0 (zero) · 4b49060d
      Rich Felker 提交于
      new behavior can be summarized as:
      inputs that parse completely as a decimal number are treated as one,
      and rejected only if the result is out of 16-bit range.
      inputs that do not parse as a decimal number (where strtoul leaves
      anything left over in the input) are searched in /etc/services.
      4b49060d
    • R
      fix remaining IPC_64 issue (shmctl) · 15d11120
      Rich Felker 提交于
      also cleanup cruft related to the issue
      15d11120
  9. 22 9月, 2012 2 次提交
  10. 21 9月, 2012 1 次提交
  11. 17 9月, 2012 1 次提交
  12. 16 9月, 2012 1 次提交
  13. 15 9月, 2012 4 次提交
    • R
      revert low rounds-count limits in crypt hashes · aeaceb1f
      Rich Felker 提交于
      it was determined in discussion that these kind of limits are not
      sufficient to protect single-threaded servers against denial of
      service attacks from maliciously large round counts. the time scales
      simply vary too much; many users will want login passwords with rounds
      counts on a scale that gives decisecond latency, while highly loaded
      webservers will need millisecond latency or shorter.
      
      still some limit is left in place; the idea is not to protect against
      attacks, but to avoid the runtime of a single call to crypt being, for
      all practical purposes, infinite, so that configuration errors can be
      caught and fixed without bringing down whole systems. these limits are
      very high, on the order of minute-long runtimes for modest systems.
      aeaceb1f
    • R
      update mips cancellation-point syscall asm with 7-arg and r25 fixes · 88186838
      Rich Felker 提交于
      these fixes were already made to the normal syscall asm but not the
      cancellation point version.
      88186838
    • R
      workaround gcc got-register-reload performance problems in malloc · afd209de
      Rich Felker 提交于
      with this patch, the malloc in libc.so built with -Os is nearly the
      same speed as the one built with -O3. thus it solves the performance
      regression that resulted from removing the forced -O3 when building
      libc.so; now libc.so can be both small and fast.
      afd209de
    • R
      use vfork if possible in posix_spawn · d62f4e98
      Rich Felker 提交于
      vfork is implemented as the fork syscall (with no atfork handlers run)
      on archs where it is not available, so this change does not introduce
      any change in behavior or regression for such archs.
      d62f4e98
  14. 11 9月, 2012 4 次提交
  15. 10 9月, 2012 1 次提交