source: mainline/uspace/lib/net/netif/netif_remote.c@ e526f08

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since e526f08 was e526f08, checked in by Jakub Jermar <jakub@…>, 15 years ago

Move net_device.h to standard library.

  • Property mode set to 100644
File size: 3.7 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
29/** @addtogroup netif
[14f1db0]30 * @{
[21580dd]31 */
32
33/** @file
[14f1db0]34 * Network interface module interface implementation for remote modules.
[21580dd]35 */
36
37#include <ipc/services.h>
38
[c7a8442]39#include <net/modules.h>
[849ed54]40#include <adt/measured_strings.h>
[c69d327]41#include <net/packet.h>
[0a866eeb]42#include <packet_client.h>
[e526f08]43#include <net/device.h>
[14f1db0]44#include <netif_remote.h>
[849ed54]45#include <netif_messages.h>
[2aa15d4]46#include <net_messages.h>
[21580dd]47
[14f1db0]48int netif_get_addr_req_remote(int netif_phone, device_id_t device_id,
49 measured_string_ref *address, char **data)
50{
51 return generic_get_addr_req(netif_phone, NET_NETIF_GET_ADDR, device_id,
52 address, data);
[21580dd]53}
54
[14f1db0]55int netif_probe_req_remote(int netif_phone, device_id_t device_id, int irq, int io)
56{
[aadf01e]57 return async_req_3_0(netif_phone, NET_NETIF_PROBE, device_id, irq, io);
[21580dd]58}
59
[14f1db0]60int netif_send_msg_remote(int netif_phone, device_id_t device_id, packet_t packet,
61 services_t sender)
62{
63 return generic_send_msg_remote(netif_phone, NET_NETIF_SEND, device_id,
64 packet_get_id(packet), sender, 0);
[21580dd]65}
66
[14f1db0]67int netif_start_req_remote(int netif_phone, device_id_t device_id)
68{
[aadf01e]69 return async_req_1_0(netif_phone, NET_NETIF_START, device_id);
[21580dd]70}
71
[14f1db0]72int netif_stop_req_remote(int netif_phone, device_id_t device_id)
73{
[aadf01e]74 return async_req_1_0(netif_phone, NET_NETIF_STOP, device_id);
[21580dd]75}
76
[14f1db0]77int netif_stats_req_remote(int netif_phone, device_id_t device_id,
78 device_stats_ref stats)
79{
80 if (!stats)
[aadf01e]81 return EBADMEM;
[14f1db0]82
83 aid_t message_id = async_send_1(netif_phone, NET_NETIF_STATS,
84 (ipcarg_t) device_id, NULL);
[aadf01e]85 async_data_read_start(netif_phone, stats, sizeof(*stats));
[14f1db0]86
87 ipcarg_t result;
[aadf01e]88 async_wait_for(message_id, &result);
[14f1db0]89
[aadf01e]90 return (int) result;
[21580dd]91}
92
[9757512]93/** Create bidirectional connection with the network interface module and
94 * registers the message receiver.
95 *
96 * @param[in] service The network interface module service.
97 * @param[in] device_id The device identifier.
98 * @param[in] me The requesting module service.
99 * @param[in] receiver The message receiver.
100 *
101 * @return The phone of the needed service.
102 * @return EOK on success.
103 * @return Other error codes as defined for the bind_service() function.
104 *
105 */
[14f1db0]106int netif_bind_service_remote(services_t service, device_id_t device_id, services_t me,
107 async_client_conn_t receiver)
108{
[aadf01e]109 return bind_service(service, device_id, me, 0, receiver);
[21580dd]110}
111
112/** @}
113 */
Note: See TracBrowser for help on using the repository browser.