A stack which works with or without an Mbed os library. Provides IPv4 or IPv6 with a full 1500 byte buffer.
Dependents: oldheating gps motorhome heating
udp/udp.cpp
- Committer:
- andrewboyson
- Date:
- 2017-10-04
- Revision:
- 37:793b39683406
- Parent:
- 33:714a0345e59b
- Child:
- 42:222a4f45f916
File content as of revision 37:793b39683406:
#include "mbed.h" #include "log.h" #include "net.h" #include "action.h" #include "udp.h" #include "ntp.h" #include "dhcp.h" #include "dns.h" #include "eth.h" #include "ip4.h" #include "ip6.h" #include "slaac.h" #include "ns.h" #include "io.h" #define UNKNOWN true #define HEADER_SIZE 8 __packed struct header { uint16_t srcPort; uint16_t dstPort; uint16_t totalLength; uint16_t checksum; }; static uint16_t srcPort; static uint16_t dstPort; static uint16_t checksum; static uint16_t totalLength; static int handlePort(void (*traceback)(void), int* pDataLength, void* pData) { switch (dstPort) { //Handle these case DHCP_CLIENT_PORT: return DhcpHandleResponse (traceback, pDataLength, pData); // 68 case NTP_PORT: return NtpHandlePacketReceived(traceback, pDataLength, pData); // 123 case DNS_UNICAST_CLIENT_PORT: return DnsHandlePacketReceived(traceback, DNS_PROTOCOL_UDNS, pDataLength, pData); //53053 case DNS_MDNS_PORT: return DnsHandlePacketReceived(traceback, DNS_PROTOCOL_MDNS, pDataLength, pData); // 5353 case DNS_LLMNR_CLIENT_PORT: return DnsHandlePacketReceived(traceback, DNS_PROTOCOL_LLMNR, pDataLength, pData); //53055 case DNS_LLMNR_SERVER_PORT: return DnsHandlePacketReceived(traceback, DNS_PROTOCOL_LLMNR, pDataLength, pData); // 5355 //Quietly drop these case DHCP_SERVER_PORT: //67 case 137: //NETBIOS name service case 138: //NETBIOS datagram service case 139: //NETBIOS session service case 1900: //SSDP Simple Service Discovery Protocol (uPnP) case 3076: //Call of Duty - Xbox case 5224: //Don't know but a burst was broadcast by Kate's phone containing '_logitech-reverse-bonjour._tcp.local.5446 192.168.1.36 string' case 9956: //Alljoyn part af Allseen IoT services case 9997: //VLC case 9998: //VLC case 9999: //VLC case 17500: //Dropbox LAN sync return DO_NOTHING; //Report anything else default: if (UNKNOWN) LogTimeF("UDP unknown port %d\r\n", dstPort); return DO_NOTHING; } } int UdpHandleReceivedPacket(void (*traceback)(void), int* pSize, void* pPacket) { void* pData = (char*)pPacket + HEADER_SIZE; int dataLength = *pSize - HEADER_SIZE; int action = handlePort(traceback, &dataLength, pData); *pSize = dataLength + HEADER_SIZE; uint16_t tmpPort = dstPort; dstPort = srcPort; srcPort = tmpPort; return action; } static int pollForPacketToSend(int type, int* pDataLength, void* pData) { int action = DO_NOTHING; if (!action && type == IPV4) //DHCP only works under IPv4 { action = DhcpPollForRequestToSend(pData, pDataLength); if (action) { srcPort = DHCP_CLIENT_PORT; dstPort = DHCP_SERVER_PORT; } } if (!action) //DNS is agnostic { action = DnsPollForPacketToSend(pData, pDataLength); int dest = ActionGetDestPart(action); if (dest) { switch (dest) { case UNICAST_DNS: srcPort = DNS_UNICAST_CLIENT_PORT; dstPort = DNS_UNICAST_SERVER_PORT; break; //53053, 53 case MULTICAST_MDNS: srcPort = DNS_MDNS_PORT; dstPort = DNS_MDNS_PORT; break; // 5353, 5353 case MULTICAST_LLMNR: srcPort = DNS_LLMNR_CLIENT_PORT; dstPort = DNS_LLMNR_SERVER_PORT; break; //53055, 5355 //Report anything else default: LogTimeF("DNS unknown dest %d\r\n", dest); return DO_NOTHING; } } } if (!action) //NTP needs to choose depending of what address is specified { action = NtpPollForPacketToSend(type, pData, pDataLength); if (action) { srcPort = NTP_PORT; dstPort = NTP_PORT; } } return action; } int UdpPollForPacketToSend(int type, int* pSize, void* pPacket) { void* pData = (char*)pPacket + HEADER_SIZE; int dataLength = *pSize - HEADER_SIZE; int action = pollForPacketToSend(type, &dataLength, pData); *pSize = dataLength + HEADER_SIZE; return action; } void UdpLogHeader(uint16_t calculatedChecksum) { Log ("UDP header\r\n"); LogF(" Source port %hu\r\n", srcPort); LogF(" Destination port %hu\r\n", dstPort); LogF(" Total length %hu\r\n", totalLength); LogF(" Checksum (hex) %04hX\r\n", checksum); LogF(" Calculated %04hX\r\n", calculatedChecksum); } void UdpMakeHeader(int size, void* pPacket) { struct header* pHeader = (header*)pPacket; pHeader->dstPort = NetToHost16(dstPort); pHeader->srcPort = NetToHost16(srcPort); pHeader->totalLength = NetToHost16(size); pHeader->checksum = 0; } void UdpAddChecksum(void* pPacket, uint16_t checksum) { struct header* pHeader = (header*)pPacket; pHeader->checksum = checksum; } void UdpReadHeader(void* pPacket, uint16_t size) { struct header* pHeader = (header*)pPacket; srcPort = NetToHost16(pHeader->srcPort); dstPort = NetToHost16(pHeader->dstPort); totalLength = NetToHost16(pHeader->totalLength); checksum = NetToHost16(pHeader->checksum); }