Contiki-NG
Toggle main menu visibility
Loading...
Searching...
No Matches
psock.h
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2004, Swedish Institute of Computer Science.
3
* All rights reserved.
4
*
5
* Redistribution and use in source and binary forms, with or without
6
* modification, are permitted provided that the following conditions
7
* are met:
8
* 1. Redistributions of source code must retain the above copyright
9
* notice, this list of conditions and the following disclaimer.
10
* 2. Redistributions in binary form must reproduce the above copyright
11
* notice, this list of conditions and the following disclaimer in the
12
* documentation and/or other materials provided with the distribution.
13
* 3. Neither the name of the Institute nor the names of its contributors
14
* may be used to endorse or promote products derived from this software
15
* without specific prior written permission.
16
*
17
* THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
18
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20
* ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
21
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27
* SUCH DAMAGE.
28
*
29
* This file is part of the Contiki operating system.
30
*
31
* Author: Adam Dunkels <adam@sics.se>
32
*
33
*/
34
35
/**
36
* \addtogroup uip
37
* @{
38
*/
39
40
/**
41
* \defgroup psock Protosockets library
42
* @{
43
*
44
* The protosocket library provides an interface to the uIP stack that is
45
* similar to the traditional BSD socket interface. Unlike programs
46
* written for the ordinary uIP event-driven interface, programs
47
* written with the protosocket library are executed in a sequential
48
* fashion and does not have to be implemented as explicit state
49
* machines.
50
*
51
* Protosockets only work with TCP connections.
52
*
53
* The protosocket library uses \ref pt protothreads to provide
54
* sequential control flow. This makes the protosockets lightweight in
55
* terms of memory, but also means that protosockets inherits the
56
* functional limitations of protothreads. Each protosocket lives only
57
* within a single function block. Automatic variables (stack
58
* variables) are not necessarily retained across a protosocket
59
* library function call.
60
*
61
* \note Because the protosocket library uses protothreads, local variables
62
* will not always be saved across a call to a protosocket library
63
* function. It is therefore advised that local variables are used
64
* with extreme care.
65
*
66
* The protosocket library provides functions for sending data without
67
* having to deal with retransmissions and acknowledgements, as well
68
* as functions for reading data without having to deal with data
69
* being split across more than one TCP segment.
70
*
71
* Because each protosocket runs as a protothread, the protosocket has to be
72
* started with a call to PSOCK_BEGIN() at the start of the function
73
* in which the protosocket is used. Similarly, the protosocket protothread can
74
* be terminated by a call to PSOCK_EXIT().
75
*
76
*/
77
78
/**
79
* \file
80
* Protosocket library header file
81
* \author
82
* Adam Dunkels <adam@sics.se>
83
*
84
*/
85
86
#ifndef PSOCK_H_
87
#define PSOCK_H_
88
89
#include "contiki.h"
90
#include "contiki-lib.h"
91
#include "contiki-net.h"
92
93
/*
94
* The structure that holds the state of a buffer.
95
*
96
* This structure holds the state of a uIP buffer. The structure has
97
* no user-visible elements, but is used through the functions
98
* provided by the library.
99
*
100
*/
101
struct
psock_buf {
102
uint8_t *ptr;
103
unsigned
short
left;
104
};
105
106
/**
107
* The representation of a protosocket.
108
*
109
* The protosocket structure is an opaque structure with no user-visible
110
* elements.
111
*/
112
struct
psock
{
113
const
uint8_t *sendptr;
/* Pointer to the next data to be sent. */
114
uint8_t *readptr;
/* Pointer to the next data to be read. */
115
116
uint8_t *bufptr;
/* Pointer to the buffer used for buffering
117
incoming data. */
118
struct
psock_buf buf;
/* The structure holding the state of the
119
input buffer. */
120
unsigned
int
bufsize;
/* The size of the input buffer. */
121
122
uint16_t sendlen;
/* The number of bytes left to be sent. */
123
uint16_t readlen;
/* The number of bytes left to be read. */
124
125
struct
pt pt, psockpt;
/* Protothreads - one that's using the psock
126
functions, and one that runs inside the
127
psock functions. */
128
unsigned
char
state;
/* The state of the protosocket. */
129
};
130
131
void
psock_init(
struct
psock
*
psock
, uint8_t *buffer,
unsigned
int
buffersize);
132
/**
133
* Initialize a protosocket.
134
*
135
* This macro initializes a protosocket and must be called before the
136
* protosocket is used. The initialization also specifies the input buffer
137
* for the protosocket.
138
*
139
* \param psock (struct psock *) A pointer to the protosocket to be
140
* initialized
141
*
142
* \param buffer (uint8_t *) A pointer to the input buffer for the
143
* protosocket.
144
*
145
* \param buffersize (unsigned int) The size of the input buffer.
146
*
147
* \hideinitializer
148
*/
149
#define PSOCK_INIT(psock, buffer, buffersize) \
150
psock_init(psock, buffer, buffersize)
151
152
/**
153
* Start the protosocket protothread in a function.
154
*
155
* This macro starts the protothread associated with the protosocket and
156
* must come before other protosocket calls in the function it is used.
157
*
158
* \param psock (struct psock *) A pointer to the protosocket to be
159
* started.
160
*
161
* \hideinitializer
162
*/
163
#define PSOCK_BEGIN(psock) PT_BEGIN(&((psock)->pt))
164
165
PT_THREAD
(psock_send(
struct
psock
*
psock
,
const
uint8_t *buf,
unsigned
int
len));
166
/**
167
* Send data.
168
*
169
* This macro sends data over a protosocket. The protosocket protothread blocks
170
* until all data has been sent and is known to have been received by
171
* the remote end of the TCP connection.
172
*
173
* \param psock (struct psock *) A pointer to the protosocket over which
174
* data is to be sent.
175
*
176
* \param data (uint8_t *) A pointer to the data that is to be sent.
177
*
178
* \param datalen (unsigned int) The length of the data that is to be
179
* sent.
180
*
181
* \hideinitializer
182
*/
183
#define PSOCK_SEND(psock, data, datalen) \
184
PT_WAIT_THREAD(&((psock)->pt), psock_send(psock, data, datalen))
185
186
/**
187
* \brief Send a null-terminated string.
188
* \param psock Pointer to the protosocket.
189
* \param str The string to be sent.
190
*
191
* This function sends a null-terminated string over the
192
* protosocket.
193
*
194
* \hideinitializer
195
*/
196
#define PSOCK_SEND_STR(psock, str) \
197
PT_WAIT_THREAD(&((psock)->pt), psock_send(psock, (uint8_t *)str, strlen(str)))
198
199
PT_THREAD
(psock_generator_send(
struct
psock
*
psock
,
200
unsigned
short
(*f)(
void
*),
void
*arg));
201
202
/**
203
* \brief Generate data with a function and send it
204
* \param psock Pointer to the protosocket.
205
* \param generator Pointer to the generator function
206
* \param arg Argument to the generator function
207
*
208
* This function generates data and sends it over the
209
* protosocket. This can be used to dynamically generate
210
* data for a transmission, instead of generating the data
211
* in a buffer beforehand. This function reduces the need for
212
* buffer memory. The generator function is implemented by
213
* the application, and a pointer to the function is given
214
* as an argument with the call to PSOCK_GENERATOR_SEND().
215
*
216
* The generator function should place the generated data
217
* directly in the uip_appdata buffer, and return the
218
* length of the generated data. The generator function is
219
* called by the protosocket layer when the data first is
220
* sent, and once for every retransmission that is needed.
221
*
222
* \hideinitializer
223
*/
224
#define PSOCK_GENERATOR_SEND(psock, generator, arg) \
225
PT_WAIT_THREAD(&((psock)->pt), \
226
psock_generator_send(psock, generator, arg))
227
228
229
/**
230
* Close a protosocket.
231
*
232
* This macro closes a protosocket and can only be called from within the
233
* protothread in which the protosocket lives.
234
*
235
* \param psock (struct psock *) A pointer to the protosocket that is to
236
* be closed.
237
*
238
* \hideinitializer
239
*/
240
#define PSOCK_CLOSE(psock) uip_close()
241
242
PT_THREAD
(psock_readbuf_len(
struct
psock
*
psock
, uint16_t len));
243
/**
244
* Read data until the buffer is full.
245
*
246
* This macro will block waiting for data and read the data into the
247
* input buffer specified with the call to PSOCK_INIT(). Data is read
248
* until the buffer is full..
249
*
250
* \param psock (struct psock *) A pointer to the protosocket from which
251
* data should be read.
252
*
253
* \hideinitializer
254
*/
255
#define PSOCK_READBUF(psock) \
256
PT_WAIT_THREAD(&((psock)->pt), psock_readbuf_len(psock, 1))
257
258
259
/**
260
* Read data until at least len bytes have been read.
261
*
262
* This macro will block waiting for data and read the data into the
263
* input buffer specified with the call to PSOCK_INIT(). Data is read
264
* until the buffer is full or len bytes have been read.
265
*
266
* \param psock (struct psock *) A pointer to the protosocket from which
267
* data should be read.
268
* \param len (uint16_t) The minimum number of bytes to read.
269
*
270
* \hideinitializer
271
*/
272
#define PSOCK_READBUF_LEN(psock, len) \
273
PT_WAIT_THREAD(&((psock)->pt), psock_readbuf_len(psock, len))
274
275
PT_THREAD
(psock_readto(
struct
psock
*
psock
,
unsigned
char
c));
276
/**
277
* Read data up to a specified character.
278
*
279
* This macro will block waiting for data and read the data into the
280
* input buffer specified with the call to PSOCK_INIT(). Data is only
281
* read until the specified character appears in the data stream.
282
*
283
* \param psock (struct psock *) A pointer to the protosocket from which
284
* data should be read.
285
*
286
* \param c (char) The character at which to stop reading.
287
*
288
* \hideinitializer
289
*/
290
#define PSOCK_READTO(psock, c) \
291
PT_WAIT_THREAD(&((psock)->pt), psock_readto(psock, c))
292
293
/**
294
* The length of the data that was previously read.
295
*
296
* This macro returns the length of the data that was previously read
297
* using PSOCK_READTO() or PSOCK_READ().
298
*
299
* \param psock (struct psock *) A pointer to the protosocket holding the data.
300
*
301
* \hideinitializer
302
*/
303
#define PSOCK_DATALEN(psock) psock_datalen(psock)
304
305
uint16_t psock_datalen(
struct
psock
*
psock
);
306
307
/**
308
* Exit the protosocket's protothread.
309
*
310
* This macro terminates the protothread of the protosocket and should
311
* almost always be used in conjunction with PSOCK_CLOSE().
312
*
313
* \sa PSOCK_CLOSE_EXIT()
314
*
315
* \param psock (struct psock *) A pointer to the protosocket.
316
*
317
* \hideinitializer
318
*/
319
#define PSOCK_EXIT(psock) PT_EXIT(&((psock)->pt))
320
321
/**
322
* Close a protosocket and exit the protosocket's protothread.
323
*
324
* This macro closes a protosocket and exits the protosocket's protothread.
325
*
326
* \param psock (struct psock *) A pointer to the protosocket.
327
*
328
* \hideinitializer
329
*/
330
#define PSOCK_CLOSE_EXIT(psock) \
331
do { \
332
PSOCK_CLOSE(psock); \
333
PSOCK_EXIT(psock); \
334
} while(0)
335
336
/**
337
* Declare the end of a protosocket's protothread.
338
*
339
* This macro is used for declaring that the protosocket's protothread
340
* ends. It must always be used together with a matching PSOCK_BEGIN()
341
* macro.
342
*
343
* \param psock (struct psock *) A pointer to the protosocket.
344
*
345
* \hideinitializer
346
*/
347
#define PSOCK_END(psock) PT_END(&((psock)->pt))
348
349
char
psock_newdata(
struct
psock
*s);
350
351
/**
352
* Check if new data has arrived on a protosocket.
353
*
354
* This macro is used in conjunction with the PSOCK_WAIT_UNTIL()
355
* macro to check if data has arrived on a protosocket.
356
*
357
* \param psock (struct psock *) A pointer to the protosocket.
358
*
359
* \hideinitializer
360
*/
361
#define PSOCK_NEWDATA(psock) psock_newdata(psock)
362
363
/**
364
* Wait until a condition is true.
365
*
366
* This macro blocks the protothread until the specified condition is
367
* true. The macro PSOCK_NEWDATA() can be used to check if new data
368
* arrives when the protosocket is waiting.
369
*
370
* Typically, this macro is used as follows:
371
*
372
\code
373
PT_THREAD(thread(struct psock *s, struct timer *t))
374
{
375
PSOCK_BEGIN(s);
376
377
PSOCK_WAIT_UNTIL(s, PSOCK_NEWDATA(s) || timer_expired(t));
378
379
if(PSOCK_NEWDATA(s)) {
380
PSOCK_READTO(s, '\n');
381
} else {
382
handle_timed_out(s);
383
}
384
385
PSOCK_END(s);
386
}
387
\endcode
388
*
389
* \param psock (struct psock *) A pointer to the protosocket.
390
* \param condition The condition to wait for.
391
*
392
* \hideinitializer
393
*/
394
#define PSOCK_WAIT_UNTIL(psock, condition) \
395
PT_WAIT_UNTIL(&((psock)->pt), (condition));
396
397
#define PSOCK_WAIT_THREAD(psock, condition) \
398
PT_WAIT_THREAD(&((psock)->pt), (condition))
399
400
#endif
/* PSOCK_H_ */
401
402
/** @} */
403
/** @} */
PT_THREAD
#define PT_THREAD(name_args)
Declaration of a protothread.
Definition
pt.h:265
psock
The representation of a protosocket.
Definition
psock.h:112
os
net
ipv6
psock.h
Generated on
for Contiki-NG by
1.17.0