FreeCalypso > hg > ffs-editor
comparison src/nucleus/smse.c @ 0:92470e5d0b9e
src: partial import from FC Selenite
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Fri, 15 May 2020 01:28:16 +0000 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:92470e5d0b9e |
---|---|
1 /*************************************************************************/ | |
2 /* */ | |
3 /* Copyright Mentor Graphics Corporation 2002 */ | |
4 /* All Rights Reserved. */ | |
5 /* */ | |
6 /* THIS WORK CONTAINS TRADE SECRET AND PROPRIETARY INFORMATION WHICH IS */ | |
7 /* THE PROPERTY OF MENTOR GRAPHICS CORPORATION OR ITS LICENSORS AND IS */ | |
8 /* SUBJECT TO LICENSE TERMS. */ | |
9 /* */ | |
10 /*************************************************************************/ | |
11 | |
12 /*************************************************************************/ | |
13 /* */ | |
14 /* FILE NAME VERSION */ | |
15 /* */ | |
16 /* smse.c Nucleus PLUS 1.14 */ | |
17 /* */ | |
18 /* COMPONENT */ | |
19 /* */ | |
20 /* SM - Semaphore Management */ | |
21 /* */ | |
22 /* DESCRIPTION */ | |
23 /* */ | |
24 /* This file contains the error checking routines for the */ | |
25 /* supplemental functions of the Semaphore component. This permits */ | |
26 /* easy removal of error checking logic when it is not needed. */ | |
27 /* */ | |
28 /* DATA STRUCTURES */ | |
29 /* */ | |
30 /* None */ | |
31 /* */ | |
32 /* FUNCTIONS */ | |
33 /* */ | |
34 /* SMSE_Reset_Semaphore Reset a semaphore */ | |
35 /* */ | |
36 /* DEPENDENCIES */ | |
37 /* */ | |
38 /* cs_extr.h Common Service functions */ | |
39 /* tc_extr.h Thread Control functions */ | |
40 /* sm_extr.h Semaphore functions */ | |
41 /* */ | |
42 /* HISTORY */ | |
43 /* */ | |
44 /* DATE REMARKS */ | |
45 /* */ | |
46 /* 03-01-1994 Created initial version 1.1 from */ | |
47 /* routines originally in core */ | |
48 /* error checking file */ | |
49 /* */ | |
50 /* 03-18-1994 Verified version 1.1 */ | |
51 /* 04-17-1996 updated to version 1.2 */ | |
52 /* 03-24-1998 Released version 1.3 */ | |
53 /* 04-17-2002 Released version 1.13m */ | |
54 /* 11-07-2002 Released version 1.14 */ | |
55 /*************************************************************************/ | |
56 #define NU_SOURCE_FILE | |
57 | |
58 | |
59 #include "cs_extr.h" /* Common service functions */ | |
60 #include "tc_extr.h" /* Thread control functions */ | |
61 #include "sm_extr.h" /* Semaphore functions */ | |
62 | |
63 | |
64 | |
65 /*************************************************************************/ | |
66 /* */ | |
67 /* FUNCTION */ | |
68 /* */ | |
69 /* SMSE_Reset_Semaphore */ | |
70 /* */ | |
71 /* DESCRIPTION */ | |
72 /* */ | |
73 /* This function performs error checking on the parameters supplied */ | |
74 /* to the reset semaphore function. */ | |
75 /* */ | |
76 /* CALLED BY */ | |
77 /* */ | |
78 /* Application */ | |
79 /* */ | |
80 /* CALLS */ | |
81 /* */ | |
82 /* SMS_Reset_Semaphore Actual reset semaphore func. */ | |
83 /* */ | |
84 /* INPUTS */ | |
85 /* */ | |
86 /* semaphore_ptr Semaphore control block ptr */ | |
87 /* initial_count Initial count to reset the */ | |
88 /* semaphore to */ | |
89 /* */ | |
90 /* OUTPUTS */ | |
91 /* */ | |
92 /* NU_INVALID_SEMAPHORE Invalid semaphore pointer */ | |
93 /* */ | |
94 /* HISTORY */ | |
95 /* */ | |
96 /* DATE REMARKS */ | |
97 /* */ | |
98 /* 03-01-1993 Created initial version 1.0 */ | |
99 /* 04-19-1993 Verified version 1.0 */ | |
100 /* 03-01-1994 Modified function interface, */ | |
101 /* resulting in version 1.1 */ | |
102 /* */ | |
103 /* 03-18-1994 Verified version 1.1 */ | |
104 /* */ | |
105 /*************************************************************************/ | |
106 STATUS SMSE_Reset_Semaphore(NU_SEMAPHORE *semaphore_ptr, | |
107 UNSIGNED initial_count) | |
108 { | |
109 | |
110 SM_SCB *semaphore; /* Semaphore control blk ptr */ | |
111 STATUS status; /* Completion status */ | |
112 | |
113 | |
114 /* Move input semaphore pointer into internal pointer. */ | |
115 semaphore = (SM_SCB *) semaphore_ptr; | |
116 | |
117 /* Determine if the semaphore pointer is valid. */ | |
118 if ((semaphore) && (semaphore -> sm_id == SM_SEMAPHORE_ID)) | |
119 | |
120 /* Semaphore pointer is valid, call function to reset it. */ | |
121 status = SMS_Reset_Semaphore(semaphore_ptr, initial_count); | |
122 | |
123 else | |
124 | |
125 /* Semaphore pointer is invalid, indicate in completion status. */ | |
126 status = NU_INVALID_SEMAPHORE; | |
127 | |
128 /* Return completion status. */ | |
129 return(status); | |
130 } | |
131 | |
132 | |
133 | |
134 |