source: mainline/uspace/lib/c/include/ipc/ip.h@ 6610565b

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 6610565b was 774e6d1a, checked in by martin@…>, 15 years ago

partial networking stack overhaul

  • a lot of coding style changes (comments, indentation, etc.)
  • convert several ints to unsigned ints or size_t values
  • streamline many of the IPC-related macros (they no longer dereference the call structure by themselves)
  • get rid of netif_interface.h (containing only aliases for remote functions and not serving any purpose)
  • rename netif_local.{c|h} to netif_skel.{c|h} (it is really just a skeleton)
  • drop the "_remote" and "_standalone" suffixes from most of the netif_ functions (they do not serve any purpose anymore)
  • implement netif_client_connection() as a common framework function for all netif modules
    • update the lo module accordingly
  • ip module now reports the default gateway to the user whenever it is being set
  • Property mode set to 100644
File size: 3.1 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 libc
30 * @{
31 */
32
33/** @file
34 * IP module messages.
35 * @see ip_interface.h
36 */
37
38#ifndef LIBC_IP_MESSAGES_H_
39#define LIBC_IP_MESSAGES_H_
40
41#include <ipc/ipc.h>
42#include <ipc/net.h>
43
44#include <net/in.h>
45#include <net/ip_codes.h>
46
47/** IP module messages. */
48typedef enum {
49 /** Adds the routing entry.
50 * @see ip_add_route()
51 */
52 NET_IP_ADD_ROUTE = NET_IP_FIRST,
53
54 /** Gets the actual route information.
55 * @see ip_get_route()
56 */
57 NET_IP_GET_ROUTE,
58
59 /** Processes the received error notification.
60 * @see ip_received_error_msg()
61 */
62 NET_IP_RECEIVED_ERROR,
63
64 /** Sets the default gateway.
65 * @see ip_set_default_gateway()
66 */
67 NET_IP_SET_GATEWAY
68} ip_messages;
69
70/** @name IP specific message parameters definitions */
71/*@{*/
72
73/** Return the address message parameter.
74 *
75 * @param[in] call Message call structure.
76 *
77 */
78#define IP_GET_ADDRESS(call) \
79 ({ \
80 in_addr_t addr; \
81 addr.s_addr = IPC_GET_ARG3(call); \
82 addr; \
83 })
84
85/** Return the gateway message parameter.
86 *
87 * @param[in] call Message call structure.
88 *
89 */
90#define IP_GET_GATEWAY(call) \
91 ({ \
92 in_addr_t addr; \
93 addr.s_addr = IPC_GET_ARG2(call); \
94 addr; \
95 })
96
97/** Set the header length in the message answer.
98 *
99 * @param[out] answer Message answer structure.
100 *
101 */
102#define IP_SET_HEADERLEN(answer, value) IPC_SET_ARG2(answer, (sysarg_t) (value))
103
104/** Return the network mask message parameter.
105 *
106 * @param[in] call Message call structure.
107 *
108 */
109#define IP_GET_NETMASK(call) \
110 ({ \
111 in_addr_t addr; \
112 addr.s_addr = IPC_GET_ARG4(call); \
113 addr; \
114 })
115
116/** Return the protocol message parameter.
117 *
118 * @param[in] call Message call structure.
119 *
120 */
121#define IP_GET_PROTOCOL(call) ((ip_protocol_t) IPC_GET_ARG1(call))
122
123/*@}*/
124
125#endif
126
127/** @}
128 */
Note: See TracBrowser for help on using the repository browser.