1. 07 10月, 2016 3 次提交
    • R
      fix regexec with haystack strings longer than INT_MAX · aee6abb2
      Rich Felker 提交于
      we inherited from TRE regexec code that's utterly wrong with respect
      to the integer types it's using. while it doesn't appear that
      compilers are producing unsafe output, signed integer overflows seem
      to happen, and regexec fails to find matches past offset INT_MAX.
      
      this patch fixes the type of all variables/fields used to store
      offsets in the string from int to regoff_t. after the changes, basic
      testing showed that regexec can now find matches past 2GB (INT_MAX)
      and past 4GB on x86_64, and code generation is unchanged on i386.
      aee6abb2
    • R
      fix missing integer overflow checks in regexec buffer size computations · c3edc06d
      Rich Felker 提交于
      most of the possible overflows were already ruled out in practice by
      regcomp having already succeeded performing larger allocations.
      however at least the num_states*num_tags multiplication can clearly
      overflow in practice. for safety, check them all, and use the proper
      type, size_t, rather than int.
      
      also improve comments, use calloc in place of malloc+memset, and
      remove bogus casts.
      c3edc06d
    • S
      fix strftime %y for negative tm_year · 583ea835
      Szabolcs Nagy 提交于
      583ea835
  2. 24 9月, 2016 2 次提交
  3. 19 9月, 2016 2 次提交
    • R
      fix undefined behavior in sched.h cpu_set_t usage · 66570ec9
      Rich Felker 提交于
      since cpu sets can be dynamically allocated and have variable size,
      accessing their contents via ->__bits is not valid; performing pointer
      arithmetic outside the range of the size of the declared __bits array
      results in undefined beahavior. instead, only use cpu_set_t for
      fixed-size cpu set objects (instantiated by the caller) and as an
      abstract pointer type for dynamically allocated ones. perform all
      accesses simply by casting the abstract pointer type cpuset_t * back
      to unsigned long *.
      66570ec9
    • R
      simplify/refactor fflush and make fflush_unlocked an alias for fflush · c002668e
      Rich Felker 提交于
      previously, fflush_unlocked was an alias for an internal backend that
      was called by fflush, either for its argument or in a loop for each
      file if a null pointer was passed. since the logic for the latter was
      in the main fflush function, fflush_unlocked crashed when passed a
      null pointer, rather than flushing all open files. since
      fflush_unlocked is not a standard function and has no specification,
      it's not clear whether it should be expected to accept null pointers
      like fflush does, but a reasonable argument could be made that it
      should.
      
      this patch eliminates the helper function, simplifying fflush, and
      makes fflush_unlocked an alias for fflush, which is valid because the
      two functions agree in their behavior in all cases where their
      behavior is defined (the unlocked version has undefined behavior if
      another thread could hold locks).
      c002668e
  4. 17 9月, 2016 4 次提交
  5. 31 8月, 2016 10 次提交
  6. 12 8月, 2016 1 次提交
    • R
      fix pread/pwrite syscall calling convention on sh · 7cc3a28e
      Rich Felker 提交于
      despite sh not generally using register-pair alignment for 64-bit
      syscall arguments, there are arch-specific versions of the syscall
      entry points for pread and pwrite which include a dummy argument for
      alignment before the 64-bit offset argument.
      7cc3a28e
  7. 14 7月, 2016 2 次提交
  8. 08 7月, 2016 1 次提交
  9. 07 7月, 2016 1 次提交
  10. 06 7月, 2016 3 次提交
  11. 04 7月, 2016 11 次提交