1. 05 10月, 2012 4 次提交
    • 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. 03 10月, 2012 1 次提交
    • R
      tell the assembler to mark all files as not requiring executable stack · adefe830
      Rich Felker 提交于
      for some reason this option is undocumented. not sure when it was
      added, so I'm using a configure test. gcc was already setting the mark
      correctly for C files, but assembler source files would need ugly
      .note boilerplate in every single file to achieve this without the
      option to the assembler.
      
      blame whoever thought it would be a good idea to make the stack
      executable by default rather than doing it the other way around...
      adefe830
  3. 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
  4. 30 9月, 2012 10 次提交
  5. 29 9月, 2012 2 次提交
  6. 28 9月, 2012 3 次提交
  7. 26 9月, 2012 1 次提交
  8. 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
  9. 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
  10. 22 9月, 2012 3 次提交
  11. 21 9月, 2012 1 次提交
  12. 17 9月, 2012 1 次提交
  13. 16 9月, 2012 4 次提交
  14. 15 9月, 2012 3 次提交
    • R
      0.9.5 release notes · 7ad42b94
      Rich Felker 提交于
      7ad42b94
    • R
      fix syscall asm constraints for arm too · 075fdb90
      Rich Felker 提交于
      no problems were detected so far, but the constraints seem to have
      been invalid just like the mips ones.
      075fdb90
    • 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