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
RevLine 
[21580dd]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
[779a47d]29/** @addtogroup libc
30 * @{
[21580dd]31 */
32
33/** @file
[779a47d]34 * IP module messages.
35 * @see ip_interface.h
[21580dd]36 */
37
[779a47d]38#ifndef LIBC_IP_MESSAGES_H_
39#define LIBC_IP_MESSAGES_H_
[21580dd]40
41#include <ipc/ipc.h>
[2aa15d4]42#include <ipc/net.h>
[21580dd]43
[e4554d4]44#include <net/in.h>
[ff2a62d]45#include <net/ip_codes.h>
[21580dd]46
[779a47d]47/** IP module messages. */
48typedef enum {
[21580dd]49 /** Adds the routing entry.
[779a47d]50 * @see ip_add_route()
[21580dd]51 */
52 NET_IP_ADD_ROUTE = NET_IP_FIRST,
[774e6d1a]53
[a64c64d]54 /** Gets the actual route information.
[779a47d]55 * @see ip_get_route()
[21580dd]56 */
[a64c64d]57 NET_IP_GET_ROUTE,
[774e6d1a]58
[21580dd]59 /** Processes the received error notification.
[779a47d]60 * @see ip_received_error_msg()
[21580dd]61 */
62 NET_IP_RECEIVED_ERROR,
[774e6d1a]63
[a64c64d]64 /** Sets the default gateway.
[779a47d]65 * @see ip_set_default_gateway()
[21580dd]66 */
[a64c64d]67 NET_IP_SET_GATEWAY
[21580dd]68} ip_messages;
69
[779a47d]70/** @name IP specific message parameters definitions */
[21580dd]71/*@{*/
72
[774e6d1a]73/** Return the address message parameter.
74 *
75 * @param[in] call Message call structure.
76 *
[a64c64d]77 */
[e417b96]78#define IP_GET_ADDRESS(call) \
[779a47d]79 ({ \
80 in_addr_t addr; \
[774e6d1a]81 addr.s_addr = IPC_GET_ARG3(call); \
[779a47d]82 addr; \
83 })
[a64c64d]84
[774e6d1a]85/** Return the gateway message parameter.
86 *
87 * @param[in] call Message call structure.
88 *
[21580dd]89 */
[e417b96]90#define IP_GET_GATEWAY(call) \
[779a47d]91 ({ \
92 in_addr_t addr; \
[774e6d1a]93 addr.s_addr = IPC_GET_ARG2(call); \
[779a47d]94 addr; \
95 })
[21580dd]96
[774e6d1a]97/** Set the header length in the message answer.
98 *
99 * @param[out] answer Message answer structure.
100 *
[21580dd]101 */
[774e6d1a]102#define IP_SET_HEADERLEN(answer, value) IPC_SET_ARG2(answer, (sysarg_t) (value))
[21580dd]103
[774e6d1a]104/** Return the network mask message parameter.
105 *
106 * @param[in] call Message call structure.
107 *
[21580dd]108 */
[e417b96]109#define IP_GET_NETMASK(call) \
[779a47d]110 ({ \
111 in_addr_t addr; \
[774e6d1a]112 addr.s_addr = IPC_GET_ARG4(call); \
[779a47d]113 addr; \
114 })
[21580dd]115
[774e6d1a]116/** Return the protocol message parameter.
117 *
118 * @param[in] call Message call structure.
119 *
[21580dd]120 */
[774e6d1a]121#define IP_GET_PROTOCOL(call) ((ip_protocol_t) IPC_GET_ARG1(call))
[21580dd]122
123/*@}*/
124
125#endif
126
127/** @}
128 */
Note: See TracBrowser for help on using the repository browser.