From owner-svn-src-all@FreeBSD.ORG Mon Nov 3 23:36:43 2014 Return-Path: Delivered-To: svn-src-all@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by hub.freebsd.org (Postfix) with ESMTPS id 0350D4DA; Mon, 3 Nov 2014 23:36:43 +0000 (UTC) Received: from svn.freebsd.org (svn.freebsd.org [IPv6:2001:1900:2254:2068::e6a:0]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client did not present a certificate) by mx1.freebsd.org (Postfix) with ESMTPS id E2F9BC6F; Mon, 3 Nov 2014 23:36:42 +0000 (UTC) Received: from svn.freebsd.org ([127.0.1.70]) by svn.freebsd.org (8.14.9/8.14.9) with ESMTP id sA3NagRI094506; Mon, 3 Nov 2014 23:36:42 GMT (envelope-from ngie@FreeBSD.org) Received: (from ngie@localhost) by svn.freebsd.org (8.14.9/8.14.9/Submit) id sA3Nafdn094499; Mon, 3 Nov 2014 23:36:41 GMT (envelope-from ngie@FreeBSD.org) Message-Id: <201411032336.sA3Nafdn094499@svn.freebsd.org> X-Authentication-Warning: svn.freebsd.org: ngie set sender to ngie@FreeBSD.org using -f From: Garrett Cooper Date: Mon, 3 Nov 2014 23:36:41 +0000 (UTC) To: src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org Subject: svn commit: r274066 - head/contrib/netbsd-tests/lib/libc/ssp X-SVN-Group: head MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-BeenThere: svn-src-all@freebsd.org X-Mailman-Version: 2.1.18-1 Precedence: list List-Id: "SVN commit messages for the entire src tree \(except for " user" and " projects" \)" List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Mon, 03 Nov 2014 23:36:43 -0000 Author: ngie Date: Mon Nov 3 23:36:41 2014 New Revision: 274066 URL: https://svnweb.freebsd.org/changeset/base/274066 Log: Port lib/libc/ssp to FreeBSD In most cases, the buffers and data were resized, but when dealing with the helpers, some of the code was adjusted to fail more reliably Submitted by: pho Modified: head/contrib/netbsd-tests/lib/libc/ssp/h_memset.c head/contrib/netbsd-tests/lib/libc/ssp/h_read.c head/contrib/netbsd-tests/lib/libc/ssp/h_readlink.c head/contrib/netbsd-tests/lib/libc/ssp/h_snprintf.c head/contrib/netbsd-tests/lib/libc/ssp/t_ssp.sh Modified: head/contrib/netbsd-tests/lib/libc/ssp/h_memset.c ============================================================================== --- head/contrib/netbsd-tests/lib/libc/ssp/h_memset.c Mon Nov 3 22:37:10 2014 (r274065) +++ head/contrib/netbsd-tests/lib/libc/ssp/h_memset.c Mon Nov 3 23:36:41 2014 (r274066) @@ -41,5 +41,9 @@ main(int argc, char *argv[]) char b[10]; size_t len = atoi(argv[1]); (void)memset(b, 0, len); +#ifdef __FreeBSD__ + return b[0]; /* keeps optimizer from zapping the call to memset() */ +#else return 0; +#endif } Modified: head/contrib/netbsd-tests/lib/libc/ssp/h_read.c ============================================================================== --- head/contrib/netbsd-tests/lib/libc/ssp/h_read.c Mon Nov 3 22:37:10 2014 (r274065) +++ head/contrib/netbsd-tests/lib/libc/ssp/h_read.c Mon Nov 3 23:36:41 2014 (r274066) @@ -36,12 +36,30 @@ __RCSID("$NetBSD: h_read.c,v 1.1 2010/12 #include #include +#ifdef __FreeBSD__ +#include + +int +main(int argc, char *argv[]) +{ + char b[MAXPATHLEN]; + int fd, n; + size_t len = atoi(argv[1]); + + fd = open("/dev/zero", O_RDONLY); + if ((n = read(fd, b, len)) == -1) + abort(); + (void)printf("%s\n", b); + return (0); +} +#else int main(int argc, char *argv[]) { char b[MAXPATHLEN]; size_t len = atoi(argv[1]); - (void)read(0, b, len); + (void)printf("%s\n", b); return 0; } +#endif Modified: head/contrib/netbsd-tests/lib/libc/ssp/h_readlink.c ============================================================================== --- head/contrib/netbsd-tests/lib/libc/ssp/h_readlink.c Mon Nov 3 22:37:10 2014 (r274065) +++ head/contrib/netbsd-tests/lib/libc/ssp/h_readlink.c Mon Nov 3 23:36:41 2014 (r274066) @@ -36,12 +36,31 @@ __RCSID("$NetBSD: h_readlink.c,v 1.1 201 #include #include +#ifdef __FreeBSD__ +#include +#include +#endif + int main(int argc, char *argv[]) { +#ifdef __FreeBSD__ + char b[512], *sl; + int n; + size_t len = atoi(argv[1]); + sl = malloc(len); + memset(sl, 'a', len); + sl[len - 1] = 0; + unlink("symlink"); + if (symlink(sl, "symlink") == -1) + err(1, "symlink()"); + n = readlink("symlink", b, len); + unlink("symlink"); +#else char b[MAXPATHLEN]; size_t len = atoi(argv[1]); (void)readlink("/", b, len); +#endif (void)printf("%s\n", b); return 0; } Modified: head/contrib/netbsd-tests/lib/libc/ssp/h_snprintf.c ============================================================================== --- head/contrib/netbsd-tests/lib/libc/ssp/h_snprintf.c Mon Nov 3 22:37:10 2014 (r274065) +++ head/contrib/netbsd-tests/lib/libc/ssp/h_snprintf.c Mon Nov 3 23:36:41 2014 (r274066) @@ -39,7 +39,13 @@ main(int argc, char *argv[]) { char b[10]; size_t len = atoi(argv[1]); +#ifdef __FreeBSD__ + char c[] = "01234567890123456789"; + c[len] = 0; + (void)snprintf(b, len, "%s", c); +#else (void)snprintf(b, len, "%s", "0123456789"); +#endif (void)printf("%s\n", b); return 0; } Modified: head/contrib/netbsd-tests/lib/libc/ssp/t_ssp.sh ============================================================================== --- head/contrib/netbsd-tests/lib/libc/ssp/t_ssp.sh Mon Nov 3 22:37:10 2014 (r274065) +++ head/contrib/netbsd-tests/lib/libc/ssp/t_ssp.sh Mon Nov 3 23:36:41 2014 (r274066) @@ -34,7 +34,15 @@ h_pass() h_fail() { echo "Executing command [ $2$1 ]" + # Begin FreeBSD + if true; then + eval $2 atf_check -s signal -o ignore -e ignore $1 + else + # End FreeBSD eval $2 atf_check -s signal:6 -o ignore -e ignore $1 + # Begin FreeBSD + fi + # End FreeBSD } atf_test_case sprintf @@ -47,7 +55,15 @@ sprintf_body() prog="$(atf_get_srcdir)/h_sprintf" h_pass "$prog ok" + # Begin FreeBSD + if true; then + h_fail "$prog 0123456789ab" + else + # End FreeBSD h_fail "$prog 0123456789" + # Begin FreeBSD + fi + # End FreeBSD } atf_test_case vsprintf @@ -60,7 +76,15 @@ vsprintf_body() prog="$(atf_get_srcdir)/h_vsprintf" h_pass "$prog ok" + # Begin FreeBSD + if true; then + h_fail "$prog 0123456789ab" + else + # End FreeBSD h_fail "$prog 0123456789" + # Begin FreeBSD + fi + # End FreeBSD } atf_test_case snprintf @@ -73,7 +97,15 @@ snprintf_body() prog="$(atf_get_srcdir)/h_snprintf" h_pass "$prog 10" + # Begin FreeBSD + if true; then + h_fail "$prog 13" + else + # End FreeBSD h_fail "$prog 11" + # Begin FreeBSD + fi + # End FreeBSD } atf_test_case vsnprintf @@ -86,7 +118,15 @@ vsnprintf_body() prog="$(atf_get_srcdir)/h_vsnprintf" h_pass "$prog 10" + # Begin FreeBSD + if true; then + h_fail "$prog 13" + else + # End FreeBSD h_fail "$prog 11" + # Begin FreeBSD + fi + # End FreeBSD } atf_test_case gets @@ -99,7 +139,15 @@ gets_body() prog="$(atf_get_srcdir)/h_gets" h_pass "$prog" "echo ok |" + # Begin FreeBSD + if true; then + h_fail "$prog" "echo 0123456789ab |" + else + # End FreeBSD h_fail "$prog" "echo 0123456789 |" + # Begin FreeBSD + fi + # End FreeBSD } atf_test_case fgets @@ -112,7 +160,15 @@ fgets_body() prog="$(atf_get_srcdir)/h_fgets" h_pass "$prog 10" "echo ok |" + # Begin FreeBSD + if true; then + h_fail "$prog 13" "echo 0123456789abc |" + else + # End FreeBSD h_fail "$prog 11" "echo busted |" + # Begin FreeBSD + fi + # End FreeBSD } atf_test_case memcpy @@ -125,7 +181,15 @@ memcpy_body() prog="$(atf_get_srcdir)/h_memcpy" h_pass "$prog 10" + # Begin FreeBSD + if true; then + h_fail "$prog 13" + else + # End FreeBSD h_fail "$prog 11" + # Begin FreeBSD + fi + # End FreeBSD } atf_test_case memmove @@ -138,7 +202,15 @@ memmove_body() prog="$(atf_get_srcdir)/h_memmove" h_pass "$prog 10" + # Begin FreeBSD + if true; then + h_fail "$prog 13" + else + # End FreeBSD h_fail "$prog 11" + # Begin FreeBSD + fi + # End FreeBSD } atf_test_case memset @@ -151,7 +223,15 @@ memset_body() prog="$(atf_get_srcdir)/h_memset" h_pass "$prog 10" + # Begin FreeBSD + if true; then + h_fail "$prog 13" + else + # End FreeBSD h_fail "$prog 11" + # Begin FreeBSD + fi + # End FreeBSD } atf_test_case strcpy @@ -164,7 +244,15 @@ strcpy_body() prog="$(atf_get_srcdir)/h_strcpy" h_pass "$prog 0123456" + # Begin FreeBSD + if true; then + h_fail "$prog 0123456789ab" + else + # End FreeBSD h_fail "$prog 0123456789" + # Begin FreeBSD + fi + # End FreeBSD } atf_test_case stpcpy @@ -177,7 +265,15 @@ stpcpy_body() prog="$(atf_get_srcdir)/h_stpcpy" h_pass "$prog 0123456" + # Begin FreeBSD + if true; then + h_fail "$prog 0123456789ab" + else + # End FreeBSD h_fail "$prog 0123456789" + # Begin FreeBSD + fi + # End FreeBSD } atf_test_case strcat @@ -203,7 +299,15 @@ strncpy_body() prog="$(atf_get_srcdir)/h_strncpy" h_pass "$prog 10" + # Begin FreeBSD + if true; then + h_fail "$prog 13" + else + # End FreeBSD h_fail "$prog 11" + # Begin FreeBSD + fi + # End FreeBSD } atf_test_case stpncpy @@ -216,7 +320,15 @@ stpncpy_body() prog="$(atf_get_srcdir)/h_stpncpy" h_pass "$prog 10" + # Begin FreeBSD + if true; then + h_fail "$prog 13" + else + # End FreeBSD h_fail "$prog 11" + # Begin FreeBSD + fi + # End FreeBSD } atf_test_case strncat @@ -228,8 +340,16 @@ strncat_body() { prog="$(atf_get_srcdir)/h_strncat" + # Begin FreeBSD h_pass "$prog 8" + if true; then + h_fail "$prog 11" + else + # End FreeBSD h_fail "$prog 9" + # Begin FreeBSD + fi + # End FreeBSD } atf_test_case raw @@ -242,7 +362,15 @@ raw_body() prog="$(atf_get_srcdir)/h_raw" h_pass "$prog 9" + # Begin FreeBSD + if true; then + h_fail "$prog 12" + else + # End FreeBSD h_fail "$prog 10" + # Begin FreeBSD + fi + # End FreeBSD } atf_test_case read @@ -255,7 +383,15 @@ read_body() prog="$(atf_get_srcdir)/h_read" h_pass "$prog 1024" "echo foo |" + # Begin FreeBSD + if true; then + h_fail "$prog 1027" "echo bar |" + else + # End FreeBSD h_fail "$prog 1025" "echo bar |" + # Begin FreeBSD + fi + # End FreeBSD } atf_test_case readlink @@ -267,8 +403,17 @@ readlink_body() { prog="$(atf_get_srcdir)/h_readlink" + # Begin FreeBSD + if true; then + h_pass "$prog 512" + h_fail "$prog 523" + else + # End FreeBSD h_pass "$prog 1024" h_fail "$prog 1025" + # Begin FreeBSD + fi + # End FreeBSD } atf_test_case getcwd @@ -281,7 +426,13 @@ getcwd_body() prog="$(atf_get_srcdir)/h_getcwd" h_pass "$prog 1024" + # Begin FreeBSD + if false; then + # End FreeBSD h_fail "$prog 1025" + # Begin FreeBSD + fi + # End FreeBSD } atf_init_test_cases()