diff options
author | Joel Sherrill <joel.sherrill@OARcorp.com> | 2009-07-22 14:00:09 +0000 |
---|---|---|
committer | Joel Sherrill <joel.sherrill@OARcorp.com> | 2009-07-22 14:00:09 +0000 |
commit | 381a53a801a7c0ab51b363eae52275fd82c2b7d5 (patch) | |
tree | 443ebc31177856f33121e2459259b51145ca0604 /testsuites/psxtests | |
parent | Regenerate. (diff) | |
download | rtems-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/ChangeLog | 4 | ||||
-rw-r--r-- | testsuites/psxtests/psxcancel/init.c | 98 |
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__ */ + |