OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [rtos/] [ecos-3.0/] [packages/] [kernel/] [current/] [tests/] [ksem1.c] - Blame information for rev 868

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 786 skrzyp
/*=================================================================
2
//
3
//        ksem1.c
4
//
5
//        C API semaphore test 1
6
//
7
//==========================================================================
8
// ####ECOSGPLCOPYRIGHTBEGIN####
9
// -------------------------------------------
10
// This file is part of eCos, the Embedded Configurable Operating System.
11
// Copyright (C) 1998, 1999, 2000, 2001, 2002 Free Software Foundation, Inc.
12
//
13
// eCos is free software; you can redistribute it and/or modify it under
14
// the terms of the GNU General Public License as published by the Free
15
// Software Foundation; either version 2 or (at your option) any later
16
// version.
17
//
18
// eCos is distributed in the hope that it will be useful, but WITHOUT
19
// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
20
// FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
21
// for more details.
22
//
23
// You should have received a copy of the GNU General Public License
24
// along with eCos; if not, write to the Free Software Foundation, Inc.,
25
// 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
26
//
27
// As a special exception, if other files instantiate templates or use
28
// macros or inline functions from this file, or you compile this file
29
// and link it with other works to produce a work based on this file,
30
// this file does not by itself cause the resulting work to be covered by
31
// the GNU General Public License. However the source code for this file
32
// must still be made available in accordance with section (3) of the GNU
33
// General Public License v2.
34
//
35
// This exception does not invalidate any other reasons why a work based
36
// on this file might be covered by the GNU General Public License.
37
// -------------------------------------------
38
// ####ECOSGPLCOPYRIGHTEND####
39
//==========================================================================
40
//#####DESCRIPTIONBEGIN####
41
//
42
// Author(s):     dsm
43
// Contributors:    dsm
44
// Date:          1998-03-20
45
// Description:   Tests basic semaphore functionality.
46
//####DESCRIPTIONEND####
47
*/
48
 
49
#include <cyg/hal/hal_arch.h>           // CYGNUM_HAL_STACK_SIZE_TYPICAL
50
 
51
#include <cyg/kernel/kapi.h>
52
 
53
#include <cyg/infra/testcase.h>
54
 
55
#ifdef CYGFUN_KERNEL_API_C
56
 
57
#include "testaux.h"
58
 
59
#define NTHREADS 2
60
#define STACKSIZE CYGNUM_HAL_STACK_SIZE_TYPICAL
61
 
62
static cyg_handle_t thread[NTHREADS];
63
 
64
static cyg_thread thread_obj[NTHREADS];
65
static char stack[NTHREADS][STACKSIZE];
66
 
67
 
68
static cyg_sem_t s0, s1, s2;
69
 
70
static volatile cyg_ucount8 q = 0;
71
 
72
static void entry0( cyg_addrword_t data )
73
{
74
    cyg_count32 val;
75
 
76
    cyg_semaphore_wait(&s0);
77
    CHECK( 1 == q++ );
78
    cyg_semaphore_post(&s1);
79
    cyg_semaphore_wait(&s0);
80
    CHECK( 3 == q++ );
81
    cyg_semaphore_peek(&s0, &val);
82
    CHECK( 0 == val);
83
    CHECK( ! cyg_semaphore_trywait(&s0) );
84
    cyg_semaphore_post(&s0);
85
    CHECK( 4 == q++ );
86
    cyg_semaphore_peek(&s0, &val);
87
    CHECK( 1 == val);
88
    cyg_semaphore_post(&s0);
89
    cyg_semaphore_peek(&s0, &val);
90
    CHECK( 2 == val);
91
    cyg_semaphore_post(&s1);
92
    cyg_semaphore_peek(&s2, &val);
93
    CHECK( 0 == val);
94
    cyg_semaphore_wait(&s2);
95
    CHECK( 6 == q++ );
96
    CYG_TEST_PASS_FINISH("Kernel C API Semaphore 1 OK");
97
}
98
 
99
static void entry1( cyg_addrword_t data )
100
{
101
    cyg_count32 val;
102
 
103
    cyg_semaphore_peek(&s1, &val);
104
    CHECK( 2 == val);
105
    cyg_semaphore_wait(&s1);
106
    cyg_semaphore_peek(&s1, &val);
107
    CHECK( 1 == val);
108
    cyg_semaphore_wait(&s1);
109
    CHECK( 0 == q++ );
110
    cyg_semaphore_peek(&s0, &val);
111
    CHECK( 0 == val);
112
    cyg_semaphore_post(&s0);
113
    cyg_semaphore_wait(&s1);
114
    CHECK( 2 == q++ );
115
    cyg_semaphore_post(&s0);
116
    cyg_semaphore_wait(&s1);
117
    CHECK( 5 == q++ );
118
    cyg_semaphore_peek(&s0, &val);
119
    CHECK( 2 == val);
120
    CHECK( cyg_semaphore_trywait(&s0) );
121
    cyg_semaphore_peek(&s0, &val);
122
    CHECK( 1 == val);
123
    CHECK( cyg_semaphore_trywait(&s0) );
124
    cyg_semaphore_peek(&s0, &val);
125
    CHECK( 0 == val);
126
    cyg_semaphore_post(&s2);
127
    cyg_semaphore_wait(&s0);
128
    CYG_TEST_FAIL_FINISH("Not reached");
129
}
130
 
131
void ksem1_main( void )
132
{
133
    CYG_TEST_INIT();
134
 
135
    cyg_semaphore_init( &s0, 0);
136
    cyg_semaphore_init( &s1, 2);
137
    cyg_semaphore_init( &s2, 0);
138
 
139
    cyg_thread_create(4, entry0 , (cyg_addrword_t)0, "ksem1-0",
140
        (void *)stack[0], STACKSIZE,&thread[0], &thread_obj[0]);
141
    cyg_thread_resume(thread[0]);
142
 
143
    cyg_thread_create(4, entry1 , (cyg_addrword_t)1, "ksem1-1",
144
        (void *)stack[1], STACKSIZE, &thread[1], &thread_obj[1]);
145
    cyg_thread_resume(thread[1]);
146
 
147
    cyg_scheduler_start();
148
 
149
    CYG_TEST_FAIL_FINISH("Not reached");
150
}
151
 
152
externC void
153
cyg_start( void )
154
{
155
    ksem1_main();
156
}
157
 
158
 
159
#else /* def CYGFUN_KERNEL_API_C */
160
externC void
161
cyg_start( void )
162
{
163
    CYG_TEST_INIT();
164
    CYG_TEST_NA("Kernel C API layer disabled");
165
}
166
#endif /* def CYGFUN_KERNEL_API_C */
167
 
168
/* EOF ksem1.c */

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.