mirror of
				https://github.com/mfulz/qmk_firmware.git
				synced 2025-11-03 23:02:34 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			82 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			82 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
             LUFA Library
 | 
						|
     Copyright (C) Dean Camera, 2010.
 | 
						|
              
 | 
						|
  dean [at] fourwalledcubicle [dot] com
 | 
						|
      www.fourwalledcubicle.com
 | 
						|
*/
 | 
						|
 | 
						|
/*
 | 
						|
  Copyright 2010  Dean Camera (dean [at] fourwalledcubicle [dot] com)
 | 
						|
 | 
						|
  Permission to use, copy, modify, distribute, and sell this 
 | 
						|
  software and its documentation for any purpose is hereby granted
 | 
						|
  without fee, provided that the above copyright notice appear in 
 | 
						|
  all copies and that both that the copyright notice and this
 | 
						|
  permission notice and warranty disclaimer appear in supporting 
 | 
						|
  documentation, and that the name of the author not be used in 
 | 
						|
  advertising or publicity pertaining to distribution of the 
 | 
						|
  software without specific, written prior permission.
 | 
						|
 | 
						|
  The author disclaim all warranties with regard to this
 | 
						|
  software, including all implied warranties of merchantability
 | 
						|
  and fitness.  In no event shall the author be liable for any
 | 
						|
  special, indirect or consequential damages or any damages
 | 
						|
  whatsoever resulting from loss of use, data or profits, whether
 | 
						|
  in an action of contract, negligence or other tortious action,
 | 
						|
  arising out of or in connection with the use or performance of
 | 
						|
  this software.
 | 
						|
*/
 | 
						|
 | 
						|
/** \file
 | 
						|
 *
 | 
						|
 *  User Datagram Protocol (UDP) packet handling routines. This protocol handles high throughput, low
 | 
						|
 *  reliability packets which are typically used to encapsulate streaming data.
 | 
						|
 */
 | 
						|
 
 | 
						|
#define  INCLUDE_FROM_UDP_C
 | 
						|
#include "UDP.h"
 | 
						|
 | 
						|
/** Processes a UDP packet inside an Ethernet frame, and writes the appropriate response
 | 
						|
 *  to the output Ethernet frame if a sub-protocol handler has created a response packet.
 | 
						|
 *
 | 
						|
 *  \param[in] IPHeaderInStart     Pointer to the start of the incoming packet's IP header
 | 
						|
 *  \param[in] UDPHeaderInStart    Pointer to the start of the incoming packet's UDP header
 | 
						|
 *  \param[out] UDPHeaderOutStart  Pointer to the start of the outgoing packet's UDP header
 | 
						|
 *
 | 
						|
 *  \return The number of bytes written to the out Ethernet frame if any, NO_RESPONSE otherwise
 | 
						|
 */
 | 
						|
int16_t UDP_ProcessUDPPacket(void* IPHeaderInStart, void* UDPHeaderInStart, void* UDPHeaderOutStart)
 | 
						|
{
 | 
						|
	UDP_Header_t* UDPHeaderIN  = (UDP_Header_t*)UDPHeaderInStart;
 | 
						|
	UDP_Header_t* UDPHeaderOUT = (UDP_Header_t*)UDPHeaderOutStart;
 | 
						|
	
 | 
						|
	int16_t RetSize = NO_RESPONSE;
 | 
						|
	
 | 
						|
	DecodeUDPHeader(UDPHeaderInStart);
 | 
						|
	
 | 
						|
	switch (SwapEndian_16(UDPHeaderIN->DestinationPort))
 | 
						|
	{
 | 
						|
		case UDP_PORT_DHCP_REQUEST:
 | 
						|
			RetSize = DHCP_ProcessDHCPPacket(IPHeaderInStart,
 | 
						|
			                                 &((uint8_t*)UDPHeaderInStart)[sizeof(UDP_Header_t)],
 | 
						|
		                                     &((uint8_t*)UDPHeaderOutStart)[sizeof(UDP_Header_t)]);
 | 
						|
			break;
 | 
						|
	}
 | 
						|
	
 | 
						|
	/* Check to see if the protocol processing routine has filled out a response */
 | 
						|
	if (RetSize > 0)
 | 
						|
	{
 | 
						|
		/* Fill out the response UDP packet header */
 | 
						|
		UDPHeaderOUT->SourcePort      = UDPHeaderIN->DestinationPort;
 | 
						|
		UDPHeaderOUT->DestinationPort = UDPHeaderIN->SourcePort;
 | 
						|
		UDPHeaderOUT->Checksum        = 0;
 | 
						|
		UDPHeaderOUT->Length          = SwapEndian_16(sizeof(UDP_Header_t) + RetSize);
 | 
						|
 | 
						|
		/* Return the size of the response so far */
 | 
						|
		return (sizeof(UDP_Header_t) + RetSize);
 | 
						|
	}
 | 
						|
	
 | 
						|
	return NO_RESPONSE;
 | 
						|
}
 |