1. 24 1月, 2013 1 次提交
  2. 19 1月, 2013 1 次提交
    • R
      use a common definition of NULL as 0L for C and C++ · 41d7c77d
      Rich Felker 提交于
      the historical mess of having different definitions for C and C++
      comes from the historical C definition as (void *)0 and the fact that
      (void *)0 can't be used in C++ because it does not convert to other
      pointer types implicitly. however, using plain 0 in C++ exposed bugs
      in C++ programs that call variadic functions with NULL as an argument
      and (wrongly; this is UB) expect it to arrive as a null pointer. on
      64-bit machines, the high bits end up containing junk. glibc dodges
      the issue by using a GCC extension __null to define NULL; this is
      observably non-conforming because a conforming application could
      observe the definition of NULL via stringizing and see that it is
      neither an integer constant expression with value zero nor such an
      expression cast to void.
      
      switching to 0L eliminates the issue and provides compatibility with
      broken applications, since on all musl targets, long and pointers have
      the same size, representation, and argument-passing convention. we
      could maintain separate C and C++ definitions of NULL (i.e. just use
      0L on C++ and use (void *)0 on C) but after careful analysis, it seems
      extremely difficult for a C program to even determine whether NULL has
      integer or pointer type, much less depend in subtle, unintentional
      ways, on whether it does. C89 seems to have no way to make the
      distinction. on C99, the fact that (int)(void *)0 is not an integer
      constant expression, along with subtle VLA/sizeof semantics, can be
      used to make the distinction, but many compilers are non-conforming
      and give the wrong result to this test anyway. on C11, _Generic can
      trivially make the distinction, but it seems unlikely that code
      targetting C11 would be so backwards in caring which definition of
      NULL an implementation uses.
      
      as such, the simplest path of using the same definition for NULL in
      both C and C++ was chosen. the #undef directive was also removed so
      that the compiler can catch and give a warning or error on
      redefinition if buggy programs have defined their own versions of
      NULL prior to inclusion of standard headers.
      41d7c77d
  3. 17 1月, 2013 2 次提交
  4. 15 1月, 2013 2 次提交
  5. 14 1月, 2013 4 次提交
  6. 13 1月, 2013 13 次提交
  7. 11 1月, 2013 2 次提交
  8. 08 1月, 2013 1 次提交
    • S
      math: erf and erfc cleanup · 121e3a38
      Szabolcs Nagy 提交于
      common part of erf and erfc was put in a separate function which
      saved some space and the new code is using unsigned arithmetics
      
      erfcf had a bug: for some inputs in [7.95,8] the result had
      more than 60ulp error: in expf(-z*z - 0.5625f) the argument
      must be exact but not enough lowbits of z were zeroed,
      -SET_FLOAT_WORD(z, ix&0xfffff000);
      +SET_FLOAT_WORD(z, ix&0xffffe000);
      fixed the issue
      121e3a38
  9. 05 1月, 2013 5 次提交
    • R
      setjmp.h: add struct tag for sigjmp_buf (GCC C++ compatibility) · d84923d8
      rofl0r 提交于
      the anonymous struct typedef with array notation breaks with
      GCC in C++ mode:
      
      error: non-local function 'static<anonymous struct>
      (& boost::signal_handler::jump_buffer())[1]' uses anonymous type
      
      this is a known GCC issue, as search results for that error msg
      suggest.
      
      since this is hard to work around in the calling C++ code, a
      fix in musl is preferable.
      d84923d8
    • R
      add legacy header values.h · 2ba3f44d
      rofl0r 提交于
      some programs (procps, babl) expect it, and it doesn't seem to
      cause any harm to just add it.
      it's small and straightforward.
      
      since math.h also defines MAXFLOAT, we undef it in both places,
      before defining it.
      2ba3f44d
    • R
      87781ac6
    • R
      wait.h: add linux specific, thread-related waitpid() flags · e895ddc0
      rofl0r 提交于
      these flags are needed in order to be able to handle lwp id's
      which the kernel returns after clone() calls for new threads
      via ptrace(PTRACE_GETEVENTMSG).
      
      fortunately, they're the same for all archs and in the reserved
      namespace.
      e895ddc0
    • R
      __assert_fail(): remove _Noreturn, to get proper stacktraces · 2c1f8fd5
      rofl0r 提交于
      for _Noreturn functions, gcc generates code that trashes the
      stack frame, and so it makes it impossible to inspect the causes
      of an assert error in gdb.
      
      abort() is not affected (i have not yet investigated why).
      2c1f8fd5
  10. 02 1月, 2013 4 次提交
    • R
      add some new-ish IPPROTO constants that were missing · 5d893e50
      Rich Felker 提交于
      5d893e50
    • S
      math: bessel cleanup (jn.c and jnf.c) · 5652d700
      Szabolcs Nagy 提交于
      both jn and yn functions had integer overflow issues for large
      and small n
      
      to handle these issues nm1 (== |n|-1) is used instead of n and -n
      in the code and some loops are changed to make sure the iteration
      counter does not overflow
      
      (another solution could be to use larger integer type or even double
      but that has more size and runtime cost, on x87 loading int64_t or
      even uint32_t into an fpu register is more than two times slower than
      loading int32_t, and using double for n slows down iteration logic)
      
      yn(-1,0) now returns inf
      
      posix2008 specifies that on overflow and at +-0 all y0,y1,yn functions
      return -inf, this is not consistent with math when n<0 odd integer in yn
      (eg. when x->0, yn(-1,x)->inf, but historically yn(-1,0) seems to be
      special cased and returned -inf)
      
      some threshold values in jnf and ynf were fixed that seems to be
      incorrectly copy-pasted from the double version
      5652d700
    • S
      math: bessel cleanup (j1.c and j1f.c) · 5bb6b249
      Szabolcs Nagy 提交于
      a common code path in j1 and y1 was factored out so the resulting
      object code is a bit smaller
      
      unsigned int arithmetics is used for bit manipulation
      
      j1(-inf) now returns 0 instead of -0
      
      an incorrect threshold in the common code of j1f and y1f got fixed
      (this caused spurious overflow and underflow exceptions)
      
      the else branch in pone and pzero functions are fixed
      (so code analyzers dont warn about uninitialized values)
      5bb6b249
    • S
      math: bessel cleanup (j0.c and j0f.c) · 697acde6
      Szabolcs Nagy 提交于
      a common code path in j0 and y0 was factored out so the resulting
      object code is smaller
      
      unsigned int arithmetics is used for bit manipulation
      
      the logic of j0 got a bit simplified (x < 1 case was handled
      separately with a bit higher precision than now, but there are large
      errors in other domains anyway so that branch has been removed)
      
      some threshold values were adjusted in j0f and y0f
      697acde6
  11. 29 12月, 2012 1 次提交
  12. 28 12月, 2012 1 次提交
    • R
      align EPOLL_* flags with fcntl O_* flag definitions, which vary by arch · 761ebe06
      Rich Felker 提交于
      the old definitions were wrong on some archs. actually, EPOLL_NONBLOCK
      probably should not even be defined; it is not accepted by the kernel
      and it's not clear to me whether it has any use at all, even if it did
      work. this issue should be revisited at some point, but I'm leaving it
      in place for now in case some applications reference it.
      761ebe06
  13. 27 12月, 2012 2 次提交
  14. 26 12月, 2012 1 次提交
    • R
      fix reference to libc struct in static tls init code · e172c7b4
      Rich Felker 提交于
      libc is the macro, __libc is the internal symbol, but under some
      configurations on old/broken compilers, the symbol might not actually
      exist and the libc macro might instead use __libc_loc() to obtain
      access to the object.
      e172c7b4