restructuring work done, and adding about 400 testcases
diff --git a/testcases/kernel/syscalls/setrlimit/setrlimit02.c b/testcases/kernel/syscalls/setrlimit/setrlimit02.c
new file mode 100644
index 0000000..ad5574e
--- /dev/null
+++ b/testcases/kernel/syscalls/setrlimit/setrlimit02.c
@@ -0,0 +1,163 @@
+/*
+ *
+ *   Copyright (c) International Business Machines  Corp., 2001
+ *
+ *   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
+ */
+
+/*
+ * NAME
+ *	setrlimit02.c
+ *
+ * DESCRIPTION
+ *	Testcase to test the different errnos set by setrlimit(2) system call.
+ *
+ * USAGE:  <for command-line>
+ *  setrlimit02 [-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.
+ *
+ * HISTORY
+ *	07/2001 Ported by Wayne Boyer
+ *
+ * RESTRICTIONS
+ *	NONE
+ */
+#include <sys/time.h>
+#include <sys/resource.h>
+#include <unistd.h>
+#include <errno.h>
+#include <linux/fs.h>
+#include "test.h"
+#include "usctest.h"
+
+char *TCID = "setrlimit02";
+int TST_TOTAL = 3;
+extern int Tst_count;
+
+struct rlimit rlim;
+
+void setup();
+void cleanup();
+
+int exp_enos[]={EFAULT, EINVAL, EPERM, 0};
+
+struct test_case_t {
+	int resource;
+	struct rlimit *rlim;
+	int error;
+} TC[] = {
+	/* rlim points outside the process address space - EFAULT */
+	{RLIMIT_NOFILE, (void *)-1, EFAULT},
+
+	/* the resource is invalid - EINVAL */
+	{-1, &rlim, EINVAL},
+
+	/* a non-root user attemps to increase the rlim_max value - EPERM */ 
+	{RLIMIT_NOFILE, &rlim, EPERM}
+};
+
+main(int ac, char **av)
+{
+	int lc;				/* loop counter */
+	char *msg;			/* message returned from parse_opts */
+	int i;
+
+	/* parse standard options */
+	if ((msg = parse_opts(ac, av, (option_t *)NULL, NULL)) != (char *)NULL){
+		tst_brkm(TBROK, tst_exit, "OPTION PARSING ERROR - %s", msg);
+		/*NOTREACHED*/
+	}
+
+	setup();
+
+	/* set up the expected errnos */
+	TEST_EXP_ENOS(exp_enos);
+
+	/* check looping state if -i option given */
+	for (lc = 0; TEST_LOOPING(lc); lc++) {
+
+		/* reset Tst_count in case we are looping. */
+		Tst_count = 0;
+
+		/* loop through the test cases */
+		for (i = 0; i < TST_TOTAL; i++) {
+
+			TEST(setrlimit(TC[i].resource, TC[i].rlim));
+
+			if (TEST_RETURN != -1) {
+				tst_resm(TFAIL, "call succeeded unexpectedly");
+				continue;
+			}
+
+			TEST_ERROR_LOG(TEST_ERRNO);
+
+			if (TEST_ERRNO == TC[i].error) {
+				tst_resm(TPASS, "expected failure - "
+					 "errno = %d : %s", TEST_ERRNO,
+					 strerror(TEST_ERRNO));
+			} else {
+				tst_resm(TFAIL, "unexpected error - %d : %s - "
+					 "expected %d", TEST_ERRNO,
+					 strerror(TEST_ERRNO), TC[i].error);
+			}
+		}
+	}
+	cleanup();
+
+	/*NOTREACHED*/
+}
+
+/*
+ * setup() - performs all ONE TIME setup for this test.
+ */
+void
+setup()
+{
+	/* must run test as a non-root user */
+	if (geteuid() == 0) {
+		tst_brkm(TBROK, tst_exit, "must not run test as root");
+	}
+
+	/* capture signals */
+	tst_sig(NOFORK, DEF_HANDLER, cleanup);
+
+	/* Pause if that option was specified */
+	TEST_PAUSE;
+
+	/* set an illegal value for a non-root user - test #3 - EPERM */
+	rlim.rlim_max = NR_OPEN + 1;
+}
+
+/*
+ * cleanup() - performs all ONE TIME cleanup for this test at
+ *	       completion or premature exit.
+ */
+void
+cleanup()
+{
+	/*
+	 * print timing stats if that option was specified.
+	 * print errno log if that option was specified.
+	 */
+	TEST_CLEANUP;
+
+	/* exit with return code appropriate for results */
+	tst_exit();
+}