1. 29 9月, 2012 1 次提交
  2. 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
  3. 10 9月, 2012 2 次提交
  4. 09 9月, 2012 1 次提交
  5. 07 9月, 2012 3 次提交
    • R
      further use of _Noreturn, for non-plain-C functions · 0c05bd3a
      Rich Felker 提交于
      note that POSIX does not specify these functions as _Noreturn, because
      POSIX is aligned with C99, not the new C11 standard. when POSIX is
      eventually updated to C11, it will almost surely give these functions
      the _Noreturn attribute. for now, the actual _Noreturn keyword is not
      used anyway when compiling with a c99 compiler, which is what POSIX
      requires; the GCC __attribute__ is used instead if it's available,
      however.
      
      in a few places, I've added infinite for loops at the end of _Noreturn
      functions to silence compiler warnings. presumably
      __buildin_unreachable could achieve the same thing, but it would only
      work on newer GCCs and would not be portable. the loops should have
      near-zero code size cost anyway.
      
      like the previous _Noreturn commit, this one is based on patches
      contributed by philomath.
      0c05bd3a
    • R
      use restrict everywhere it's required by c99 and/or posix 2008 · 400c5e5c
      Rich Felker 提交于
      to deal with the fact that the public headers may be used with pre-c99
      compilers, __restrict is used in place of restrict, and defined
      appropriately for any supported compiler. we also avoid the form
      [restrict] since older versions of gcc rejected it due to a bug in the
      original c99 standard, and instead use the form *restrict.
      400c5e5c
    • R
      fcfba995
  6. 11 7月, 2012 1 次提交
    • R
      initial version of mips (o32) port, based on work by Richard Pennington (rdp) · 6315004f
      Rich Felker 提交于
      basically, this version of the code was obtained by starting with
      rdp's work from his ellcc source tree, adapting it to musl's build
      system and coding style, auditing the bits headers for discrepencies
      with kernel definitions or glibc/LSB ABI or large file issues, fixing
      up incompatibility with the old binutils from aboriginal linux, and
      adding some new special cases to deal with the oddities of sigaction
      and pipe syscall interfaces on mips.
      
      at present, minimal test programs work, but some interfaces are broken
      or missing. threaded programs probably will not link.
      6315004f
  7. 20 6月, 2012 3 次提交
  8. 25 5月, 2012 1 次提交
  9. 02 3月, 2012 1 次提交
  10. 26 9月, 2011 1 次提交
    • R
      cleanup various minor issues reported by nsz · fd142e5e
      Rich Felker 提交于
      the changes to syscall_ret are mostly no-ops in the generated code,
      just cleanup of type issues and removal of some implementation-defined
      behavior. the one exception is the change in the comparison value,
      which is fixed so that 0xf...f000 (which in principle could be a valid
      return value for mmap, although probably never in reality) is not
      treated as an error return.
      fd142e5e
  11. 22 9月, 2011 1 次提交
  12. 14 9月, 2011 1 次提交
  13. 30 7月, 2011 3 次提交
    • R
      fix some bugs in setxid and update setrlimit to use __synccall · 544ee752
      Rich Felker 提交于
      setrlimit is supposed to be per-process, not per-thread, but again
      linux gets it wrong. work around this in userspace. not only is it
      needed for correctness; setxid also depends on the resource limits for
      all threads being the same to avoid situations where temporarily
      unlimiting the limit succeeds in some threads but fails in others.
      544ee752
    • R
      afade235
    • R
      new attempt at making set*id() safe and robust · acb04806
      Rich Felker 提交于
      changing credentials in a multi-threaded program is extremely
      difficult on linux because it requires synchronizing the change
      between all threads, which have their own thread-local credentials on
      the kernel side. this is further complicated by the fact that changing
      the real uid can fail due to exceeding RLIMIT_NPROC, making it
      possible that the syscall will succeed in some threads but fail in
      others.
      
      the old __rsyscall approach being replaced was robust in that it would
      report failure if any one thread failed, but in this case, the program
      would be left in an inconsistent state where individual threads might
      have different uid. (this was not as bad as glibc, which would
      sometimes even fail to report the failure entirely!)
      
      the new approach being committed refuses to change real user id when
      it cannot temporarily set the rlimit to infinity. this is completely
      POSIX conformant since POSIX does not require an implementation to
      allow real-user-id changes for non-privileged processes whatsoever.
      still, setting the real uid can fail due to memory allocation in the
      kernel, but this can only happen if there is not already a cached
      object for the target user. thus, we forcibly serialize the syscalls
      attempts, and fail the entire operation on the first failure. this
      *should* lead to an all-or-nothing success/failure result, but it's
      still fragile and highly dependent on kernel developers not breaking
      things worse than they're already broken.
      
      ideally linux will eventually add a CLONE_USERCRED flag that would
      give POSIX conformant credential changes without any hacks from
      userspace, and all of this code would become redundant and could be
      removed ~10 years down the line when everyone has abandoned the old
      broken kernels. i'm not holding my breath...
      acb04806
  14. 22 4月, 2011 1 次提交
  15. 21 4月, 2011 1 次提交
    • R
      workaround bug in linux dup2 · f9a6372a
      Rich Felker 提交于
      the linux documentation for dup2 says it can fail with EBUSY due to a
      race condition with open and dup in the kernel. shield applications
      (and the rest of libc) from this nonsense by looping until it succeeds
      f9a6372a
  16. 19 4月, 2011 1 次提交
    • R
      remove bogus extra logic for close cancellability · 61b56a8d
      Rich Felker 提交于
      like all other syscalls, close should return to the caller if and only
      if it successfully performed its action. it is necessary that the
      application be able to determine whether the close succeeded.
      61b56a8d
  17. 18 4月, 2011 1 次提交
  18. 17 4月, 2011 1 次提交
    • R
      overhaul pthread cancellation · feee9890
      Rich Felker 提交于
      this patch improves the correctness, simplicity, and size of
      cancellation-related code. modulo any small errors, it should now be
      completely conformant, safe, and resource-leak free.
      
      the notion of entering and exiting cancellation-point context has been
      completely eliminated and replaced with alternative syscall assembly
      code for cancellable syscalls. the assembly is responsible for setting
      up execution context information (stack pointer and address of the
      syscall instruction) which the cancellation signal handler can use to
      determine whether the interrupted code was in a cancellable state.
      
      these changes eliminate race conditions in the previous generation of
      cancellation handling code (whereby a cancellation request received
      just prior to the syscall would not be processed, leaving the syscall
      to block, potentially indefinitely), and remedy an issue where
      non-cancellable syscalls made from signal handlers became cancellable
      if the signal handler interrupted a cancellation point.
      
      x86_64 asm is untested and may need a second try to get it right.
      feee9890
  19. 07 4月, 2011 2 次提交
    • R
    • R
      move rsyscall out of pthread_create module · b2486a89
      Rich Felker 提交于
      this is something of a tradeoff, as now set*id() functions, rather
      than pthread_create, are what pull in the code overhead for dealing
      with linux's refusal to implement proper POSIX thread-vs-process
      semantics. my motivations are:
      
      1. it's cleaner this way, especially cleaner to optimize out the
      rsyscall locking overhead from pthread_create when it's not needed.
      2. it's expected that only a tiny number of core system programs will
      ever use set*id() functions, whereas many programs may want to use
      threads, and making thread overhead tiny is an incentive for "light"
      programs to try threads.
      b2486a89
  20. 04 4月, 2011 2 次提交
  21. 02 4月, 2011 1 次提交
  22. 20 3月, 2011 2 次提交
    • R
      global cleanup to use the new syscall interface · aa398f56
      Rich Felker 提交于
      aa398f56
    • R
      syscall overhaul part two - unify public and internal syscall interface · 685e40bb
      Rich Felker 提交于
      with this patch, the syscallN() functions are no longer needed; a
      variadic syscall() macro allows syscalls with anywhere from 0 to 6
      arguments to be made with a single macro name. also, manually casting
      each non-integer argument with (long) is no longer necessary; the
      casts are hidden in the macros.
      
      some source files which depended on being able to define the old macro
      SYSCALL_RETURNS_ERRNO have been modified to directly use __syscall()
      instead of syscall(). references to SYSCALL_SIGSET_SIZE and SYSCALL_LL
      have also been changed.
      
      x86_64 has not been tested, and may need a follow-up commit to fix any
      minor bugs/oversights.
      685e40bb
  23. 15 2月, 2011 2 次提交
  24. 14 2月, 2011 1 次提交
    • R
      cleaning up syscalls in preparation for x86_64 port · 2cdfb7ca
      Rich Felker 提交于
      - hide all the legacy xxxxxx32 name cruft in syscall.h so the actual
      source files can be clean and uniform across all archs.
      
      - cleanup llseek/lseek and mmap2/mmap handling for 32/64 bit systems
      
      - alternate implementation for nice if the target lacks nice syscall
      2cdfb7ca
  25. 12 2月, 2011 1 次提交