Skip to content
Snippets Groups Projects
  1. Oct 06, 2021
  2. Oct 05, 2021
    • David Goulet's avatar
      cc: Fix 32bit arithmetic to actually be 64bit · cdbf756b
      David Goulet authored
      
      Coverity report: CID 1492322
      
      ________________________________________________________________________________________________________
      *** CID 1492322:  Integer handling issues  (OVERFLOW_BEFORE_WIDEN)
      /src/core/or/congestion_control_flow.c: 399 in circuit_process_stream_xon()
      393       }
      394
      395       log_info(LD_EDGE, "Got XON: %d", xon->kbps_ewma);
      396
      397       /* Adjust the token bucket of this edge connection with the drain rate in
      398        * the XON. Rate is in bytes from kilobit (kpbs). */
      >>>     CID 1492322:  Integer handling issues  (OVERFLOW_BEFORE_WIDEN)
      >>>     Potentially overflowing expression "xon_cell_get_kbps_ewma(xon) * 1000U" with type "unsigned int" (32 bits, unsigned) is evaluated using 32-bit arithmetic, and then used in a context that expects an expression of type "uint64_t" (64 bits, unsigned).
      399       uint64_t rate = xon_cell_get_kbps_ewma(xon) * 1000;
      400       if (rate == 0 || INT32_MAX < rate) {
      401         /* No rate. */
      402         rate = INT32_MAX;
      403       }
      404       token_bucket_rw_adjust(&conn->bucket, (uint32_t) rate, (uint32_t) rate);
      
      Fixes #40478
      
      Signed-off-by: David Goulet's avatarDavid Goulet <dgoulet@torproject.org>
      cdbf756b
  3. Oct 04, 2021
  4. Sep 28, 2021
  5. Sep 27, 2021
  6. Sep 17, 2021
  7. Sep 16, 2021
  8. Sep 15, 2021
  9. Sep 14, 2021
Loading