source: mainline/uspace/lib/c/include/ipc/icmp.h@ 8426912a

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 8426912a 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.7 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 * ICMP module messages.
35 * @see icmp_interface.h
36 */
37
38#ifndef LIBC_ICMP_MESSAGES_
39#define LIBC_ICMP_MESSAGES_
40
41#include <ipc/ipc.h>
42#include <ipc/net.h>
43#include <sys/types.h>
44#include <sys/time.h>
45
46#include <net/icmp_codes.h>
47
48/** ICMP module messages. */
49typedef enum {
50 /** Sends echo request. @see icmp_echo() */
51 NET_ICMP_ECHO = NET_ICMP_FIRST,
52
53 /**
54 * Sends destination unreachable error message.
55 * @see icmp_destination_unreachable_msg()
56 */
57 NET_ICMP_DEST_UNREACH,
58
59 /**
60 * Sends source quench error message.
61 * @see icmp_source_quench_msg()
62 */
63 NET_ICMP_SOURCE_QUENCH,
64
65 /**
66 * Sends time exceeded error message.
67 * @see icmp_time_exceeded_msg()
68 */
69 NET_ICMP_TIME_EXCEEDED,
70
71 /**
72 * Sends parameter problem error message.
73 * @see icmp_parameter_problem_msg()
74 */
75 NET_ICMP_PARAMETERPROB,
76
77 /** Initializes new connection. */
78 NET_ICMP_INIT
79} icmp_messages;
80
81/** @name ICMP specific message parameters definitions */
82/*@{*/
83
84/** Return the ICMP code message parameter.
85 *
86 * @param[in] call Message call structure.
87 *
88 */
89#define ICMP_GET_CODE(call) ((icmp_code_t) IPC_GET_ARG1(call))
90
91/** Return the ICMP link MTU message parameter.
92 *
93 * @param[in] call Message call structure.
94 *
95 */
96#define ICMP_GET_MTU(call) ((icmp_param_t) IPC_GET_ARG3(call))
97
98/** Return the pointer message parameter.
99 *
100 * @param[in] call Message call structure.
101 *
102 */
103#define ICMP_GET_POINTER(call) ((icmp_param_t) IPC_GET_ARG3(call))
104
105/** Return the size message parameter.
106 *
107 * @param[in] call Message call structure.
108 *
109 */
110#define ICMP_GET_SIZE(call) ((size_t) IPC_GET_ARG1(call))
111
112/** Return the timeout message parameter.
113 *
114 * @param[in] call Message call structure.
115 *
116 */
117#define ICMP_GET_TIMEOUT(call) ((suseconds_t) IPC_GET_ARG2(call))
118
119/** Return the time to live message parameter.
120 *
121 * @param[in] call Message call structure.
122 *
123 */
124#define ICMP_GET_TTL(call) ((ip_ttl_t) IPC_GET_ARG3(call))
125
126/** Return the type of service message parameter.
127 *
128 * @param[in] call Message call structure.
129 *
130 */
131#define ICMP_GET_TOS(call) ((ip_tos_t) IPC_GET_ARG4(call))
132
133/** Return the dont fragment message parameter.
134 *
135 * @param[in] call Message call structure.
136 */
137#define ICMP_GET_DONT_FRAGMENT(call) ((int) IPC_GET_ARG5(call))
138
139/*@}*/
140
141#endif
142
143/** @}
144 */
Note: See TracBrowser for help on using the repository browser.