source: mainline/uspace/srv/net/udp/udp_inet.c@ c3f7d37

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since c3f7d37 was c3f7d37, checked in by Jiri Svoboda <jiri@…>, 10 years ago

Remove excessive debugging output.

  • Property mode set to 100644
File size: 3.5 KB
RevLine 
[66a272f8]1/*
[2f19103]2 * Copyright (c) 2015 Jiri Svoboda
[66a272f8]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 udp
30 * @{
31 */
32
33/**
34 * @file
35 */
36
37#include <bitops.h>
38#include <byteorder.h>
39#include <errno.h>
40#include <inet/inet.h>
41#include <io/log.h>
42#include <stdio.h>
43#include <task.h>
44
[92b42442]45#include "assoc.h"
46#include "pdu.h"
[66a272f8]47#include "std.h"
48#include "udp_inet.h"
[ee603c4]49#include "udp_type.h"
[66a272f8]50
51static int udp_inet_ev_recv(inet_dgram_t *dgram);
[92b42442]52static void udp_received_pdu(udp_pdu_t *pdu);
[66a272f8]53
54static inet_ev_ops_t udp_inet_ev_ops = {
55 .recv = udp_inet_ev_recv
56};
57
58/** Received datagram callback */
59static int udp_inet_ev_recv(inet_dgram_t *dgram)
60{
[92b42442]61 udp_pdu_t *pdu;
[66a272f8]62
[a1a101d]63 log_msg(LOG_DEFAULT, LVL_DEBUG, "udp_inet_ev_recv()");
[66a272f8]64
[92b42442]65 pdu = udp_pdu_new();
[8d48c7e]66 pdu->iplink = dgram->iplink;
[92b42442]67 pdu->data = dgram->data;
68 pdu->data_size = dgram->size;
[a2e3ee6]69
70 pdu->src = dgram->src;
71 pdu->dest = dgram->dest;
[92b42442]72
73 udp_received_pdu(pdu);
[f1a8c23]74
75 /* We don't want udp_pdu_delete() to free dgram->data */
76 pdu->data = NULL;
[92b42442]77 udp_pdu_delete(pdu);
[66a272f8]78
79 return EOK;
80}
81
82/** Transmit PDU over network layer. */
[ee603c4]83int udp_transmit_pdu(udp_pdu_t *pdu)
[66a272f8]84{
85 int rc;
86 inet_dgram_t dgram;
87
[a1a101d]88 log_msg(LOG_DEFAULT, LVL_DEBUG, "udp_transmit_pdu()");
[92b42442]89
[695b6ff]90 dgram.iplink = pdu->iplink;
[a2e3ee6]91 dgram.src = pdu->src;
92 dgram.dest = pdu->dest;
[66a272f8]93 dgram.tos = 0;
[ee603c4]94 dgram.data = pdu->data;
95 dgram.size = pdu->data_size;
[66a272f8]96
97 rc = inet_send(&dgram, INET_TTL_MAX, 0);
98 if (rc != EOK)
[a1a101d]99 log_msg(LOG_DEFAULT, LVL_ERROR, "Failed to transmit PDU.");
[ee603c4]100
101 return rc;
[66a272f8]102}
[ee603c4]103
[66a272f8]104/** Process received PDU. */
[92b42442]105static void udp_received_pdu(udp_pdu_t *pdu)
[66a272f8]106{
[92b42442]107 udp_msg_t *dmsg;
[2f19103]108 inet_ep2_t rident;
[66a272f8]109
[a1a101d]110 log_msg(LOG_DEFAULT, LVL_DEBUG, "udp_received_pdu()");
[66a272f8]111
[92b42442]112 if (udp_pdu_decode(pdu, &rident, &dmsg) != EOK) {
[a1a101d]113 log_msg(LOG_DEFAULT, LVL_WARN, "Not enough memory. PDU dropped.");
[66a272f8]114 return;
115 }
[92b42442]116
117 /*
118 * Insert decoded message into appropriate receive queue.
119 * This transfers ownership of dmsg to the callee, we do not
120 * free it.
121 */
122 udp_assoc_received(&rident, dmsg);
[66a272f8]123}
[92b42442]124
[66a272f8]125int udp_inet_init(void)
126{
127 int rc;
128
[a1a101d]129 log_msg(LOG_DEFAULT, LVL_DEBUG, "udp_inet_init()");
[66a272f8]130
131 rc = inet_init(IP_PROTO_UDP, &udp_inet_ev_ops);
132 if (rc != EOK) {
[a1a101d]133 log_msg(LOG_DEFAULT, LVL_ERROR, "Failed connecting to internet service.");
[66a272f8]134 return ENOENT;
135 }
136
137 return EOK;
138}
139
140/**
141 * @}
142 */
Note: See TracBrowser for help on using the repository browser.