[rtems-examples commit] posix_api/psx_example_3/test3.c: Clean up and allow to build on Linux
Joel Sherrill
joel at rtems.org
Thu Feb 24 23:04:33 UTC 2022
Module: rtems-examples
Branch: master
Commit: ca4b4e78ee29d2aa5b42058d05ce8068041852aa
Changeset: http://git.rtems.org/rtems-examples/commit/?id=ca4b4e78ee29d2aa5b42058d05ce8068041852aa
Author: Joel Sherrill <joel at rtems.org>
Date: Fri Aug 20 15:59:44 2021 -0500
posix_api/psx_example_3/test3.c: Clean up and allow to build on Linux
---
posix_api/psx_example_3/test3.c | 45 +++++++++++++++++++++++++++++------------
1 file changed, 32 insertions(+), 13 deletions(-)
diff --git a/posix_api/psx_example_3/test3.c b/posix_api/psx_example_3/test3.c
index d4d258b..705a0aa 100644
--- a/posix_api/psx_example_3/test3.c
+++ b/posix_api/psx_example_3/test3.c
@@ -1,21 +1,25 @@
#include <sched.h>
-#include <bsp.h>
#include <stdlib.h>
#include <stdio.h>
#include <pthread.h>
- pthread_mutex_t mutex;
- pthread_cond_t cond;
- struct timespec timeout;
- struct sched_param param;
- pthread_attr_t attr;
-
+pthread_mutex_t mutex;
+pthread_cond_t cond;
+
void * print_hello(void * arg)
{
+ struct timespec now;
+ struct timespec timeout;
+
printf("<child>: Hello World! task with max priority \n");
- clock_gettime( CLOCK_REALTIME, &timeout );
- timeout.tv_sec += 3;
- timeout.tv_nsec = 0;
+ clock_gettime( CLOCK_REALTIME, &now );
+
+ printf("\nnow tv_sec = %d, tv_nsec = %d\n", now.tv_sec, now.tv_nsec);
+
+ timeout.tv_sec = now.tv_sec + 3;
+ timeout.tv_nsec = now.tv_nsec;
+
+ printf("timeout tv_sec = %d, tv_nsec = %d\n", timeout.tv_sec, timeout.tv_nsec);
printf("The task is coming to enter in a timed wait\n");
pthread_cond_timedwait(&cond, &mutex, &timeout);
printf("The task is coming out from the timed wait \n");
@@ -29,10 +33,15 @@ void * print_hello_a(void * arg)
}
-void *POSIX_Init()
+int main(int argc, char **argv)
{
- pthread_t child1;
- pthread_t child2;
+ pthread_attr_t attr;
+ pthread_t child1;
+ pthread_t child2;
+ struct sched_param param;
+
+ (void) argc;
+ (void) argv;
pthread_attr_init(&attr);
pthread_attr_setschedpolicy(&attr, SCHED_FIFO);
@@ -71,6 +80,15 @@ void *POSIX_Init()
exit(0);
}
+
+#if defined(__rtems__)
+#include <bsp.h>
+
+static void *POSIX_Init()
+{
+ return (void *)main(0, NULL);
+}
+
#define CONFIGURE_APPLICATION_NEEDS_CONSOLE_DRIVER
#define CONFIGURE_APPLICATION_NEEDS_CLOCK_DRIVER
@@ -79,6 +97,7 @@ void *POSIX_Init()
#define CONFIGURE_INIT
#include <rtems/confdefs.h>
+#endif
More information about the vc
mailing list