1. 01 Aug, 2014 1 commit
  2. 29 Jul, 2014 2 commits
    • Cody P Schafer's avatar
      configurator: add BUILTIN_CTZ*, BUILTIN_FFS, and ICCARM_INTRINSICS · 54d5123a
      Cody P Schafer authored
      Realistically, the ICCARM_INTRINSICS probably won't ever be generated
      by configurator, but will show up in manually created or alternately
      generated config.h's.
      Signed-off-by: default avatarCody P Schafer <dev@codyps.com>
      54d5123a
    • Douglas Bagnall's avatar
      opt/helpers: fix out-of-range check in opt_set_floatval() · 106eab33
      Douglas Bagnall authored
      opt_set_floatval() uses opt_set_doubleval() to do initial conversion
      and bounds checking before casting the result to float.  Previously
      the out of bounds check compared the original and float values for
      equality and declared anything unequal to be out of bounds. While this
      trick works well in the orderly integer world, it can backfire with
      floating point. For example, 3.1 resolves to the double more precisely
      known as 3.100000000000000088817841970012523233890533447265625, while
      3.1f resolves to 3.099999904632568359375.  These are not equal, though
      3.1 is generally regarded as being in bounds for a float.  There are
      around 8 billion other doubles (i.e. 3.1 +/- a little bit) that map to
      the same 3.1f value, of which only one is strictly equal to it.
      
      Why wasn't this discovered by the tests? It turns out that neither
      set_floatval nor set_doubleval were tested against non-integral
      numbers.  This is slightly improved here.
      
      This patch uses the arguably more reasonable definition of bounds that
      is found in opt_set_doubleval(): it excludes numbers that would get
      rounded to zero or an infinity. One subtlety is that the double
      version allows `--foo=INF` for an explicit infinity without overflow.
      This is possibly useful, and there is some fiddling to allow this for
      floats. Likewise an explicit zero is allowed, as you would expect.
      
      It is perhaps worth noting that the `*f = d` cast/assignment at the
      heart of it all can crash and core dump on overflow or underflow if
      the floating point exception flags are in an unexpected state.
      Signed-off-by: default avatarDouglas Bagnall <douglas@halo.gen.nz>
      106eab33
  3. 25 Jul, 2014 1 commit
  4. 17 Jul, 2014 1 commit
  5. 25 Jun, 2014 1 commit
  6. 23 Jun, 2014 6 commits
  7. 22 Jun, 2014 1 commit
  8. 21 Jun, 2014 3 commits
  9. 16 Jun, 2014 4 commits
  10. 13 Jun, 2014 2 commits
  11. 12 Jun, 2014 1 commit
  12. 10 Jun, 2014 17 commits