summaryrefslogtreecommitdiffstats
path: root/testsuites/psxtests
diff options
context:
space:
mode:
authorJoel Sherrill <joel.sherrill@OARcorp.com>2009-07-22 14:00:09 +0000
committerJoel Sherrill <joel.sherrill@OARcorp.com>2009-07-22 14:00:09 +0000
commit381a53a801a7c0ab51b363eae52275fd82c2b7d5 (patch)
tree443ebc31177856f33121e2459259b51145ca0604 /testsuites/psxtests
parentRegenerate. (diff)
downloadrtems-381a53a801a7c0ab51b363eae52275fd82c2b7d5.tar.bz2
2009-07-22 Joel Sherrill <joel.sherrill@oarcorp.com>
* psxcancel/init.c: Clean up.
Diffstat (limited to 'testsuites/psxtests')
-rw-r--r--testsuites/psxtests/ChangeLog4
-rw-r--r--testsuites/psxtests/psxcancel/init.c98
2 files changed, 45 insertions, 57 deletions
diff --git a/testsuites/psxtests/ChangeLog b/testsuites/psxtests/ChangeLog
index e88867c07d..f76b132f44 100644
--- a/testsuites/psxtests/ChangeLog
+++ b/testsuites/psxtests/ChangeLog
@@ -1,3 +1,7 @@
+2009-07-22 Joel Sherrill <joel.sherrill@oarcorp.com>
+
+ * psxcancel/init.c: Clean up.
+
2009-07-21 Joel Sherrill <joel.sherrill@oarcorp.com>
* psxmutexattr01/init.c: Make test optional if tools do not support
diff --git a/testsuites/psxtests/psxcancel/init.c b/testsuites/psxtests/psxcancel/init.c
index 4f2d08d068..a2f691fa9a 100644
--- a/testsuites/psxtests/psxcancel/init.c
+++ b/testsuites/psxtests/psxcancel/init.c
@@ -1,10 +1,4 @@
/*
- * Thread Test Program
- *
- * - test of POSIX's pthread_init() function from rtemstask Init()
- *
- * ott@linux.thai.net
- *
* 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.
@@ -17,44 +11,18 @@
#include <stdlib.h>
#include <pthread.h>
#include <sys/time.h>
-
-#ifdef __rtems__
-#include <rtems.h>
-/* configuration information */
-
-#define CONFIGURE_INIT
-
#include <unistd.h>
#include <errno.h>
#include <sched.h>
-#include <bsp.h> /* for device driver prototypes */
-#include <pmacros.h>
-
-rtems_task Init( rtems_task_argument argument);
-/* configuration information */
-
-#define CONFIGURE_APPLICATION_NEEDS_CONSOLE_DRIVER
-#define CONFIGURE_APPLICATION_NEEDS_CLOCK_DRIVER
-
-#define CONFIGURE_MAXIMUM_TASKS 3
-#define CONFIGURE_RTEMS_INIT_TASKS_TABLE
-#define CONFIGURE_EXTRA_TASK_STACKS (3 * RTEMS_MINIMUM_STACK_SIZE)
-
-#define CONFIGURE_MAXIMUM_POSIX_THREADS 5
-#define CONFIGURE_MAXIMUM_POSIX_MUTEXES 5
-#define CONFIGURE_MAXIMUM_POSIX_CONDITION_VARIABLES 5
-
-#include <rtems/console.h>
-#include <rtems/confdefs.h>
-
-#endif /* __rtems__ */
-
-void countTaskAsync(void);
-void countTaskDeferred(void);
+#if defined(__rtems__)
+#include <rtems.h>
+#include <bsp.h>
+#include <pmacros.h>
+#endif
-void countTaskDeferred(void)
+void *countTaskDeferred(void *ignored)
{
int i=0;
int type,state;
@@ -65,10 +33,10 @@ void countTaskDeferred(void)
printf("countTaskDeferred: elapsed time (second): %2d\n", i++ );
sleep(1);
pthread_testcancel();
- }
+ }
}
-void countTaskAsync(void)
+void *countTaskAsync(void *ignored)
{
int i=0;
int type,state;
@@ -78,16 +46,16 @@ void countTaskAsync(void)
while (1) {
printf("countTaskAsync: elapsed time (second): %2d\n", i++ );
sleep(1);
- }
+ }
}
-#ifdef __linux__
-int main(){
+#if defined(__rtems__)
+ void *POSIX_Init(void *ignored)
#else
- rtems_task Init( rtems_task_argument ignored ) {
+ int main(int argc, char **argv)
#endif
-
- pthread_t count;
+{
+ pthread_t task;
int taskparameter = 0;
puts( "\n\n*** POSIX CANCEL TEST ***" );
@@ -95,37 +63,53 @@ int main(){
/* Start countTask deferred */
{
int task_ret;
- task_ret = pthread_create(&count, NULL, (void *) countTaskDeferred, (void *) &taskparameter);
+ task_ret = pthread_create(&task, NULL, countTaskDeferred, &taskparameter);
if (task_ret) {
perror("pthread_create: countTask");
rtems_test_exit(EXIT_FAILURE);
}
/* sleep for 5 seconds, then cancel it */
sleep(5);
- pthread_cancel(count);
- pthread_join(count,NULL);
+ pthread_cancel(task);
+ pthread_join(task, NULL);
}
/* Start countTask asynchronous */
{
int task_ret;
- task_ret = pthread_create(&count, NULL, (void *) countTaskAsync, (void *) &taskparameter);
+ task_ret = pthread_create(&task, NULL, countTaskAsync, &taskparameter);
if (task_ret) {
perror("pthread_create: countTask");
rtems_test_exit(EXIT_FAILURE);
}
/* sleep for 5 seconds, then cancel it */
sleep(5);
- pthread_cancel(count);
- pthread_join(count,NULL);
+ pthread_cancel(task);
+ pthread_join(task, NULL);
}
puts( "*** END OF POSIX CANCEL TEST ***" );
-#ifdef __linux__
- return 0;
-#else
- rtems_test_exit(EXIT_SUCCESS);
-#endif
+ #if defined(__rtems__)
+ rtems_test_exit(EXIT_SUCCESS);
+ return NULL;
+ #else
+ return 0;
+ #endif
}
+
+/* configuration information */
+#if defined(__rtems__)
+
+#define CONFIGURE_APPLICATION_NEEDS_CONSOLE_DRIVER
+#define CONFIGURE_APPLICATION_NEEDS_CLOCK_DRIVER
+
+#define CONFIGURE_MAXIMUM_POSIX_THREADS 2
+#define CONFIGURE_POSIX_INIT_THREAD_TABLE
+
+#define CONFIGURE_INIT
+#include <rtems/confdefs.h>
+
+#endif /* __rtems__ */
+