Signed-off-by: Manas Kumar Nayak <[email protected]>
To: LTP List <[email protected]>
Cc: Subrata Modak <[email protected]>
Cc: Masatake YAMATO <[email protected]>
---

--- ltp-full-20090531.orig/testcases/kernel/syscalls/mbind/Makefile     
1970-01-01 05:30:00.000000000 +0530
+++ ltp-full-20090531/testcases/kernel/syscalls/mbind/Makefile  2009-06-12 
16:30:33.000000000 +0530
@@ -0,0 +1,31 @@
+#
+#  Copyright (c) International Business Machines  Corp., 2009
+#
+#  This program is free software;  you can redistribute it and/or modify
+#  it under the terms of the GNU General Public License as published by
+#  the Free Software Foundation; either version 2 of the License, or
+#  (at your option) any later version.
+#
+#  This program is distributed in the hope that it will be useful,
+#  but WITHOUT ANY WARRANTY;  without even the implied warranty of
+#  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See
+#  the GNU General Public License for more details.
+#
+#  You should have received a copy of the GNU General Public License
+#  along with this program;  if not, write to the Free Software
+#  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
+#
+
+CFLAGS += -I../../../../include -I../utils/ -Wall -O2
+LDLIBS += -L../../../../lib -lltp
+
+SRCS    = $(wildcard *.c)
+TARGETS = $(patsubst %.c,%,$(SRCS))
+
+all: $(TARGETS)
+
+install:
+       @set -e; for i in $(TARGETS); do ln -f $$i ../../../bin/$$i ; done
+
+clean:
+       rm -f $(TARGETS)
--- ltp-full-20090531.orig/testcases/kernel/syscalls/mbind/mbind01.c    
1970-01-01 05:30:00.000000000 +0530
+++ ltp-full-20090531/testcases/kernel/syscalls/mbind/mbind01.c 2009-06-12 
16:58:30.000000000 +0530
@@ -0,0 +1,415 @@
+/******************************************************************************/
+/* Copyright (c) Crackerjack Project., 2007-2008                              
*/
+/* Author(s): Takahiro Yasui <[email protected]>,                */
+/*            Yumiko Sugita <[email protected]>,                  */
+/*            Satoshi Fujiwara <[email protected]>                   */
+/*                                                                            
*/
+/* This program is free software;  you can redistribute it and/or modify      
*/
+/* it under the terms of the GNU General Public License as published by       
*/
+/* the Free Software Foundation; either version 2 of the License, or          
*/
+/* (at your option) any later version.                                        
*/
+/*                                                                            
*/
+/* This program is distributed in the hope that it will be useful,            
*/
+/* but WITHOUT ANY WARRANTY;  without even the implied warranty of            
*/
+/* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See                  
*/
+/* the GNU General Public License for more details.                           
*/
+/*                                                                            
*/
+/* You should have received a copy of the GNU General Public License          
*/
+/* along with this program;  if not, write to the Free Software               
*/
+/* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA    
*/
+/*                                                                            
*/
+/******************************************************************************/
+/******************************************************************************/
+/*                                                                            
*/
+/* File:        mbind01.c                                           */
+/*                                                                            
*/
+/* Description: This tests the mbind() syscall                      */
+/*                                                                            
*/
+/* Usage:  <for command-line>                                                 
*/
+/* mbind01 [-c n] [-e][-i n] [-I x] [-p x] [-t]                     */
+/*      where,  -c n : Run n copies concurrently.                             
*/
+/*              -e   : Turn on errno logging.                                 
*/
+/*              -i n : Execute test n times.                                  
*/
+/*              -I x : Execute test for x seconds.                            
*/
+/*              -P x : Pause for x seconds between iterations.                
*/
+/*              -t   : Turn on syscall timing.                                
*/
+/*                                                                            
*/
+/* Total Tests: 1                                                             
*/
+/*                                                                            
*/
+/* Test Name:   mbind01                                             */
+/* History:     Porting from Crackerjack to LTP is done by                    
*/
+/*              Manas Kumar Nayak [email protected]>                        
*/
+/******************************************************************************/
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <errno.h>
+#include <unistd.h>
+
+#include <sys/syscall.h>
+#include <sys/types.h>
+#include <sys/mman.h>
+#include <getopt.h>
+#include <string.h>
+#include <stdlib.h>
+#include <errno.h>
+#include <stdio.h>
+#include <unistd.h>
+#include "numaif.h"
+#include "include_j_h.h"
+
+/* Harness Specific Include Files. */
+#include "test.h"
+#include "usctest.h"
+#include "linux_syscall_numbers.h"
+
+/* Extern Global Variables */
+extern int Tst_count;           /* counter for tst_xxx routines.         */
+extern char *TESTDIR;           /* temporary dir created by tst_tmpdir() */
+
+/* Global Variables */
+char *TCID = "mbind01";  /* Test program identifier.*/
+int  testno;
+int  TST_TOTAL = 2;                   /* total number of tests in this file.   
*/
+
+/* Extern Global Functions */
+/******************************************************************************/
+/*                                                                            
*/
+/* Function:    cleanup                                                       
*/
+/*                                                                            
*/
+/* Description: Performs all one time clean up for this test on successful    
*/
+/*              completion,  premature exit or  failure. Closes all temporary 
*/
+/*              files, removes all temporary directories exits the test with  
*/
+/*              appropriate return code by calling tst_exit() function.       
*/
+/*                                                                            
*/
+/* Input:       None.                                                         
*/
+/*                                                                            
*/
+/* Output:      None.                                                         
*/
+/*                                                                            
*/
+/* Return:      On failure - Exits calling tst_exit(). Non '0' return code.   
*/
+/*              On success - Exits calling tst_exit(). With '0' return code.  
*/
+/*                                                                            
*/
+/******************************************************************************/
+extern void cleanup() {
+        /* Remove tmp dir and all files in it */
+        TEST_CLEANUP;
+        tst_rmdir();
+
+        /* Exit with appropriate return code. */
+        tst_exit();
+}
+
+/* Local  Functions */
+/******************************************************************************/
+/*                                                                            
*/
+/* Function:    setup                                                         
*/
+/*                                                                            
*/
+/* Description: Performs all one time setup for this test. This function is   
*/
+/*              typically used to capture signals, create temporary dirs      
*/
+/*              and temporary files that may be used in the course of this    
*/
+/*              test.                                                         
*/
+/*                                                                            
*/
+/* Input:       None.                                                         
*/
+/*                                                                            
*/
+/* Output:      None.                                                         
*/
+/*                                                                            
*/
+/* Return:      On failure - Exits by calling cleanup().                      
*/
+/*              On success - returns 0.                                       
*/
+/*                                                                            
*/
+/******************************************************************************/
+void setup() {
+        /* Capture signals if any */
+        /* Create temporary directories */
+        TEST_PAUSE;
+        tst_tmpdir();
+}
+
+int sig_count = 0;
+
+void sig_action(int sig) {
+        sig_count = 1;
+}
+
+/*
+ * Macros
+ */
+#define SYSCALL_NAME    "mbind"
+
+/*
+ * Global variables
+ */
+static int opt_debug;
+static char *progname;
+
+enum test_type {
+        NORMAL,
+        INVALID_POINTER,
+};
+
+enum from_node {
+        NONE,
+        SELF,
+};
+
+/*
+ * Data Structure
+ */
+struct test_case {
+        int ttype;
+        int policy;
+        int from_node;
+        unsigned flags;
+        int ret;
+        int err;
+};
+
+/* Test cases
+ *
+ *   test status of errors on man page
+ *
+ *   EFAULT             v (detect unmapped hole or invalid pointer)
+ *   EINVAL             v (invalid arguments)
+ *   ENOMEM             can't check because it's difficult to create no-memory
+ *   EIO                can't check because we don't have N-node NUMA system
+ *                      (only we can do is simulate 1-node NUMA)
+ */
+
+static struct test_case tcase[] = {
+        { // case00
+                .policy         = MPOL_DEFAULT,
+                .from_node      = NONE,
+                .ret            = 0,
+                .err            = 0,
+        },
+        { // case01
+                .policy         = MPOL_DEFAULT,
+                .from_node      = SELF, // target exists
+                .ret            = -1,
+                .err            = EINVAL,
+        },
+        { // case02
+                .policy         = MPOL_BIND,
+                .from_node      = NONE, // no target
+                .ret            = -1,
+                .err            = EINVAL,
+        },
+       { // case03
+                .policy         = MPOL_BIND,
+                .from_node      = SELF,
+                .ret            = 0,
+                .err            = 0,
+        },
+        { // case04
+                .policy         = MPOL_INTERLEAVE,
+                .from_node      = NONE, // no target
+                .ret            = -1,
+                .err            = EINVAL,
+        },
+        { // case05
+                .policy         = MPOL_INTERLEAVE,
+                .from_node      = SELF,
+                .ret            = 0,
+                .err            = 0,
+        },
+        { // case06
+                .policy         = MPOL_PREFERRED,
+                .from_node      = NONE,
+                .ret            = 0,
+                .err            = 0,
+        },
+        { // case07
+                .policy         = MPOL_PREFERRED,
+                .from_node      = SELF,
+                .ret            = 0,
+                .err            = 0,
+       },
+        { // case08
+                .policy         = -1, // unknown policy
+                .from_node      = NONE,
+                .ret            = -1,
+                .err            = EINVAL,
+        },
+        { // case09
+                .policy         = MPOL_DEFAULT,
+                .from_node      = NONE,
+                .flags          = -1, // invalid flags
+                .ret            = -1,
+                .err            = EINVAL,
+        },
+        { // case10
+                .ttype          = INVALID_POINTER,
+                .policy         = MPOL_DEFAULT,
+                .from_node      = NONE,
+                .ret            = -1,
+                .err            = EFAULT,
+        },
+};
+
+#define MEM_LENGTH              (4 * 1024 * 1024)
+/*
+ * do_test()
+ *
+ *   Input  : TestCase Data
+ *   Return : RESULT_OK(0), RESULT_NG(1)
+ *
+ */
+
+static int do_test(struct test_case *tc) {
+        int sys_ret;
+        int sys_errno;
+        int result = RESULT_OK;
+        int rc, policy, cmp_ok = 1;
+        char *p = NULL;
+        nodemask_t nodemask, getnodemask;
+        unsigned long maxnode = NUMA_NUM_NODES;
+        unsigned long len = MEM_LENGTH;
+
+        /* We assume that there is only one node(node0). */
+        nodemask_zero(&nodemask);
+        nodemask_set(&nodemask, 0);
+        nodemask_zero(&getnodemask);
+
+        /*
+         * mmap memory
+         */
+        p = mmap(NULL, len, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS,0, 
0);
+        if (p == (void*)-1) {
+               tst_resm(TFAIL, "malloc failed - errno = %d : %s",TEST_ERRNO, 
strerror(TEST_ERRNO));
+               cleanup();
+                tst_exit();
+        }
+        if(tc->ttype == INVALID_POINTER)
+                p = (char*)0xc0000000;
+/*
+         * Execute system call
+         */
+        errno = 0;
+        if (tc->from_node == NONE)
+                TEST(sys_ret = syscall(__NR_mbind, p, len, tc->policy,NULL, 0, 
tc->flags));
+        else
+                TEST(sys_ret = syscall(__NR_mbind, p, len, 
tc->policy,&nodemask, maxnode, tc->flags));
+        sys_errno = errno;
+        if (sys_ret < 0)
+                goto TEST_END;
+
+        /*
+         * Check policy of the allocated memory
+         */
+        TEST(rc = syscall(__NR_get_mempolicy, &policy, &getnodemask, 
maxnode,p, MPOL_F_ADDR));
+        if (rc < 0) {
+               tst_resm(TFAIL, "get_mempolicy failed - errno = %d : 
%s",TEST_ERRNO, strerror(TEST_ERRNO));
+                result = 1;
+                tst_exit();
+        }
+
+// When policy equals MPOL_DEFAULT, then get_mempolicy not return node
+        if (tc->policy == MPOL_DEFAULT)
+               nodemask_zero(&nodemask);
+       cmp_ok = ((tc->policy == policy) && 
nodemask_equal(&nodemask,&getnodemask));
+        if (opt_debug) {
+               nodemask_dump("nodemask Expect:", &nodemask);
+               nodemask_dump("nodemask Result:", &getnodemask);
+               tst_resm(TINFO,"policy E:%d R:%d", tc->policy, policy);
+        }
+
+
+TEST_END:
+        /*
+         * Check results
+         */
+        result |= ((sys_errno != tc->err) || (!cmp_ok));
+        PRINT_RESULT_CMP(0, tc->ret, tc->err, sys_ret, sys_errno, cmp_ok);
+        return result;
+}
+
+/*
+ * usage()
+ */
+static void usage(char *progname) {
+       tst_resm(TINFO,"usage: %s [options]", progname);
+       tst_resm(TINFO,"This is a regression test program of %s system 
call.",SYSCALL_NAME);
+       tst_resm(TINFO,"options:");
+       tst_resm(TINFO,"    -d --debug           Show debug messages");
+        tst_resm(TINFO,"    -h --help            Show this message");
+       tst_resm(TINFO,"NG");
+        exit(1);
+}
+
+
+
+
+
+int main(int ac, char **av) {
+       int result = 0;
+       int lc, i;                 /* loop counter */
+       char *msg;              /* message returned from parse_opts */
+
+       struct option long_options[] = {
+                { "debug", no_argument, 0, 'd' },
+                { "help",  no_argument, 0, 'h' },
+                { NULL, 0, NULL, 0 }
+       };
+       
+        /* parse standard options */
+       if ((msg = parse_opts(ac, av, (option_t *)NULL, NULL)) != (char *)NULL){
+               tst_brkm(TBROK, cleanup, "OPTION PARSING ERROR - %s", msg);
+               tst_exit();
+       }
+
+        setup();
+
+       progname = strchr(av[0],'/');
+       progname = (progname ? progname + 1 : av[0]);
+
+        /* Check looping state if -i option given */
+        for (lc = 0; TEST_LOOPING(lc); ++lc) {
+                Tst_count = 0;
+                for (testno = 0; testno < TST_TOTAL; ++testno) {
+                       TEST(getopt_long(ac, av, "dh", long_options, NULL));
+                       while (TEST_RETURN != -1){
+                               switch(TEST_RETURN) {
+                               case 'd':
+                                       opt_debug = 1;
+                                       break;
+                               default:
+                                       usage(progname);
+                               }
+                       } /* end of while */
+                       if(ac != optind) {
+                               tst_resm(TFAIL, "Options are not match - errno 
= %d : %s",TEST_ERRNO, strerror(TEST_ERRNO));
+                               usage(progname);
+                               cleanup();
+                               tst_exit();
+                       }
+                       
+                       /*
+                        * Execute test
+                        */
+                       for (i = 0; i < (int)(sizeof(tcase) / 
sizeof(tcase[0])); i++) {
+                               int ret;
+                               tst_resm(TINFO,"(case%02d) START", i);
+                               ret = do_test(&tcase[i]);
+                               tst_resm(TINFO,"(case%02d) END => %s", i, ( 
TEST_RETURN== 0) ? "OK" : "NG");
+                               result |= ret;
+                       }
+
+                        /*
+                        * Check results
+                        */
+                       switch(result) {
+                       case RESULT_OK:
+                                       tst_resm(TPASS, "mbind call succeeded 
--OK-- ");
+
+                       default:
+                               tst_resm(TFAIL, "%s failed - errno = %d : %s 
--NG--", TCID, TEST_ERRNO, strerror(TEST_ERRNO));
+                               cleanup();
+                               tst_exit();
+                       }
+
+
+                }
+        }      
+        cleanup();
+       tst_exit();
+}
+
--- ltp-full-20090531.orig/runtest/syscalls     2009-06-12 16:11:03.000000000 
+0530
+++ ltp-full-20090531/runtest/syscalls  2009-06-12 16:59:58.000000000 +0530
@@ -506,6 +506,8 @@ lstat03_64 lstat03_64
 
 mallopt01 mallopt01
 
+mbind01 mbind01
+
 memset01 memset01
 memcmp01 memcmp01
 memcpy01 memcpy01

---
Regards--
Manas


------------------------------------------------------------------------------
Crystal Reports - New Free Runtime and 30 Day Trial
Check out the new simplified licensing option that enables unlimited
royalty-free distribution of the report engine for externally facing 
server and web deployment.
http://p.sf.net/sfu/businessobjects
_______________________________________________
Ltp-list mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/ltp-list

Reply via email to