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
Line 
1/*
2 * Copyright (c) 2015 Jiri Svoboda
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
45#include "assoc.h"
46#include "pdu.h"
47#include "std.h"
48#include "udp_inet.h"
49#include "udp_type.h"
50
51static int udp_inet_ev_recv(inet_dgram_t *dgram);
52static void udp_received_pdu(udp_pdu_t *pdu);
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{
61 udp_pdu_t *pdu;
62
63 log_msg(LOG_DEFAULT, LVL_DEBUG, "udp_inet_ev_recv()");
64
65 pdu = udp_pdu_new();
66 pdu->iplink = dgram->iplink;
67 pdu->data = dgram->data;
68 pdu->data_size = dgram->size;
69
70 pdu->src = dgram->src;
71 pdu->dest = dgram->dest;
72
73 udp_received_pdu(pdu);
74
75 /* We don't want udp_pdu_delete() to free dgram->data */
76 pdu->data = NULL;
77 udp_pdu_delete(pdu);
78
79 return EOK;
80}
81
82/** Transmit PDU over network layer. */
83int udp_transmit_pdu(udp_pdu_t *pdu)
84{
85 int rc;
86 inet_dgram_t dgram;
87
88 log_msg(LOG_DEFAULT, LVL_DEBUG, "udp_transmit_pdu()");
89
90 dgram.iplink = pdu->iplink;
91 dgram.src = pdu->src;
92 dgram.dest = pdu->dest;
93 dgram.tos = 0;
94 dgram.data = pdu->data;
95 dgram.size = pdu->data_size;
96
97 rc = inet_send(&dgram, INET_TTL_MAX, 0);
98 if (rc != EOK)
99 log_msg(LOG_DEFAULT, LVL_ERROR, "Failed to transmit PDU.");
100
101 return rc;
102}
103
104/** Process received PDU. */
105static void udp_received_pdu(udp_pdu_t *pdu)
106{
107 udp_msg_t *dmsg;
108 inet_ep2_t rident;
109
110 log_msg(LOG_DEFAULT, LVL_DEBUG, "udp_received_pdu()");
111
112 if (udp_pdu_decode(pdu, &rident, &dmsg) != EOK) {
113 log_msg(LOG_DEFAULT, LVL_WARN, "Not enough memory. PDU dropped.");
114 return;
115 }
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);
123}
124
125int udp_inet_init(void)
126{
127 int rc;
128
129 log_msg(LOG_DEFAULT, LVL_DEBUG, "udp_inet_init()");
130
131 rc = inet_init(IP_PROTO_UDP, &udp_inet_ev_ops);
132 if (rc != EOK) {
133 log_msg(LOG_DEFAULT, LVL_ERROR, "Failed connecting to internet service.");
134 return ENOENT;
135 }
136
137 return EOK;
138}
139
140/**
141 * @}
142 */
Note: See TracBrowser for help on using the repository browser.