source: mainline/uspace/srv/net/socket/socket_core.h@ 60ab6c3

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 60ab6c3 was aadf01e, checked in by Lukas Mejdrech <lukasmejdrech@…>, 15 years ago

Coding style (no functional change)

  • Property mode set to 100644
File size: 9.0 KB
Line 
1/*
2 * Copyright (c) 2009 Lukas Mejdrech
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 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29/** @addtogroup socket
30 * @{
31 */
32
33/** @file
34 * Socket common core.
35 */
36
37#ifndef __NET_SOCKET_CORE_H__
38#define __NET_SOCKET_CORE_H__
39
40#include <sys/types.h>
41
42#include "../include/in.h"
43#include "../include/device.h"
44
45#include "../structures/generic_char_map.h"
46#include "../structures/dynamic_fifo.h"
47#include "../structures/int_map.h"
48#include "../structures/packet/packet.h"
49
50/** Initial size of the received packet queue.
51 */
52#define SOCKET_INITIAL_RECEIVED_SIZE 4
53
54/** Maximum size of the received packet queue.
55 */
56#define SOCKET_MAX_RECEIVED_SIZE 0
57
58/** Initial size of the sockets for acceptance queue.
59 */
60#define SOCKET_INITIAL_ACCEPTED_SIZE 1
61
62/** Maximum size of the sockets for acceptance queue.
63 */
64#define SOCKET_MAX_ACCEPTEDED_SIZE 0
65
66/** Listening sockets' port map key.
67 */
68#define SOCKET_MAP_KEY_LISTENING "L"
69
70/** Type definition of the socket core.
71 * @see socket_core
72 */
73typedef struct socket_core socket_core_t;
74
75/** Type definition of the socket core pointer.
76 * @see socket_core
77 */
78typedef socket_core_t * socket_core_ref;
79
80/** Type definition of the socket port.
81 * @see socket_port
82 */
83typedef struct socket_port socket_port_t;
84
85/** Type definition of the socket port pointer.
86 * @see socket_port
87 */
88typedef socket_port_t * socket_port_ref;
89
90/** Socket core.
91 */
92struct socket_core{
93 /** Socket identifier.
94 */
95 int socket_id;
96 /** Client application phone.
97 */
98 int phone;
99 /** Bound port.
100 */
101 int port;
102 /** Received packets queue.
103 */
104 dyn_fifo_t received;
105 /** Sockets for acceptance queue.
106 */
107 dyn_fifo_t accepted;
108 /** Protocol specific data.
109 */
110 void * specific_data;
111 /** Socket ports map key.
112 */
113 const char * key;
114 /** Length of the Socket ports map key.
115 */
116 size_t key_length;
117};
118
119/** Sockets map.
120 * The key is the socket identifier.
121 */
122INT_MAP_DECLARE(socket_cores, socket_core_t);
123
124/** Bount port sockets map.
125 * The listening socket has the SOCKET_MAP_KEY_LISTENING key identifier whereas the other use the remote addresses.
126 */
127GENERIC_CHAR_MAP_DECLARE(socket_port_map, socket_core_ref);
128
129/** Ports map.
130 * The key is the port number.
131 */
132INT_MAP_DECLARE(socket_ports, socket_port_t);
133
134/** Destroys local sockets.
135 * Releases all buffered packets and calls the release function for each of the sockets.
136 * @param[in] packet_phone The packet server phone to release buffered packets.
137 * @param[in] local_sockets The local sockets to be destroyed.
138 * @param[in,out] global_sockets The global sockets to be updated.
139 * @param[in] socket_release The client release callback function.
140 */
141void socket_cores_release(int packet_phone, socket_cores_ref local_sockets, socket_ports_ref global_sockets, void (*socket_release)(socket_core_ref socket));
142
143/** Binds the socket to the port.
144 * The address port is used if set, a free port is used if not.
145 * @param[in] local_sockets The local sockets to be searched.
146 * @param[in,out] global_sockets The global sockets to be updated.
147 * @param[in] socket_id The new socket identifier.
148 * @param[in] addr The address to be bound to.
149 * @param[in] addrlen The address length.
150 * @param[in] free_ports_start The minimum free port.
151 * @param[in] free_ports_end The maximum free port.
152 * @param[in] last_used_port The last used free port.
153 * @returns EOK on success.
154 * @returns ENOTSOCK if the socket was not found.
155 * @returns EAFNOSUPPORT if the address family is not supported.
156 * @returns EADDRINUSE if the port is already in use.
157 * @returns Other error codes as defined for the socket_bind_free_port() function.
158 * @returns Other error codes as defined for the socket_bind_insert() function.
159 */
160int socket_bind(socket_cores_ref local_sockets, socket_ports_ref global_sockets, int socket_id, void * addr, size_t addrlen, int free_ports_start, int free_ports_end, int last_used_port);
161
162/** Binds the socket to a free port.
163 * The first free port is used.
164 * @param[in,out] global_sockets The global sockets to be updated.
165 * @param[in,out] socket The socket to be bound.
166 * @param[in] free_ports_start The minimum free port.
167 * @param[in] free_ports_end The maximum free port.
168 * @param[in] last_used_port The last used free port.
169 * @returns EOK on success.
170 * @returns ENOTCONN if no free port was found.
171 * @returns Other error codes as defined for the socket_bind_insert() function.
172 */
173int socket_bind_free_port(socket_ports_ref global_sockets, socket_core_ref socket, int free_ports_start, int free_ports_end, int last_used_port);
174
175/** Creates a new socket.
176 * @param[in,out] local_sockets The local sockets to be updated.
177 * @param[in] app_phone The application phone.
178 * @param[in] specific_data The socket specific data.
179 * @param[in,out] socket_id The new socket identifier. A new identifier is chosen if set to zero (0) or negative. A negative identifier is chosen if set to negative.
180 * @returns EOK on success.
181 * @returns EINVAL if the socket_id parameter is NULL.
182 * @returns ENOMEM if there is not enough memory left.
183 */
184int socket_create(socket_cores_ref local_sockets, int app_phone, void * specific_data, int * socket_id);
185
186/** Destroys the socket.
187 * If the socket is bound, the port is released.
188 * Releases all buffered packets, calls the release function and removes the socket from the local sockets.
189 * @param[in] packet_phone The packet server phone to release buffered packets.
190 * @param[in] socket_id The socket identifier.
191 * @param[in,out] local_sockets The local sockets to be updated.
192 * @param[in,out] global_sockets The global sockets to be updated.
193 * @param[in] socket_release The client release callback function.
194 * @returns EOK on success.
195 * @returns ENOTSOCK if the socket is not found.
196 */
197int socket_destroy(int packet_phone, int socket_id, socket_cores_ref local_sockets, socket_ports_ref global_sockets, void (*socket_release)(socket_core_ref socket));
198
199/** Replies the packet or the packet queue data to the application via the socket.
200 * Uses the current message processing fibril.
201 * @param[in] packet The packet to be transfered.
202 * @param[out] length The total data length.
203 * @returns EOK on success.
204 * @returns EBADMEM if the length parameter is NULL.
205 * @returns ENOMEM if there is not enough memory left.
206 * @returns Other error codes as defined for the data_reply() function.
207 */
208int socket_reply_packets(packet_t packet, size_t * length);
209
210/** Finds the bound port socket.
211 * @param[in] global_sockets The global sockets to be searched.
212 * @param[in] port The port number.
213 * @param[in] key The socket key identifier.
214 * @param[in] key_length The socket key length.
215 * @returns The found socket.
216 * @returns NULL if no socket was found.
217 */
218socket_core_ref socket_port_find(socket_ports_ref global_sockets, int port, const char * key, size_t key_length);
219
220/** Releases the socket port.
221 * If the socket is bound the port entry is released.
222 * If there are no more port entries the port is release.
223 * @param[in] global_sockets The global sockets to be updated.
224 * @param[in] socket The socket to be unbound.
225 */
226void socket_port_release(socket_ports_ref global_sockets, socket_core_ref socket);
227
228/** Adds the socket to an already bound port.
229 * @param[in] global_sockets The global sockets to be updated.
230 * @param[in] port The port number to be bound to.
231 * @param[in] socket The socket to be added.
232 * @param[in] key The socket key identifier.
233 * @param[in] key_length The socket key length.
234 * @returns EOK on success.
235 * @returns ENOENT if the port is not already used.
236 * @returns Other error codes as defined for the socket_port_add_core() function.
237 */
238int socket_port_add(socket_ports_ref global_sockets, int port, socket_core_ref socket, const char * key, size_t key_length);
239
240#endif
241
242/** @}
243 */
Note: See TracBrowser for help on using the repository browser.