change log for rtems (2010-06-23)
rtems-vc at rtems.org
rtems-vc at rtems.org
Wed Jun 23 19:13:24 UTC 2010
*jennifer*:
2010-06-23 Jennifer Averett <Jennifer Averett at OARcorp.com>
* Makefile.am, configure.ac: Added test case for calls that check for
an unopened file descriptor.
* psxfile02/.cvsignore, psxfile02/Makefile.am, psxfile02/init.c,
psxfile02/psxfile02.doc, psxfile02/psxfile02.scn: New files.
M 1.268 testsuites/psxtests/ChangeLog
M 1.59 testsuites/psxtests/Makefile.am
M 1.62 testsuites/psxtests/configure.ac
A 1.1 testsuites/psxtests/psxfile02/.cvsignore
A 1.1 testsuites/psxtests/psxfile02/Makefile.am
A 1.1 testsuites/psxtests/psxfile02/init.c
A 1.1 testsuites/psxtests/psxfile02/psxfile02.doc
A 1.1 testsuites/psxtests/psxfile02/psxfile02.scn
diff -u rtems/testsuites/psxtests/ChangeLog:1.267 rtems/testsuites/psxtests/ChangeLog:1.268
--- rtems/testsuites/psxtests/ChangeLog:1.267 Tue Jun 22 12:44:01 2010
+++ rtems/testsuites/psxtests/ChangeLog Wed Jun 23 13:43:23 2010
@@ -1,3 +1,10 @@
+2010-06-23 Jennifer Averett <Jennifer Averett at OARcorp.com>
+
+ * Makefile.am, configure.ac: Added test case for calls that check for
+ an unopened file descriptor.
+ * psxfile02/.cvsignore, psxfile02/Makefile.am, psxfile02/init.c,
+ psxfile02/psxfile02.doc, psxfile02/psxfile02.scn: New files.
+
2010-06-22 Jennifer Averett <Jennifer.Averett at OARcorp.com>
* psxtime/psxtime.scn, psxtime/test.c: Add a normal case with second
diff -u rtems/testsuites/psxtests/Makefile.am:1.58 rtems/testsuites/psxtests/Makefile.am:1.59
--- rtems/testsuites/psxtests/Makefile.am:1.58 Mon Dec 28 10:43:10 2009
+++ rtems/testsuites/psxtests/Makefile.am Wed Jun 23 13:43:23 2010
@@ -19,8 +19,8 @@
endif
## File IO tests
-SUBDIRS += psxfile01 psxreaddir psxstat psxmount psx13 psxchroot01 \
- psxpasswd01
+SUBDIRS += psxfile01 psxfile02 psxreaddir psxstat psxmount psx13 \
+ psxchroot01 psxpasswd01
## Until sys/uio.h is moved to libcsupport, we have to have networking
## enabled to support readv and writev. Hopefully this is a temporary
diff -u rtems/testsuites/psxtests/configure.ac:1.61 rtems/testsuites/psxtests/configure.ac:1.62
--- rtems/testsuites/psxtests/configure.ac:1.61 Sat May 29 00:31:45 2010
+++ rtems/testsuites/psxtests/configure.ac Wed Jun 23 13:43:23 2010
@@ -87,6 +87,7 @@
psxfatal01/Makefile
psxfatal02/Makefile
psxfile01/Makefile
+psxfile02/Makefile
psxhdrs/Makefile
psxintrcritical01/Makefile
psxitimer/Makefile
diff -u /dev/null rtems/testsuites/psxtests/psxfile02/.cvsignore:1.1
--- /dev/null Wed Jun 23 14:13:23 2010
+++ rtems/testsuites/psxtests/psxfile02/.cvsignore Wed Jun 23 13:43:23 2010
@@ -0,0 +1,2 @@
+Makefile
+Makefile.in
diff -u /dev/null rtems/testsuites/psxtests/psxfile02/Makefile.am:1.1
--- /dev/null Wed Jun 23 14:13:24 2010
+++ rtems/testsuites/psxtests/psxfile02/Makefile.am Wed Jun 23 13:43:23 2010
@@ -0,0 +1,26 @@
+##
+## $Id$
+##
+
+MANAGERS = all
+
+rtems_tests_PROGRAMS = psxfile02
+psxfile02_SOURCES = init.c ../../support/src/spin.c
+
+dist_rtems_tests_DATA = psxfile02.scn
+dist_rtems_tests_DATA += psxfile02.doc
+
+include $(RTEMS_ROOT)/make/custom/@RTEMS_BSP at .cfg
+include $(top_srcdir)/../automake/compile.am
+include $(top_srcdir)/../automake/leaf.am
+
+AM_CPPFLAGS += -I$(top_srcdir)/../support/include
+
+LINK_OBJS = $(psxfile02_OBJECTS) $(psxfile02_LDADD)
+LINK_LIBS = $(psxfile02_LDLIBS)
+
+psxfile02$(EXEEXT): $(psxfile02_OBJECTS) $(psxfile02_DEPENDENCIES)
+ @rm -f psxfile02$(EXEEXT)
+ $(make-exe)
+
+include $(top_srcdir)/../automake/local.am
diff -u /dev/null rtems/testsuites/psxtests/psxfile02/init.c:1.1
--- /dev/null Wed Jun 23 14:13:24 2010
+++ rtems/testsuites/psxtests/psxfile02/init.c Wed Jun 23 13:43:24 2010
@@ -0,0 +1,152 @@
+/*
+ * COPYRIGHT (c) 1989-2010.
+ * On-Line Applications Research Corporation (OAR).
+ *
+ * The license and distribution terms for this file may be
+ * found in the file LICENSE in this distribution or at
+ * http://www.rtems.com/license/LICENSE.
+ *
+ * $Id$
+ */
+#include <stdio.h>
+#include <sys/uio.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <unistd.h>
+#include <errno.h>
+#include <string.h>
+#include <ctype.h>
+#include <rtems/imfs.h>
+
+#include <rtems.h>
+#include <rtems/libio.h>
+
+#include <tmacros.h>
+#include "test_support.h"
+
+int _fcntl_r(
+ struct _reent *ptr __attribute__((unused)),
+ int fd,
+ int cmd,
+ int arg
+);
+
+off_t _lseek_r(
+ struct _reent *ptr __attribute__((unused)),
+ int fd,
+ off_t offset,
+ int whence
+);
+
+
+
+rtems_task Init(
+ rtems_task_argument argument
+)
+{
+ int fd;
+ struct stat stat_buff;
+ struct iovec vec[4];
+ off_t res;
+ int status;
+
+ puts( "\n\n*** PSXFILE02 TEST ***" );
+
+ /*
+ * Simple open case where the file is created.
+ */
+ puts( "mkdir /tmp" );
+ status = mkdir( "/tmp", S_IRWXU );
+ rtems_test_assert( !status );
+
+ puts( "open /tmp/j" );
+ fd = open( "/tmp/j", O_RDWR|O_CREAT, S_IRWXU|S_IRWXG|S_IRWXO );
+ rtems_test_assert( fd != -1 );
+ printf( "open returned file descriptor %d\n", fd );
+
+ puts( "close /tmp/j" );
+ status = close( fd );
+ rtems_test_assert( !status );
+
+ puts("ftruncate an unopened file");
+ status = ftruncate(fd, 40);
+ rtems_test_assert( status == -1 );
+ printf( "%d: %s\n", errno, strerror( errno ) );
+ rtems_test_assert( errno == EBADF );
+
+ puts("_fcntl_r unopened file");
+ status = _fcntl_r( NULL, fd, F_SETFD, 1 );
+ rtems_test_assert( status == -1 );
+ printf( "%d: %s\n", errno, strerror( errno ) );
+ rtems_test_assert( errno == EBADF );
+
+ puts("fdatasync unopened file");
+ status = fdatasync( fd );
+ rtems_test_assert( status == -1 );
+ printf( "%d: %s\n", errno, strerror( errno ) );
+ rtems_test_assert( errno == EBADF );
+
+ puts("fstat unopened file");
+ status = fstat( fd, &stat_buff );
+ rtems_test_assert( status == -1 );
+ printf( "%d: %s\n", errno, strerror( errno ) );
+ rtems_test_assert( errno == EBADF );
+
+ puts("fsync unopened file");
+ status = fsync( fd );
+ rtems_test_assert( status == -1 );
+ printf( "%d: %s\n", errno, strerror( errno ) );
+ rtems_test_assert( errno == EBADF );
+
+ puts("ioctl unopened file");
+ status = ioctl( fd, 0 );
+ rtems_test_assert( status == -1 );
+ printf( "%d: %s\n", errno, strerror( errno ) );
+ rtems_test_assert( errno == EBADF );
+
+ puts("_lseek_r unopened file");
+ res = _lseek_r (NULL, fd, 0, SEEK_SET);
+ rtems_test_assert( res == -1 );
+ printf( "%d: %s\n", errno, strerror( errno ) );
+ rtems_test_assert( errno == EBADF );
+
+ puts("readv unopened file");
+ status = readv(fd, vec, 4);
+ rtems_test_assert( status == -1 );
+ printf( "%d: %s\n", errno, strerror( errno ) );
+ rtems_test_assert( errno == EBADF );
+
+ puts("writev unopened file");
+ status = writev(fd, vec, 4);
+ rtems_test_assert( status == -1 );
+ printf( "%d: %s\n", errno, strerror( errno ) );
+ rtems_test_assert( errno == EBADF );
+
+ puts("write unopened file");
+ status = write(fd, "1234", 4);
+ rtems_test_assert( status == -1 );
+ printf( "%d: %s\n", errno, strerror( errno ) );
+ rtems_test_assert( errno == EBADF );
+
+
+
+
+ puts( "*** END OF PSXFILE02 TEST ***" );
+
+ rtems_test_exit(0);
+}
+
+/* configuration information */
+
+#define CONFIGURE_APPLICATION_NEEDS_CONSOLE_DRIVER
+#define CONFIGURE_APPLICATION_NEEDS_CLOCK_DRIVER
+#define CONFIGURE_USE_IMFS_AS_BASE_FILESYSTEM
+#define CONFIGURE_LIBIO_MAXIMUM_FILE_DESCRIPTORS 6
+#define CONFIGURE_MAXIMUM_TASKS 1
+#define CONFIGURE_RTEMS_INIT_TASKS_TABLE
+
+#define CONFIGURE_INIT
+
+#include <rtems/confdefs.h>
+/* end of file */
diff -u /dev/null rtems/testsuites/psxtests/psxfile02/psxfile02.doc:1.1
--- /dev/null Wed Jun 23 14:13:24 2010
+++ rtems/testsuites/psxtests/psxfile02/psxfile02.doc Wed Jun 23 13:43:24 2010
@@ -0,0 +1,22 @@
+#
+# $Id$
+#
+# COPYRIGHT (c) 1989-2010.
+# On-Line Applications Research Corporation (OAR).
+#
+# The license and distribution terms for this file may be
+# found in the file LICENSE in this distribution or at
+# http://www.rtems.com/license/LICENSE.
+#
+
+This file describes the directives and concepts tested by this test set.
+
+test set name: psxfile02
+
+directives:
+
+ XXX list them
+
+concepts:
+
++ XXX list them
diff -u /dev/null rtems/testsuites/psxtests/psxfile02/psxfile02.scn:1.1
--- /dev/null Wed Jun 23 14:13:24 2010
+++ rtems/testsuites/psxtests/psxfile02/psxfile02.scn Wed Jun 23 13:43:24 2010
@@ -0,0 +1,26 @@
+*** PSXFILE02 TEST ***
+mkdir /tmp
+open /tmp/j
+open returned file descriptor 3
+close /tmp/j
+ftruncate an unopened file
+9: Bad file number
+_fcntl_r unopened file
+9: Bad file number
+fdatasync unopened file
+9: Bad file number
+fstat unopened file
+9: Bad file number
+fsync unopened file
+9: Bad file number
+ioctl unopened file
+9: Bad file number
+_lseek_r unopened file
+9: Bad file number
+readv unopened file
+9: Bad file number
+writev unopened file
+9: Bad file number
+write unopened file
+9: Bad file number
+*** END OF PSXFILE02 TEST ***
*joel*:
2010-06-23 Joel Sherrill <joel.sherrilL at OARcorp.com>
* libmisc/stackchk/check.c: Clean up to improve coverage.
M 1.2454 cpukit/ChangeLog
M 1.67 cpukit/libmisc/stackchk/check.c
diff -u rtems/cpukit/ChangeLog:1.2453 rtems/cpukit/ChangeLog:1.2454
--- rtems/cpukit/ChangeLog:1.2453 Wed Jun 23 00:01:46 2010
+++ rtems/cpukit/ChangeLog Wed Jun 23 13:18:41 2010
@@ -1,3 +1,7 @@
+2010-06-23 Joel Sherrill <joel.sherrilL at OARcorp.com>
+
+ * libmisc/stackchk/check.c: Clean up to improve coverage.
+
2010-06-23 Chris Johns <chrisj at rtems.org>
PR 1577/filesystem
diff -u rtems/cpukit/libmisc/stackchk/check.c:1.66 rtems/cpukit/libmisc/stackchk/check.c:1.67
--- rtems/cpukit/libmisc/stackchk/check.c:1.66 Sat Apr 10 02:32:13 2010
+++ rtems/cpukit/libmisc/stackchk/check.c Wed Jun 23 13:18:42 2010
@@ -116,12 +116,13 @@
#define Stack_check_usable_stack_size(_the_stack) \
((_the_stack)->size - sizeof(Stack_check_Control))
-/*
- * Do we have an interrupt stack?
- * XXX it would sure be nice if the interrupt stack were also
- * stored in a "stack" structure!
- */
-Stack_Control Stack_check_Interrupt_stack;
+#if (CPU_ALLOCATE_INTERRUPT_STACK == TRUE)
+ /*
+ * Did RTEMS allocate the interrupt stack? If so, put it in
+ * Stack_Control format.
+ */
+ Stack_Control Stack_check_Interrupt_stack;
+#endif
/*
* Fill an entire stack area with BYTE_PATTERN. This will be used
@@ -381,28 +382,28 @@
Stack_Control *stack;
char name[5];
- if ( !the_thread )
- return;
-
- if ( !print_handler )
- return;
+ /*
+ * The pointer passed in for the_thread is guaranteed to be non-NULL from
+ * rtems_iterate_over_all_threads() so no need to check it here.
+ */
/*
* Obtain interrupt stack information
*/
-
- if (the_thread == (Thread_Control *) -1) {
- if (Stack_check_Interrupt_stack.area) {
+ #if (CPU_ALLOCATE_INTERRUPT_STACK == TRUE)
+ if (the_thread == (Thread_Control *) -1) {
+ if (!Stack_check_Interrupt_stack.area)
+ return;
stack = &Stack_check_Interrupt_stack;
the_thread = 0;
current = 0;
+ } else
+ #else
+ {
+ stack = &the_thread->Start.Initial_stack;
+ current = (void *)_CPU_Context_Get_SP( &the_thread->Registers );
}
- else
- return;
- } else {
- stack = &the_thread->Start.Initial_stack;
- current = (void *)_CPU_Context_Get_SP( &the_thread->Registers );
- }
+ #endif
low = Stack_check_usable_stack_start(stack);
size = Stack_check_usable_stack_size(stack);
@@ -468,6 +469,9 @@
rtems_printk_plugin_t print
)
{
+ if ( !print )
+ return;
+
print_context = context;
print_handler = print;
@@ -479,8 +483,10 @@
/* iterate over all threads and dump the usage */
rtems_iterate_over_all_threads( Stack_check_Dump_threads_usage );
- /* dump interrupt stack info if any */
- Stack_check_Dump_threads_usage((Thread_Control *) -1);
+ #if (CPU_ALLOCATE_INTERRUPT_STACK == TRUE)
+ /* dump interrupt stack info if any */
+ Stack_check_Dump_threads_usage((Thread_Control *) -1);
+ #endif
print_context = NULL;
print_handler = NULL;
--
Generated by Deluxe Loginfo [http://www.codewiz.org/projects/index.html#loginfo] 2.122 by Bernardo Innocenti <bernie at develer.com>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.rtems.org/pipermail/vc/attachments/20100623/ffff1cc0/attachment-0001.html>
More information about the vc
mailing list