1. 04 7月, 2017 2 次提交
    • R
      fix regression in dlopen promotion from RTLD_LOCAL to RTLD_GLOBAL · 43c423af
      Rich Felker 提交于
      commit 4ff234f6 inadvertently removed
      the logic to do this when changing the representation of global
      status.
      43c423af
    • R
      ldso: avoid spurious & possible erroneous work for libs with no deps · 66b53cfa
      Rich Felker 提交于
      a null pointer for a library's deps list was ambiguous: it could
      indicate either no dependencies or that the dependency list had not
      yet been populated. inability to distinguish could lead to spurious
      work when dlopen is called multiple times on a library with no deps,
      and due to related bugs, could actually cause other libraries to
      falsely appear as dependencies, translating into false positives for
      dlsym.
      
      avoid the problem by always initializing the deps pointer, pointing to
      an empty list if there are no deps. rather than wasting memory and
      introducing another failure path by allocating an empty list per
      library, simply share a global dummy list.
      
      further fixes will be needed for related bugs, and much of this code
      may end up being replaced.
      66b53cfa
  2. 24 6月, 2017 3 次提交
  3. 23 6月, 2017 1 次提交
    • S
      fix arm run-time abi string functions · e6def544
      Szabolcs Nagy 提交于
      in arm rtabi these __aeabi_* functions have special abi (they are
      only allowed to clobber r0,r1,r2,r3,ip,lr,cpsr), so they cannot
      be simple wrappers around normal string functions (which may
      clobber other registers), the safest solution is to write them in
      asm, a minimalistic implementation works because these are not
      supposed to be emitted by compilers or used in general.
      e6def544
  4. 22 6月, 2017 2 次提交
  5. 21 6月, 2017 2 次提交
  6. 16 6月, 2017 3 次提交
    • R
      set errno when getpw*_r, getgr*_r, and getspnam_r fail · 2d7d05f0
      Rich Felker 提交于
      these functions return an error code, and are not explicitly
      documented to set errno, but they are nonstandard and the historical
      implementations do set errno as well, and some applications expect
      this behavior. do likewise for compatibility.
      
      patch by Rudolph Pereira.
      2d7d05f0
    • R
      handle localtime errors in ctime · 5c10c33d
      Rich Felker 提交于
      ctime passes the result from localtime directly to asctime. But in case
      of error, localtime returns 0. This causes an error (NULL pointer
      dereference) in asctime.
      
      based on patch by Omer Anson.
      5c10c33d
    • R
      handle mremap failure in realloc of mmap-serviced allocations · 1c86c7f5
      Rich Felker 提交于
      mremap seems to always fail on nommu, and on some non-Linux
      implementations of the Linux syscall API, it at least fails to
      increase allocation size, and may fail to move (i.e. defragment) the
      existing mapping when shrinking it too. instead of failing realloc or
      leaving an over-sized allocation that may waste a large amount of
      memory, fallback to malloc-memcpy-free if mremap fails.
      1c86c7f5
  7. 15 6月, 2017 2 次提交
    • A
      getdate: correctly specify error number · 10800088
      A. Wilcox 提交于
      POSIX defines getdate error #5 as:
      "An I/O error is encountered while reading the template file."
      
      POSIX defines getdate error #7 as:
      "There is no line in the template that matches the input."
      
      This change correctly disambiguates between the two error conditions.
      10800088
    • A
      catopen: set errno to EOPNOTSUPP · af051730
      A. Wilcox 提交于
      Per 1003.1-2008 (2016 ed.), catopen must set errno on failure.
      
      We set errno to EOPNOTSUPP because musl does not currently support
      message catalogues.
      af051730
  8. 09 6月, 2017 2 次提交
    • R
      fix glob failure to match plain "/" to root directory · 84eff797
      Rich Felker 提交于
      the check to prevent matching empty string wrongly blocked matching
      of "/" due to checking emptiness after stripping leading slashes
      rather than checking the full original argument string.
      
      simplified from patch by Julien Ramseier.
      84eff797
    • R
      use hard-coded sh4a atomic opcodes to avoid linker errors on sh · bc313e88
      Rich Felker 提交于
      when using the sh4a opcodes, the assembler tags the resulting object
      file as requiring sh4a. the linker then refuses to (static) link it
      with object files marked as requiring j2, since there is no isa level
      that includes both sh4a and j2 instructions.
      bc313e88
  9. 01 6月, 2017 3 次提交
    • N
      towupper/towlower: fast path for ascii chars · 179766aa
      Natanael Copa 提交于
      Make a fast path for ascii chars which is assumed to be the most common
      case. This has significant performance benefit on xml json and similar
      179766aa
    • R
      remove long-obsolete clang workarounds from mips* syscall_arch.h files · 1c497005
      Rich Felker 提交于
      at one point, clang reportedly failed to support the asm register
      constraints needed for inline syscalls. versions of clang that old
      have much bigger problems that preclude using them to compile musl
      libc.
      1c497005
    • R
      fix fstatat syscall on mips64 · 4073f03a
      Rich Felker 提交于
      mips64 requires 'struct stat' conversion due to incorrect 32-bit
      fields where time_t should be in the kernel version of the structure.
      syscall_arch.h already performed the correct translation for stat,
      fstat, and lstat syscalls, but omitted special handling for fstatat.
      4073f03a
  10. 28 5月, 2017 2 次提交
    • S
      fix fchown fallback on arches without chown(2) · 81f4a120
      Samuel Holland 提交于
      The flags argument was missing, causing uninitalized data to be passed
      to fchownat(2). The correct value of flags should match the fallback for
      chown(3).
      81f4a120
    • R
      fix iconv conversions to legacy 8bit encodings · 97bd6b09
      Rich Felker 提交于
      there was missing reverse-conversion logic for the case, handled
      specially in the character set tables, where a byte represents a
      unicode codepoint with the same value.
      
      this patch adds code to handle the case, and refactors the two-level
      10-bit table lookup for legacy character sets into a function to avoid
      repeating it yet another time as part of the fix.
      97bd6b09
  11. 23 4月, 2017 5 次提交
    • R
      have posix_spawnattr_setflags check for supported flags · f9f686b7
      Rich Felker 提交于
      per POSIX, EINVAL is not a mandatory error, only an optional one. but
      reporting unsupported flags allows an application to fallback
      gracefully when a requested feature is not supported. this is not
      helpful now, but it may be in the future if additional flags are
      added.
      
      had this checking been present before, applications would have been
      able to check for the newly-added POSIX_SPAWN_SETSID feature (added in
      commit bb439bb1) at runtime.
      f9f686b7
    • R
      add no-op POSIX_SPAWN_USEVFORK to spawn.h · 77e895dc
      Rich Felker 提交于
      the bit is reserved anyway for ABI-compat reasons; this documents it
      and makes it so we can have posix_spawnattr_setflags check for flag
      validity without hard-coding an anonymous bit value.
      77e895dc
    • B
      s390x: provide sigcontext struct definition · 55550416
      Bobby Bingham 提交于
      This structure was missed when creating the s390x port.
      
      This is based on the report and patch from William Pitcock, but with a
      modified structure defintion to more closely match the kernel's
      definition.
      55550416
    • R
      implement new posix_spawn flag POSIX_SPAWN_SETSID · bb439bb1
      Rich Felker 提交于
      this functionality has been adopted for inclusion in the next issue of
      POSIX as the result of Austin Group issue #1044.
      
      based on patch by Daurnimator.
      bb439bb1
    • R
      remove va_arg hacks in printf core with undefined behavior · 58e2396a
      Rich Felker 提交于
      the code being removed was written to optimize for size assuming the
      compiler cannot collapse code paths for different types with the same
      underlying representation. modern compilers sometimes succeed in
      making this optimization themselves, but either way it's a small size
      difference and not worth the source-level complexity or the UB
      involved in this hack.
      
      some incorrect use of va_arg still remains, particularly use of void *
      where the actual argument has a different pointer type. fixing this
      requires some actual code additions, rather than just removing cruft,
      so I'm leaving it to be done later as a separate commit.
      58e2396a
  12. 22 4月, 2017 4 次提交
    • R
      make ttyname[_r] return ENODEV rather than ENOENT · e1232f5b
      Rich Felker 提交于
      commit 0a950dcf added checking that
      the pathname a tty device was opened with actually matches the device,
      which can fail to hold when a container inherits a tty from outside
      the container. the error code added at the time was ENOENT; however,
      discussions between affected applications and glibc developers
      resulted in glibc adopting ENODEV as the error for this condition, and
      this has now been documented in the man pages project as well. adopt
      the same error code for consistency.
      
      patch by Christian Brauner.
      e1232f5b
    • R
      fix regression in support for resolv.conf attempts option · 1a7fa5e5
      Rich Felker 提交于
      commit d6cb08bc moved the code and
      introduced an incorrect string offset for the new parsing, probably
      due to a copy-and-paste error.
      
      patch by Stefan Sedich.
      1a7fa5e5
    • S
      fix scalbn when result is in the subnormal range · 8c44a060
      Szabolcs Nagy 提交于
      in nearest rounding mode scalbn could introduce double rounding error
      when an intermediate value and the final result were both in the
      subnormal range e.g.
      
        scalbn(0x1.7ffffffffffffp-1, -1073)
      
      returned 0x1p-1073 instead of 0x1p-1074, because the intermediate
      computation got rounded to 0x1.8p-1023.
      
      with the fix an intermediate value can only be in the subnormal range
      if the final result is 0 which is correct even after double rounding.
      (there still can be two roundings so signals may be raised twice, but
      that's only observable with trapping exceptions which is not supported.)
      8c44a060
    • R
      allow full-range file offsets to mmap on archs with 64-bit syscall args · 2577b1bc
      Rich Felker 提交于
      normally 32-bit archs use the mmap2 syscall and are limited to an
      offset of 2^32 pages. however some 32-bit archs (mainly ILP32-on-64
      ones like x32) have 64-bit syscall argument slots and thus can accept
      the full range. don't artifically limit them.
      2577b1bc
  13. 12 4月, 2017 2 次提交
    • R
      fix dl_iterate_phdr in static PIE binaries · b3751c32
      Rich Felker 提交于
      analogous to commit 5bf7eba2, use of
      AT_PHDR/PT_PHDR does not actually work to find the program base, and
      the method with _DYNAMIC vs PT_DYNAMIC must be used as an alternative.
      
      patch by Shiz, along with testing to confirm that this fixes unwinding
      in static PIE.
      b3751c32
    • R
      fix read past end of buffer in getaddrinfo backend · 1ca59755
      Rich Felker 提交于
      due to testing buf[i].family==AF_INET before checking i==cnt, it was
      possible to read past the end of the array, or past the valid part. in
      practice, without active bounds/indeterminate-value checking by the
      compiler, the worst that happened was failure to return early and
      optimize out the sorting that's unneeded for v4-only results.
      
      returning on i==cnt-1 rather than i==cnt would be an alternate fix,
      but the approach this patch takes is more idiomatic and less
      error-prone.
      
      patch by Timo Teräs.
      1ca59755
  14. 22 3月, 2017 6 次提交
    • S
      aarch64: add single instruction math functions · 54807d47
      Szabolcs Nagy 提交于
      this should increase performance and reduce code size on aarch64.
      
      the compiled code was checked against using __builtin_* instead
      of inline asm with gcc-6.2.0.
      
      lrint is two instructions.
      
      c with inline asm is used because it is safer than a pure asm
      implementation, this prevents ll{rint,round} to be an alias
      of l{rint,round} (because the types don't match) and depends
      on gcc style inline asm support.
      
      ceil, floor, round, trunc can either raise inexact on finite
      non-integer inputs or not raise any exceptions. the new
      implementation does not raise exceptions while the generic
      c code does.
      
      on aarch64, the underflow exception is signaled before rounding
      (ieee 754 allows both before and after rounding, but it must be
      consistent), the generic fma c code signals it after rounding
      so using single instruction fixes a slight conformance issue too.
      54807d47
    • J
      fix strptime output for %C without %y · b6e1fe0d
      Julien Ramseier 提交于
      in this case, a potentially-uninitialized or unrelated existing value
      in tm_year was being used. instead use 0 if %y was not present.
      b6e1fe0d
    • J
      fix processing of strptime %p format · 834ef7af
      Julien Ramseier 提交于
      string pointer was not advanced after matching.
      834ef7af
    • J
      fix off-by-one in strptime %j · 85dfab7e
      Julien Ramseier 提交于
      tm_yday range is 0-365 while %j is 1-366
      85dfab7e
    • J
      regex: fix newline matching with negated brackets · 9571c531
      Julien Ramseier 提交于
      With REG_NEWLINE, POSIX says:
      "A <newline> in string shall not be matched by a period outside
      a bracket expression or by any form of a non-matching list"
      9571c531
    • R
      increase limit on locale name length from 15 to 23 bytes · e6917ece
      Rich Felker 提交于
      the old limit was one byte too short to support locale names of the
      form xx_XX.UTF-8@modifier where modifier is more than 3 bytes, a form
      which various real-world locale names take. the problem could be
      avoided by omitting the useless ".UTF-8" part, but users may need to
      have it present when operating on mixed-libc systems or when it will
      be carried over (e.g. across ssh) to other systems.
      
      the new limit is chosen sufficient for existing/reasonable locale
      names while still keeping the size of setlocale's static buffer small.
      
      also add locale_impl.h to the Makefile's list of headers which force
      rebuild of source files, to prevent dangerously inconsistent object
      files from getting used after this change.
      e6917ece
  15. 21 3月, 2017 1 次提交
    • R
      search locale name variants for gettext translations · e4fc9ad7
      Rich Felker 提交于
      often translations will be named only by language, whereas locale
      names may also include a territory code, modifier, and codeset
      portion. previously, only translations exactly matching the locale
      name were loaded. this was a major usability issue, requiring
      workarounds like symlinks or tweaking of the locale name.
      
      with these changes, gettext now searches for translations by first
      removing the codeset portion of the locale name, then trying the
      remainder in full, with modifier (@mod) removed, with territory code
      (_XX) removed, and with both removed.
      
      part of the reason gettext lacked support for searching fallbacks
      before is that the candidate pathname for a translation file was
      constructed on each call and used as the key to lookup an
      already-mapped translation file. this was very costly/inefficient. we
      now use the tuple of textdomain binding pointer, locale map pointer,
      and integer category id as the key for looking up a translation file
      mapping.
      
      based on patch by He X.
      e4fc9ad7