source: rtems/testsuites/psxtests/psxenosys/init.c @ 698c2e50

4.115
Last change on this file since 698c2e50 was 698c2e50, checked in by Sebastian Huber <sebastian.huber@…>, on 03/25/14 at 07:06:16

tests/psxtests: Use <rtems/test.h>

  • Property mode set to 100644
File size: 3.4 KB
RevLine 
[8728969]1/*
[b95e69d2]2 *  COPYRIGHT (c) 1989-2010.
[8728969]3 *  On-Line Applications Research Corporation (OAR).
4 *
5 *  The license and distribution terms for this file may be
6 *  found in the file LICENSE in this distribution or at
[c499856]7 *  http://www.rtems.org/license/LICENSE.
[8728969]8 */
9
[cafefbf]10#ifdef HAVE_CONFIG_H
11#include "config.h"
12#endif
13
[9c54ec3]14#include <sys/types.h>
15#include <sys/wait.h>
16#if HAVE_SYS_MMAN_H
17/* POSIX mandates mprotect in sys/mman.h, but newlib doesn't have this */
18#include <sys/mman.h>
19#endif
[b1ddc72]20#include <pthread.h>
[9c54ec3]21
[8728969]22#define CONFIGURE_INIT
23#include "system.h"
[8571262]24#include "tmacros.h"
[8728969]25
26#include <aio.h>
27#include <time.h>
28#include <unistd.h>
29#include <sched.h>
30
[698c2e50]31const char rtems_test_name[] = "PSXENOSYS";
32
[9c54ec3]33#if !HAVE_DECL_MPROTECT
34extern int mprotect(const void *addr, size_t len, int prot);
35#endif
[b1ddc72]36#if !HAVE_DECL_PTHREAD_ATFORK
37extern int pthread_atfork(void (*prepare)(void), void (*parent)(void), void (*child)(void));
38#endif
[9c54ec3]39
[2e7e636f]40void check_enosys(int status);
41
[8728969]42void check_enosys(int status)
43{
[b1274bd9]44  if ( (status == -1) && (errno == ENOSYS) )
[8728969]45    return;
46  puts( "ERROR -- did not return ENOSYS as expected" );
47  rtems_test_exit(0);
48}
49
50void *POSIX_Init(
51  void *argument
52)
53{
54  int             sc;
55
[698c2e50]56  TEST_BEGIN();
[8728969]57
58  puts( "lio_listio -- ENOSYS" );
59  sc = lio_listio( 0, NULL, 0, NULL );
60  check_enosys( sc );
61
62  puts( "aio_suspend -- ENOSYS" );
63  sc = aio_suspend( NULL, 0, NULL );
64  check_enosys( sc );
65
66  puts( "clock_getcpuclockid -- ENOSYS" );
67  sc = clock_getcpuclockid( 0, NULL );
68  check_enosys( sc );
69
70  puts( "clock_getenable_attr -- ENOSYS" );
71  sc = clock_getenable_attr( 0, NULL );
72  check_enosys( sc );
73
74  puts( "clock_setenable_attr -- ENOSYS" );
75  sc = clock_setenable_attr( 0, 0 );
76  check_enosys( sc );
77
78  puts( "execl -- ENOSYS" );
[dd06f5c]79  sc = execl( NULL, NULL, (char*)0 );
[8728969]80  check_enosys( sc );
81
82  puts( "execle -- ENOSYS" );
[dd06f5c]83  sc = execle( NULL, NULL, (char*)0, NULL );
[8728969]84  check_enosys( sc );
85
86  puts( "execlp -- ENOSYS" );
[dd06f5c]87  sc = execlp( NULL, NULL, (char*)0 );
[8728969]88  check_enosys( sc );
89
90  puts( "execv -- ENOSYS" );
91  sc = execv( NULL, NULL );
92  check_enosys( sc );
93
94  puts( "execve -- ENOSYS" );
95  sc = execve( NULL, NULL, NULL );
96  check_enosys( sc );
97
98  puts( "execvp -- ENOSYS" );
99  sc = execvp( NULL, NULL );
100  check_enosys( sc );
101
102  puts( "fork -- ENOSYS" );
103  sc = fork();
104  check_enosys( sc );
105
106  puts( "pthread_atfork -- ENOSYS" );
107  sc = pthread_atfork( NULL, NULL, NULL );
108  check_enosys( sc );
109
110  puts( "pthread_getcpuclockid -- ENOSYS" );
111  sc = pthread_getcpuclockid( 0, NULL );
112  check_enosys( sc );
113
114  puts( "sched_setparam -- ENOSYS" );
115  sc = sched_setparam( 0, NULL );
116  check_enosys( sc );
117
118  puts( "sched_getparam -- ENOSYS" );
119  sc = sched_getparam( 0, NULL );
120  check_enosys( sc );
121
122  puts( "sched_setscheduler -- ENOSYS" );
123  sc = sched_setscheduler( 0, 0, NULL );
124  check_enosys( sc );
125
126  puts( "sched_getscheduler -- ENOSYS" );
[2209eecd]127  sc = sched_getscheduler( 0 );
[8728969]128  check_enosys( sc );
129
130  puts( "wait -- ENOSYS" );
131  sc = wait( NULL );
132  check_enosys( sc );
133
134  puts( "waitpid -- ENOSYS" );
135  sc = waitpid( 0, NULL, 0 );
136  check_enosys( sc );
137
[8571262]138  puts( "mprotect -- stub implementation - OK" );
139  sc = mprotect( NULL, 0, 0 );
140  posix_service_failed( sc, "mprotect" );
141
[4a10519]142  puts( "vfork -- stub implementation - OK" );
143  sc = vfork();
144  if ( sc != -1 ) {
145    puts( "vfork did not return -1" );
146    rtems_test_exit( 0 );
147  }
148
[698c2e50]149  TEST_END();
[8728969]150  rtems_test_exit( 0 );
151
152  return NULL; /* just so the compiler thinks we returned something */
153}
Note: See TracBrowser for help on using the repository browser.