source: mainline/uspace/lib/net/il/il_remote.c@ 4a4c8bcf

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 4a4c8bcf was 797b704, checked in by Martin Decky <martin@…>, 14 years ago

streamline internetworking layer

  • IPC method renaming

NET_IL_DEVICE → NET_IP_DEVICE
NET_IL_PACKET_SPACE → NET_IP_PACKET_SPACE
NET_IL_SEND → NET_IP_SEND

The original methods were actually not generic methods of the IL layer (used by the lower layers), but specific methods of the IP module
and used by the higher layers. The original naming was rather confusing.

  • implelement common IL module skeleton
  • small improvements in the comments of the NETIF and NIL skeletons
  • IL modules now use a separate receiver function for the NET_IL_* calls
  • Property mode set to 100644
File size: 3.6 KB
RevLine 
[fb9ffb0]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 libnet
30 * @{
31 */
32
33/** @file
34 * Internetwork layer module interface for the underlying network interface
[797b704]35 * layer.
[fb9ffb0]36 */
37
[797b704]38#include <il_remote.h>
[fb9ffb0]39#include <generic.h>
40#include <packet_client.h>
41
42#include <ipc/services.h>
43#include <ipc/il.h>
44
45#include <net/device.h>
46#include <net/packet.h>
47
48/** Notify the internetwork layer modules about the device state change.
49 *
50 * @param[in] il_phone The internetwork layer module phone used for
51 * (semi)remote calls.
52 * @param[in] device_id The device identifier.
53 * @param[in] state The new device state.
54 * @param[in] target The target internetwork module service to be
55 * delivered to.
56 *
57 * @return EOK on success.
58 *
59 */
60int il_device_state_msg(int il_phone, device_id_t device_id,
61 device_state_t state, services_t target)
62{
63 return generic_device_state_msg_remote(il_phone, NET_IL_DEVICE_STATE,
64 device_id, state, target);
65}
66
67/** Notify the internetwork layer modules about the received packet/s.
68 *
69 * @param[in] il_phone The internetwork layer module phone used for
70 * (semi)remote calls.
71 * @param[in] device_id The device identifier.
72 * @param[in] packet The received packet or the received packet queue.
73 * @param[in] target The target internetwork module service to be
74 * delivered to.
75 *
76 * @return EOK on success.
77 *
78 */
[46d4d9f]79int il_received_msg(int il_phone, device_id_t device_id, packet_t *packet,
[fb9ffb0]80 services_t target)
81{
82 return generic_received_msg_remote(il_phone, NET_IL_RECEIVED, device_id,
83 packet_get_id(packet), target, 0);
84}
85
86/** Notify the internetwork layer modules about the mtu change.
87 *
88 * @param[in] il_phone The internetwork layer module phone used for
89 * (semi)remote calls.
90 * @param[in] device_id The device identifier.
91 * @param[in] mtu The new mtu value.
92 * @param[in] target The target internetwork module service to be
93 * delivered to.
94 *
95 * @return EOK on success.
96 *
97 */
98int il_mtu_changed_msg(int il_phone, device_id_t device_id, size_t mtu,
99 services_t target)
100{
101 return generic_device_state_msg_remote(il_phone, NET_IL_MTU_CHANGED,
102 device_id, (int) mtu, target);
103}
104
105/** @}
106 */
Note: See TracBrowser for help on using the repository browser.