1. 08 5月, 2018 1 次提交
    • R
      clean up and reduce size of internal pthread structure · 1db9a355
      Rich Felker 提交于
      over time the pthread structure has accumulated a lot of cruft taking
      up size. this commit removes unused fields and packs booleans and
      other small data more efficiently. changes which would also require
      changing code are not included at this time.
      
      non-volatile booleans are packed as unsigned char bitfield members.
      
      the canceldisable and cancelasync fields need volatile qualification
      due to how they're accessed from the cancellation signal handler and
      cancellable syscalls called from signal handlers. since volatile
      bitfield semantics are not clearly defined, discrete char objects are
      used instead.
      
      the pid field is completely removed; it has been unused since commit
      83dc6eb0.
      
      the tid field's type is changed to int because its use is as a value
      in futexes, which are defined as plain int. it has no conceptual
      relationship to pid_t. also, its position is not ABI.
      
      startlock is reduced to a length-1 array. the second element was
      presumably intended as a waiter count, but it was never used and made
      no sense, since there is at most one waiter.
      1db9a355
  2. 06 5月, 2018 1 次提交
    • R
      improve joinable/detached thread state handling · cdba6b25
      Rich Felker 提交于
      previously, some accesses to the detached state (from pthread_join and
      pthread_getattr_np) were unsynchronized; they were harmless in
      programs with well-defined behavior, but ugly. other accesses (in
      pthread_exit and pthread_detach) were synchronized by a poorly named
      "exitlock", with an ad-hoc trylock operation on it open-coded in
      pthread_detach, whose only purpose was establishing protocol for which
      thread is responsible for deallocation of detached-thread resources.
      
      instead, use an atomic detach_state and unify it with the futex used
      to wait for thread exit. this eliminates 2 members from the pthread
      structure, gets rid of the hackish lock usage, and makes rigorous the
      trap added in commit 80bf5952 for
      catching attempts to join detached threads. it should also make
      attempt to detach an already-detached thread reliably trap.
      cdba6b25
  3. 05 5月, 2018 2 次提交
    • R
      improve pthread_exit synchronization with functions targeting tid · 526e64f5
      Rich Felker 提交于
      if the last thread exited via pthread_exit, the logic that marked it
      dead did not account for the possibility of it targeting itself via
      atexit handlers. for example, an atexit handler calling
      pthread_kill(pthread_self(), SIGKILL) would return success
      (previously, ESRCH) rather than causing termination via the signal.
      
      move the release of killlock after the determination is made whether
      the exiting thread is the last thread. in the case where it's not,
      move the release all the way to the end of the function. this way we
      can clear the tid rather than spending storage on a dedicated
      dead-flag. clearing the tid is also preferable in that it hardens
      against inadvertent use of the value after the thread has terminated
      but before it is joined.
      526e64f5
    • R
      remove incorrect ESRCH error from pthread_kill · 4df42163
      Rich Felker 提交于
      posix documents in the rationale and future directions for
      pthread_kill that, since the lifetime of the thread id for a joinable
      thread lasts until it is joined, ESRCH is not a correct error for
      pthread_kill to produce when the target thread has exited but not yet
      been joined, and that conforming applications cannot attempt to detect
      this state. future versions of the standard may explicitly require
      that ESRCH not be returned for this case.
      4df42163
  4. 03 5月, 2018 1 次提交
    • R
      use a dedicated futex object for pthread_join instead of tid field · 9e2d820a
      Rich Felker 提交于
      the tid field in the pthread structure is not volatile, and really
      shouldn't be, so as not to limit the compiler's ability to reorder,
      merge, or split loads in code paths that may be relevant to
      performance (like controlling lock ownership).
      
      however, use of objects which are not volatile or atomic with futex
      wait is inherently broken, since the compiler is free to transform a
      single load into multiple loads, thereby using a different value for
      the controlling expression of the loop and the value passed to the
      futex syscall, leading the syscall to block instead of returning.
      
      reportedly glibc's pthread_join was actually affected by an equivalent
      issue in glibc on s390.
      
      add a separate, dedicated join_futex object for pthread_join to use.
      9e2d820a
  5. 02 5月, 2018 3 次提交
    • R
      optimize sigisemptyset · 941bd884
      Rich Felker 提交于
      the static const zero set ended up getting put in bss instead of
      rodata, wasting writable memory, and the call to memcmp was
      size-inefficient. generally for nonstandard extension functions we try
      to avoid poking at any internals directly, but the way the zero set
      was setup was arguably already doing so.
      941bd884
    • R
      avoid excessive stack usage in getcwd · 375840c7
      Rich Felker 提交于
      to support the GNU extension of allocating a buffer for getcwd's
      result when a null pointer is passed without incurring a link
      dependency on free, we use a PATH_MAX-sized buffer on the stack and
      only duplicate it to allocated storage after the operation succeeds.
      unfortunately this imposed excessive stack usage on all callers,
      including those not making use of the GNU extension.
      
      instead, use a VLA to make stack allocation conditional.
      375840c7
    • R
      work around arm gcc's rejection of r7 asm constraints in thumb mode · e3c682ab
      Rich Felker 提交于
      in thumb mode, r7 is the ABI frame pointer register, and unless frame
      pointer is disabled, gcc insists on treating it as a fixed register,
      refusing to spill it to satisfy constraints. unfortunately, r7 is also
      used in the syscall ABI for passing the syscall number.
      
      up til now we just treated this as a requirement to disable frame
      pointer when generating code as thumb, but it turns out gcc forcibly
      enables frame pointer, and the fixed register constraint that goes
      with it, for functions which contain VLAs. this produces an
      unacceptable arch-specific constraint that (non-arm-specific) source
      files making syscalls cannot use VLAs.
      
      as a workaround, avoid r7 register constraints when producing thumb
      code and instead save/restore r7 in a temp register as part of the asm
      block. at some point we may want/need to support armv6-m/thumb1, so
      the asm has been tweaked to be thumb1-compatible while also
      near-optimal for thumb2: it allows the temp and/or syscall number to
      be in high registers (necessary since r0-r5 may all be used for
      syscalll args) and in thumb2 mode allows the syscall number to be an
      8-bit immediate.
      e3c682ab
  6. 27 4月, 2018 1 次提交
    • R
      getopt_long_only: don't prefix-match long-options that match short ones · 9be4ed5d
      Rich Felker 提交于
      for getopt_long, partial (prefix) matches of long options always begin
      with "--" and thus can never be ambiguous with a short option. for
      getopt_long_only, though, a single-character option can match both a
      short option and as a prefix for a long option. in this case, we
      wrongly interpreted it as a prefix for the long option.
      
      introduce a new pass, only in long-only mode, to check the prefix
      match against short options before accepting it. the only reason
      there's a slightly nontrivial loop being introduced rather than strchr
      is that our getopt already supports multibyte short options, and
      getopt_long_long should handle them consistently. a temp buffer and
      strstr could have been used, but the code to set it up would be just
      as large as what's introduced here and it would unnecessarily pull in
      relatively large code for strstr.
      9be4ed5d
  7. 20 4月, 2018 10 次提交
    • R
      reintroduce hardening against partially-replaced allocator · b4b1e103
      Rich Felker 提交于
      commit 618b18c7 removed the previous
      detection and hardening since it was incorrect. commit
      72141795 already handled all that
      remained for hardening the static-linked case. in the dynamic-linked
      case, have the dynamic linker check whether malloc was replaced and
      make that information available.
      
      with these changes, the properties documented in commit
      c9f415d7 are restored: if calloc is
      not provided, it will behave as malloc+memset, and any of the
      memalign-family functions not provided will fail with ENOMEM.
      b4b1e103
    • R
      return chunks split off by memalign using __bin_chunk instead of free · 72141795
      Rich Felker 提交于
      this change serves multiple purposes:
      
      1. it ensures that static linking of memalign-family functions will
      pull in the system malloc implementation, thereby causing link errors
      if an attempt is made to link the system memalign functions with a
      replacement malloc (incomplete allocator replacement).
      
      2. it eliminates calls to free that are unpaired with allocations,
      which are confusing when setting breakpoints or tracing execution.
      
      as a bonus, making __bin_chunk external may discourage aggressive and
      unnecessary inlining of it.
      72141795
    • R
      using malloc implementation types/macros/idioms for memalign · 3c2cbbe7
      Rich Felker 提交于
      the generated code should be mostly unchanged, except for explicit use
      of C_INUSE in place of copying the low bits from existing chunk
      headers/footers.
      
      these changes also remove mild UB due to dubious arithmetic on
      pointers into imaginary size_t[] arrays.
      3c2cbbe7
    • R
    • R
      revert detection of partially-replaced allocator · 618b18c7
      Rich Felker 提交于
      commit c9f415d7 included checks to
      make calloc fallback to memset if used with a replaced malloc that
      didn't also replace calloc, and the memalign family fail if free has
      been replaced. however, the checks gave false positives for
      replacement whenever malloc or free resolved to a PLT entry in the
      main program.
      
      for now, disable the checks so as not to leave libc in a broken state.
      this means that the properties documented in the above commit are no
      longer satisfied; failure to replace calloc and the memalign family
      along with malloc is unsafe if they are ever called.
      
      the calloc checks were correct but useless for static linking. in both
      cases (simple or full malloc), calloc and malloc are in a source file
      together, so replacement of one but not the other would give linking
      errors. the memalign-family check was useful for static linking, but
      broken for dynamic as described above, and can be replaced with a
      better link-time check.
      618b18c7
    • W
      setvbuf: minor comment typo fix · 3f3cc3e9
      Will Dietz 提交于
      3f3cc3e9
    • A
      arm: use a_ll/a_sc atomics when building for ARMv6T2 · 8c2943f0
      Andre McCurdy 提交于
      ARMv6 cores with support for Thumb2 can take advantage of the "ldrex"
      and "strex" based implementations of a_ll and a_sc.
      8c2943f0
    • A
      arm: respect both __ARM_ARCH_6KZ__ and __ARM_ARCH_6ZK__ macros · 749a06b4
      Andre McCurdy 提交于
      __ARM_ARCH_6ZK__ is a gcc specific historical typo which may not be
      defined by other compilers.
      
        https://gcc.gnu.org/ml/gcc-patches/2015-07/msg02237.html
      
      To avoid unexpected results when building for ARMv6KZ with clang, the
      correct form of the macro (ie 6KZ) needs to be tested. The incorrect
      form of the macro (ie 6ZK) still needs to be tested for compatibility
      with pre-2015 versions of gcc.
      749a06b4
    • A
      provide optimized a_ctz_32 for arm · ea489b8b
      Andre McCurdy 提交于
      Provide an ARM specific a_ctz_32 helper function for architecture
      versions for which it can be implemented efficiently via the "rbit"
      instruction (ie all Thumb-2 capable versions of ARM v6 and above).
      ea489b8b
    • A
      remove a_ctz_l from arch specific atomic_arch.h · 0c6abb58
      Andre McCurdy 提交于
      Update atomic.h to provide a_ctz_l in all cases (atomic_arch.h should
      now only provide a_ctz_32 and/or a_ctz_64).
      
      The generic version of a_ctz_32 now takes advantage of a_clz_32 if
      available and the generic a_ctz_64 now makes use of a_ctz_32.
      0c6abb58
  8. 19 4月, 2018 8 次提交
  9. 18 4月, 2018 7 次提交
    • R
      remove unused __brk function/source file · 50202754
      Rich Felker 提交于
      commit e3bc22f1 removed all references
      to __brk.
      50202754
    • R
      enable reclaim_gaps for fdpic · d610c148
      Rich Felker 提交于
      the existing laddr function for fdpic cannot translate ELF virtual
      addresses outside of the LOAD segments to runtime addresses because
      the fdpic loadmap only covers the logically-mapped part. however the
      whole point of reclaim_gaps is to recover the slack space up to the
      page boundaries, so it needs to work with such addresses.
      
      add a new laddr_pg function that accepts any address in the page range
      for the LOAD segment by expanding the loadmap records out to page
      boundaries. only use the new version for reclaim_gaps, so as not to
      impact performance of other address lookups.
      
      also, only use laddr_pg for the start address of a gap; the end
      address lies one byte beyond the end, potentially in a different page
      where it would get mapped differently. instead of mapping end, apply
      the length (end-start) to the mapped value of start.
      d610c148
    • R
      comment __malloc_donate overflow logic · 14032c30
      Rich Felker 提交于
      14032c30
    • A
      ldso, malloc: implement reclaim_gaps via __malloc_donate · ce7ae11a
      Alexander Monakov 提交于
      Split 'free' into unmap_chunk and bin_chunk, use the latter to introduce
      __malloc_donate and use it in reclaim_gaps instead of calling 'free'.
      ce7ae11a
    • A
      malloc: fix an over-allocation bug · d889cc34
      Alexander Monakov 提交于
      Fix an instance where realloc code would overallocate by OVERHEAD bytes
      amount. Manually arrange for reuse of memcpy-free-return exit sequence.
      d889cc34
    • R
      use explicit dynamic-list rather than symbolic-functions for linking · b9410061
      Rich Felker 提交于
      we have always bound symbols at libc.so link time rather than runtime
      to minimize startup-time relocations and overhead of calls through the
      PLT, and possibly also to preclude interposition that would not work
      correctly anyway if allowed. historically, binding at link-time was
      also necessary for the dynamic linker to work, but the dynamic linker
      bootstrap overhaul in commit f3ddd173
      made it unnecessary.
      
      our use of -Bsymbolic-functions, rather than -Bsymbolic, was chosen
      because the latter is incompatible with public global data; it makes
      it incompatible with copy relocations in the main program. however,
      not all global data needs to be public. by using --dynamic-list
      instead with an explicit list, we can reduce the number of symbolic
      relocations left for runtime.
      
      this change will also allow us to permit interposition of specific
      functions (e.g. the allocator) if/when we want to, by adding them to
      the dynamic list.
      b9410061
    • R
      fix return value of nice function · 4bf0717e
      Rich Felker 提交于
      the Linux SYS_nice syscall is unusable because it does not return the
      newly set priority. always use SYS_setpriority. also avoid overflows
      in addition of inc by handling large inc values directly without
      examining the old nice value.
      4bf0717e
  10. 12 4月, 2018 2 次提交
    • A
      optimize malloc0 · 424eab22
      Alexander Monakov 提交于
      Implementation of __malloc0 in malloc.c takes care to preserve zero
      pages by overwriting only non-zero data. However, malloc must have
      already modified auxiliary heap data just before and beyond the
      allocated region, so we know that edge pages need not be preserved.
      
      For allocations smaller than one page, pass them immediately to memset.
      Otherwise, use memset to handle partial pages at the head and tail of
      the allocation, and scan complete pages in the interior. Optimize the
      scanning loop by processing 16 bytes per iteration and handling rest of
      page via memset as soon as a non-zero byte is found.
      424eab22
    • R
      fix incorrect results for catan with some inputs · 10e4bd37
      Rich Felker 提交于
      the catan implementation from OpenBSD includes a FIXME-annotated
      "overflow" branch that produces a meaningless and incorrect
      large-magnitude result. it was reachable via three paths,
      corresponding to gotos removed by this commit, in order:
      
      1. pure imaginary argument with imaginary component greater than 1 in
         magnitude. this case does not seem at all exceptional and is
         handled (at least with the quality currently expected from our
         complex math functions) by the existing non-exceptional code path.
      
      2. arguments on the unit circle, including the pure-real argument 1.0.
         these are not exceptional except for ±i, which should produce
         results with infinite imaginary component and which lead to
         computation of atan2(±0,0) in the existing non-exceptional code
         path. such calls to atan2() however are well-defined by POSIX.
      
      3. the specific argument +i. this route should be unreachable due to
         the above (2), but subtle rounding effects might have made it
         possible in rare cases. continuing on the non-exceptional code path
         in this case would lead to computing the (real) log of an infinite
         argument, then producing a NAN when multiplying it by I.
      
      for now, remove the exceptional code paths entirely. replace the
      multiplication by I with construction of a complex number using the
      CMPLX macro so that the NAN issue (3) prevented cannot arise.
      
      with these changes, catan should give reasonably correct results for
      real arguments, and should no longer give completely-wrong results for
      pure-imaginary arguments outside the interval (-i,+i).
      10e4bd37
  11. 10 4月, 2018 1 次提交
    • R
      fix wrong result in casin and many related complex functions · ae2a01da
      Rich Felker 提交于
      the factor of -i noted in the comment at the top of casin.c was
      omitted from the actual code, yielding a result rotated 90 degrees and
      propagating into errors in other functions defined in terms of casin.
      
      implement multiplication by -i as a rotation of the real and imaginary
      parts of the result, rather than by actual multiplication, since the
      latter cannot be optimized without knowledge that the operand is
      finite. here, the rotation is the actual intent, anyway.
      ae2a01da
  12. 08 4月, 2018 1 次提交
    • S
      implement wcsftime padding specifier extensions · ea81529f
      Samuel Holland 提交于
      Commit 8a6bd730 added support for
      padding specifier extensions to strftime, but did not modify wcsftime.
      In the process, it added a parameter to __strftime_fmt_1 in strftime.c,
      but failed to update the prototype in wcsftime.c. This was found by
      compiling musl with LTO:
      
          src/time/wcsftime.c:7:13: warning: type of '__strftime_fmt_1' does \
              not match original declaration [-Wlto-type-mismatch]
      
      Fix the prototype of __strftime_fmt_1 in wcsftime.c, and generate the
      'pad' argument the same way as it is done in strftime.
      ea81529f
  13. 05 4月, 2018 1 次提交
    • R
      prevent bypass of guarantee that suids start with fd 0/1/2 open · 119bc55b
      Rich Felker 提交于
      it was reported by Erik Bosman that poll fails without setting revents
      when the nfds argument exceeds the current value for RLIMIT_NOFILE,
      causing the subsequent open calls to be bypassed. if the rlimit is
      either 1 or 2, this leaves fd 0 and 1 potentially closed but openable
      when the application code is reached.
      
      based on a brief reading of the poll syscall documentation and code,
      it may be possible for poll to fail under other attacker-controlled
      conditions as well. if it turns out these are reasonable conditions
      that may happen in the real world, we may have to go back and
      implement fallbacks to probe each fd individually if poll fails, but
      for now, keep things simple and treat all poll failures as fatal.
      119bc55b
  14. 03 4月, 2018 1 次提交
    • S
      fix fmaf wrong result · 282b1cd2
      Szabolcs Nagy 提交于
      if double precision r=x*y+z is not a half way case between two single
      precision floats or it is an exact result then fmaf returns (float)r.
      
      however the exactness check was wrong when |x*y| < |z| and could cause
      incorrectly rounded result in nearest rounding mode when r is a half
      way case.
      
      fmaf(-0x1.26524ep-54, -0x1.cb7868p+11, 0x1.d10f5ep-29)
      was incorrectly rounded up to 0x1.d117ap-29 instead of 0x1.d1179ep-29.
      (exact result is 0x1.d1179efffffffecp-29, r is 0x1.d1179fp-29)
      282b1cd2
新手
引导
客服 返回
顶部