1. 02 2月, 2013 2 次提交
  2. 01 2月, 2013 2 次提交
  3. 31 1月, 2013 1 次提交
    • R
      SOL_TCP is nonstandard and not in the reserved namespace · 725c5552
      Rich Felker 提交于
      alternatively, we could define it in sys/socket.h since SO* is
      reserved there, and tcp.h includes sys/socket.h in extensions mode.
      
      note that SOL_TCP is simply wrong and it's only here for compatibility
      with broken applications. the correct argument to pass for setting TCP
      socket options is IPPROTO_TCP, which of course has the same value as
      SOL_TCP but works everywhere.
      725c5552
  4. 27 1月, 2013 1 次提交
  5. 24 1月, 2013 3 次提交
  6. 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
  7. 17 1月, 2013 2 次提交
  8. 15 1月, 2013 2 次提交
  9. 14 1月, 2013 4 次提交
  10. 13 1月, 2013 13 次提交
  11. 11 1月, 2013 2 次提交
  12. 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
  13. 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
  14. 02 1月, 2013 1 次提交