Date: Mon, 13 Oct 2008 18:44:59 +0000 (UTC) From: "Christian S.J. Peron" <csjp@FreeBSD.org> To: src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-releng@freebsd.org Subject: svn commit: r183837 - in releng/6.4/sys: . netinet/libalias Message-ID: <200810131844.m9DIixJ8083547@svn.freebsd.org>
next in thread | raw e-mail | index | archive | help
Author: csjp Date: Mon Oct 13 18:44:59 2008 New Revision: 183837 URL: http://svn.freebsd.org/changeset/base/183837 Log: MFC change 182488 Improve entropy in source port generation for libalias consumers. Approved by: re (kib) Modified: releng/6.4/sys/ (props changed) releng/6.4/sys/netinet/libalias/alias_db.c Modified: releng/6.4/sys/netinet/libalias/alias_db.c ============================================================================== --- releng/6.4/sys/netinet/libalias/alias_db.c Mon Oct 13 18:42:25 2008 (r183836) +++ releng/6.4/sys/netinet/libalias/alias_db.c Mon Oct 13 18:44:59 2008 (r183837) @@ -603,7 +603,7 @@ GetNewPort(struct libalias *la, struct a port_sys = ntohs(port_net); } else { /* First trial and all subsequent are random. */ - port_sys = random() & ALIAS_PORT_MASK; + port_sys = arc4random() & ALIAS_PORT_MASK; port_sys += ALIAS_PORT_BASE; port_net = htons(port_sys); } @@ -654,7 +654,7 @@ GetNewPort(struct libalias *la, struct a } #endif } - port_sys = random() & ALIAS_PORT_MASK; + port_sys = arc4random() & ALIAS_PORT_MASK; port_sys += ALIAS_PORT_BASE; port_net = htons(port_sys); } @@ -767,9 +767,9 @@ FindNewPortGroup(struct libalias *la, /* First trial and all subsequent are random. */ if (align == FIND_EVEN_ALIAS_BASE) - port_sys = random() & ALIAS_PORT_MASK_EVEN; + port_sys = arc4random() & ALIAS_PORT_MASK_EVEN; else - port_sys = random() & ALIAS_PORT_MASK; + port_sys = arc4random() & ALIAS_PORT_MASK; port_sys += ALIAS_PORT_BASE; } @@ -791,9 +791,9 @@ FindNewPortGroup(struct libalias *la, /* Find a new base to try */ if (align == FIND_EVEN_ALIAS_BASE) - port_sys = random() & ALIAS_PORT_MASK_EVEN; + port_sys = arc4random() & ALIAS_PORT_MASK_EVEN; else - port_sys = random() & ALIAS_PORT_MASK; + port_sys = arc4random() & ALIAS_PORT_MASK; port_sys += ALIAS_PORT_BASE; }
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200810131844.m9DIixJ8083547>