Skip site navigation (1)Skip section navigation (2)
Date:      Sat, 18 Mar 2017 23:00:13 +0000 (UTC)
From:      Don Lewis <truckman@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org
Subject:   svn commit: r315516 - head/sys/netpfil/ipfw
Message-ID:  <201703182300.v2IN0DKa081619@repo.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: truckman
Date: Sat Mar 18 23:00:13 2017
New Revision: 315516
URL: https://svnweb.freebsd.org/changeset/base/315516

Log:
  Change several constants used by the PIE algorithm from unsigned to signed.
  
   - PIE_MAX_PROB is compared to variable of int64_t and the type promotion
     rules can cause the value of that variable to be treated as unsigned.
     If the value is actually negative, then the result of the comparsion
     is incorrect, causing the algorithm to perform poorly in some
     situations.  Changing the constant to be signed cause the comparision
     to work correctly.
  
   - PIE_SCALE is also compared to signed values.  Fortunately they are
     also compared to zero and negative values are discarded so this is
     more of a cosmetic fix.
  
   - PIE_DQ_THRESHOLD is only compared to unsigned values, but it is small
     enough that the automatic promotion to unsigned is harmless.
  
  Submitted by:	Rasool Al-Saadi <ralsaadi@swin.edu.au>
  MFC after:	1 week

Modified:
  head/sys/netpfil/ipfw/dn_aqm_pie.h

Modified: head/sys/netpfil/ipfw/dn_aqm_pie.h
==============================================================================
--- head/sys/netpfil/ipfw/dn_aqm_pie.h	Sat Mar 18 22:19:23 2017	(r315515)
+++ head/sys/netpfil/ipfw/dn_aqm_pie.h	Sat Mar 18 23:00:13 2017	(r315516)
@@ -37,16 +37,16 @@
 #define DN_AQM_PIE 2
 #define PIE_DQ_THRESHOLD_BITS 14
 /* 2^14 =16KB */
-#define PIE_DQ_THRESHOLD (1UL << PIE_DQ_THRESHOLD_BITS) 
+#define PIE_DQ_THRESHOLD (1L << PIE_DQ_THRESHOLD_BITS) 
 #define MEAN_PKTSIZE 800
 
 /* 31-bits because random() generates range from 0->(2**31)-1 */
 #define PIE_PROB_BITS 31
-#define PIE_MAX_PROB ((1ULL<<PIE_PROB_BITS) -1)
+#define PIE_MAX_PROB ((1LL<<PIE_PROB_BITS) -1)
 
 /* for 16-bits, we have 3-bits for integer part and 13-bits for fraction */
 #define PIE_FIX_POINT_BITS 13
-#define PIE_SCALE (1UL<<PIE_FIX_POINT_BITS)
+#define PIE_SCALE (1L<<PIE_FIX_POINT_BITS)
 
 
 /* PIE options */



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201703182300.v2IN0DKa081619>