-
Notifications
You must be signed in to change notification settings - Fork 220
/
Copy pathosapi-select.h
157 lines (144 loc) · 5.43 KB
/
osapi-select.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
/*
* NASA Docket No. GSC-18,370-1, and identified as "Operating System Abstraction Layer"
*
* Copyright (c) 2019 United States Government as represented by
* the Administrator of the National Aeronautics and Space Administration.
* All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/**
* @file osapi-select.h
*/
#ifndef OSAPI_SELECT_H
#define OSAPI_SELECT_H
#include "osconfig.h"
#include "common_types.h"
/**
* @brief An abstract structure capable of holding several OSAL IDs
*
* This is part of the select API and is manipulated using the
* related API calls. It should not be modified directly by applications.
*
* @sa OS_SelectFdZero(), OS_SelectFdAdd(), OS_SelectFdClear(), OS_SelectFdIsSet()
*/
typedef struct
{
uint8 object_ids[(OS_MAX_NUM_OPEN_FILES + 7) / 8];
} OS_FdSet;
/**
* @brief For the OS_SelectSingle() function's in/out StateFlags parameter,
* the state(s) of the stream and the result of the select is a combination
* of one or more of these states.
*
* @sa OS_SelectSingle()
*/
typedef enum
{
OS_STREAM_STATE_BOUND = 0x01, /**< @brief whether the stream is bound */
OS_STREAM_STATE_CONNECTED = 0x02, /**< @brief whether the stream is connected */
OS_STREAM_STATE_READABLE = 0x04, /**< @brief whether the stream is readable */
OS_STREAM_STATE_WRITABLE = 0x08, /**< @brief whether the stream is writable */
} OS_StreamState_t;
/** @defgroup OSAPISelect OSAL Select APIs
* @{
*/
/*-------------------------------------------------------------------------------------*/
/**
* @brief Wait for events across multiple file handles
*
* Wait for any of the given sets of IDs to be become readable or writable
*
* This function will block until any of the following occurs:
* - At least one OSAL ID in the ReadSet is readable
* - At least one OSAL ID in the WriteSet is writable
* - The timeout has elapsed
*
* The sets are input/output parameters. On entry, these indicate the
* file handle(s) to wait for. On exit, these are set to the actual
* file handle(s) that have activity.
*
* If the timeout occurs this returns an error code and all output sets
* should be empty.
*
* @note This does not lock or otherwise protect the file handles in the
* given sets. If a filehandle supplied via one of the FdSet arguments
* is closed or modified by another while this function is in progress,
* the results are undefined. Because of this limitation, it is recommended
* to use OS_SelectSingle() whenever possible.
*
* @return Execution status, see @ref OSReturnCodes
*/
int32 OS_SelectMultiple(OS_FdSet *ReadSet, OS_FdSet *WriteSet, int32 msecs);
/*-------------------------------------------------------------------------------------*/
/**
* @brief Wait for events on a single file handle
*
* Wait for a single OSAL filehandle to change state
*
* This function can be used to wait for a single OSAL stream ID
* to become readable or writable. On entry, the "StateFlags"
* parameter should be set to the desired state (OS_STREAM_STATE_READABLE
* and/or OS_STREAM_STATE_WRITABLE) and upon return the flags
* will be set to the state actually detected.
*
* As this operates on a single ID, the filehandle is protected
* during this call, such that another thread accessing the same
* handle will return an error. However, it is important to note that
* once the call returns then other threads may then also read/write
* and affect the state before the current thread can service it.
*
* To mitigate this risk the application may prefer to use
* the OS_TimedRead/OS_TimedWrite calls.
*
* @return Execution status, see @ref OSReturnCodes
*/
int32 OS_SelectSingle(osal_id_t objid, uint32 *StateFlags, int32 msecs);
/*-------------------------------------------------------------------------------------*/
/**
* @brief Clear a FdSet structure
*
* After this call the set will contain no OSAL IDs
*
* @return Execution status, see @ref OSReturnCodes
*/
int32 OS_SelectFdZero(OS_FdSet *Set);
/*-------------------------------------------------------------------------------------*/
/**
* @brief Add an ID to an FdSet structure
*
* After this call the set will contain the given OSAL ID
*
* @return Execution status, see @ref OSReturnCodes
*/
int32 OS_SelectFdAdd(OS_FdSet *Set, osal_id_t objid);
/*-------------------------------------------------------------------------------------*/
/**
* @brief Clear an ID from an FdSet structure
*
* After this call the set will no longer contain the given OSAL ID
*
* @return Execution status, see @ref OSReturnCodes
*/
int32 OS_SelectFdClear(OS_FdSet *Set, osal_id_t objid);
/*-------------------------------------------------------------------------------------*/
/**
* @brief Check if an FdSet structure contains a given ID
*
* @return Boolean set status
* @retval true FdSet structure contains ID
* @retval false FDSet structure does not contain ID
*/
bool OS_SelectFdIsSet(OS_FdSet *Set, osal_id_t objid);
/**@}*/
#endif