Loading net/ipv4/multipath_random.c +2 −16 Original line number Diff line number Diff line Loading @@ -32,6 +32,7 @@ #include <linux/module.h> #include <linux/mroute.h> #include <linux/init.h> #include <linux/random.h> #include <net/ip.h> #include <net/protocol.h> #include <linux/skbuff.h> Loading @@ -48,21 +49,6 @@ #define MULTIPATH_MAX_CANDIDATES 40 /* interface to random number generation */ static unsigned int RANDOM_SEED = 93186752; static inline unsigned int random(unsigned int ubound) { static unsigned int a = 1588635695, q = 2, r = 1117695901; RANDOM_SEED = a*(RANDOM_SEED % q) - r*(RANDOM_SEED / q); return RANDOM_SEED % ubound; } static void random_select_route(const struct flowi *flp, struct rtable *first, struct rtable **rp) Loading @@ -84,7 +70,7 @@ static void random_select_route(const struct flowi *flp, if (candidate_count > 1) { unsigned char i = 0; unsigned char candidate_no = (unsigned char) random(candidate_count); (random32() % candidate_count); /* find chosen candidate and adjust GC data for all candidates * to ensure they stay in cache Loading net/ipv4/multipath_wrandom.c +2 −13 Original line number Diff line number Diff line Loading @@ -32,6 +32,7 @@ #include <linux/module.h> #include <linux/mroute.h> #include <linux/init.h> #include <linux/random.h> #include <net/ip.h> #include <net/protocol.h> #include <linux/skbuff.h> Loading Loading @@ -84,18 +85,6 @@ struct multipath_route { /* state: primarily weight per route information */ static struct multipath_bucket state[MULTIPATH_STATE_SIZE]; /* interface to random number generation */ static unsigned int RANDOM_SEED = 93186752; static inline unsigned int random(unsigned int ubound) { static unsigned int a = 1588635695, q = 2, r = 1117695901; RANDOM_SEED = a*(RANDOM_SEED % q) - r*(RANDOM_SEED / q); return RANDOM_SEED % ubound; } static unsigned char __multipath_lookup_weight(const struct flowi *fl, const struct rtable *rt) { Loading Loading @@ -193,7 +182,7 @@ static void wrandom_select_route(const struct flowi *flp, /* choose a weighted random candidate */ decision = first; selector = random(power); selector = random32() % power; last_power = 0; /* select candidate, adjust GC data and cleanup local state */ Loading Loading
net/ipv4/multipath_random.c +2 −16 Original line number Diff line number Diff line Loading @@ -32,6 +32,7 @@ #include <linux/module.h> #include <linux/mroute.h> #include <linux/init.h> #include <linux/random.h> #include <net/ip.h> #include <net/protocol.h> #include <linux/skbuff.h> Loading @@ -48,21 +49,6 @@ #define MULTIPATH_MAX_CANDIDATES 40 /* interface to random number generation */ static unsigned int RANDOM_SEED = 93186752; static inline unsigned int random(unsigned int ubound) { static unsigned int a = 1588635695, q = 2, r = 1117695901; RANDOM_SEED = a*(RANDOM_SEED % q) - r*(RANDOM_SEED / q); return RANDOM_SEED % ubound; } static void random_select_route(const struct flowi *flp, struct rtable *first, struct rtable **rp) Loading @@ -84,7 +70,7 @@ static void random_select_route(const struct flowi *flp, if (candidate_count > 1) { unsigned char i = 0; unsigned char candidate_no = (unsigned char) random(candidate_count); (random32() % candidate_count); /* find chosen candidate and adjust GC data for all candidates * to ensure they stay in cache Loading
net/ipv4/multipath_wrandom.c +2 −13 Original line number Diff line number Diff line Loading @@ -32,6 +32,7 @@ #include <linux/module.h> #include <linux/mroute.h> #include <linux/init.h> #include <linux/random.h> #include <net/ip.h> #include <net/protocol.h> #include <linux/skbuff.h> Loading Loading @@ -84,18 +85,6 @@ struct multipath_route { /* state: primarily weight per route information */ static struct multipath_bucket state[MULTIPATH_STATE_SIZE]; /* interface to random number generation */ static unsigned int RANDOM_SEED = 93186752; static inline unsigned int random(unsigned int ubound) { static unsigned int a = 1588635695, q = 2, r = 1117695901; RANDOM_SEED = a*(RANDOM_SEED % q) - r*(RANDOM_SEED / q); return RANDOM_SEED % ubound; } static unsigned char __multipath_lookup_weight(const struct flowi *fl, const struct rtable *rt) { Loading Loading @@ -193,7 +182,7 @@ static void wrandom_select_route(const struct flowi *flp, /* choose a weighted random candidate */ decision = first; selector = random(power); selector = random32() % power; last_power = 0; /* select candidate, adjust GC data and cleanup local state */ Loading