Simple Module UDP

File: Transport/UDP/UDP.ned

C++ definition: click here

UDP protocol implementation, for IPv4 and IPv6.

The UDP protocol header is represented by the class UDPPacket.

Communication with clients (applications)

The module can (should) be connected to several applications. For sending an UDP packet, the application should attach an UDPControlInfo object to the payload, and send it to UDP. UDP will also attach an UDPControlInfo object to any payload message in sends up to the application.

For receiving UDP packets, the connected applications should first "bind" to the given UDP port. This can be done by sending an arbitrary message with message kind UDP_C_BIND and an UDPControlInfo attached with srcPort filled in.

If there is only one app which doesn't bind to any port, it will receive all packets.

Communication with the IP (IPv4/IPv6) layer

The UDP model relies on sending and receiving IPControlInfo/IPv6ControlInfo objects attached to UDPPacket objects as control info (see cMessage::setControlInfo()).

See also: UDPPacket, UDPControlInfo, UDPCommandCode

Usage diagram:

The following diagram shows usage relationships between modules, networks and channels. Unresolved module (and channel) types are missing from the diagram. Click here to see the full picture.

Used in compound modules:

If a module type shows up more than once, that means it has been defined in more than one NED file.

StandardHost

IP host with TCP, UDP layers and applications.

QuaggaRouter

Quagga-based IP router.

MobileHost

Models a mobile host with a wireless (802.11b) card. This module is a WirelessHost less the PPP and Ethernet interfaces, plus mobility support (BasicMobility). It is intended mainly for mobile ad-hoc networks.

WirelessHost2

Models a host with zero, one or more wireless (802.11b) cards. This module is a variation of WirelessHost.

WirelessHost

Models a host with one wireless (802.11b) card. This module is basically a StandardHost with a Nic80211 added.

StandardHost6

IPv6 host with TCP, UDP layers and applications.

LDP_LSR

An LDP-capable router.

Gates:

Name Direction Description
from_app [ ] input
from_ip input
from_ipv6 input
to_app [ ] output
to_ip output
to_ipv6 output

Source code:

simple UDP
    gates:
        in: from_app[];
        in: from_ip;
        in: from_ipv6;
        out: to_app[];
        out: to_ip;
        out: to_ipv6;
endsimple