Subversion Repositories HelenOS

Rev

Rev 4707 | Blame | Compare with Previous | Last modification | View Log | Download | RSS feed

  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
  30.  *  @{
  31.  */
  32.  
  33. /** @file
  34.  *  Network interface module interface implementation for standalone remote modules.
  35.  *  @see netif_interface.h
  36.  */
  37.  
  38. #include <ipc/services.h>
  39.  
  40. #include "../modules.h"
  41.  
  42. #include "../structures/measured_strings.h"
  43. #include "../structures/packet/packet.h"
  44. #include "../structures/packet/packet_client.h"
  45.  
  46. #include "../include/device.h"
  47. #include "../include/netif_interface.h"
  48.  
  49. #include "netif_messages.h"
  50.  
  51. int netif_get_addr_req( int netif_phone, device_id_t device_id, measured_string_ref * address, char ** data ){
  52.     return generic_get_addr_req( netif_phone, NET_NETIF_GET_ADDR, device_id, address, data );
  53. }
  54.  
  55. int netif_probe_req( int netif_phone, device_id_t device_id, int irq, int io ){
  56.     return async_req_3_0( netif_phone, NET_NETIF_PROBE, device_id, irq, io );
  57. }
  58.  
  59. int netif_send_msg( int netif_phone, device_id_t device_id, packet_t packet, services_t sender ){
  60.     return generic_send_msg( netif_phone, NET_NETIF_SEND, device_id, packet_get_id( packet ), sender, 0 );
  61. }
  62.  
  63. int netif_start_req( int netif_phone, device_id_t device_id ){
  64.     return async_req_1_0( netif_phone, NET_NETIF_START, device_id );
  65. }
  66.  
  67. int netif_stop_req( int netif_phone, device_id_t device_id ){
  68.     return async_req_1_0( netif_phone, NET_NETIF_STOP, device_id );
  69. }
  70.  
  71. int netif_stats_req( int netif_phone, device_id_t device_id, device_stats_ref stats ){
  72.     aid_t       message_id;
  73.     ipcarg_t    result;
  74.  
  75.     if( ! stats ) return EBADMEM;
  76.     message_id = async_send_1( netif_phone, NET_NETIF_STATS, ( ipcarg_t ) device_id, NULL );
  77.     ipc_data_read_start( netif_phone, stats, sizeof( * stats ));
  78.     async_wait_for( message_id, & result );
  79.     return ( int ) result;
  80. }
  81.  
  82. int netif_bind_service( services_t service, device_id_t device_id, services_t me, async_client_conn_t receiver ){
  83.     return bind_service( service, device_id, me, 0, receiver );
  84. }
  85.  
  86. /** @}
  87.  */
  88.