Add more comments

git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@7138 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
jgong5 2008-12-26 09:09:02 +00:00
parent d17371e86b
commit cab450ccda
2 changed files with 174 additions and 91 deletions

View File

@ -2,10 +2,10 @@
The helper routines to access UDP service. It is used by both The helper routines to access UDP service. It is used by both
DHCP and MTFTP. DHCP and MTFTP.
Copyright (c) 2006 - 2008, Intel Corporation Copyright (c) 2006 - 2008, Intel Corporation.<BR>
All rights reserved. This program and the accompanying materials All rights reserved. This program and the accompanying materials
are licensed and made available under the terms and conditions of the BSD License are licensed and made available under the terms and conditions of the BSD License
which accompanies this distribution. The full text of the license may be found at which accompanies this distribution. The full text of the license may be found at<BR>
http://opensource.org/licenses/bsd-license.php http://opensource.org/licenses/bsd-license.php
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
@ -23,12 +23,18 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
typedef struct _UDP_IO_PORT UDP_IO_PORT; typedef struct _UDP_IO_PORT UDP_IO_PORT;
///
/// Signatures used by UdpIo Library.
///
typedef enum { typedef enum {
UDP_IO_RX_SIGNATURE = SIGNATURE_32 ('U', 'D', 'P', 'R'), UDP_IO_RX_SIGNATURE = SIGNATURE_32 ('U', 'D', 'P', 'R'),
UDP_IO_TX_SIGNATURE = SIGNATURE_32 ('U', 'D', 'P', 'T'), UDP_IO_TX_SIGNATURE = SIGNATURE_32 ('U', 'D', 'P', 'T'),
UDP_IO_SIGNATURE = SIGNATURE_32 ('U', 'D', 'P', 'I') UDP_IO_SIGNATURE = SIGNATURE_32 ('U', 'D', 'P', 'I')
} UDP_IO_SIGNATURE_TYPE; } UDP_IO_SIGNATURE_TYPE;
///
/// The Udp4 address pair.
///
typedef struct { typedef struct {
IP4_ADDR LocalAddr; IP4_ADDR LocalAddr;
UINT16 LocalPort; UINT16 LocalPort;
@ -36,27 +42,39 @@ typedef struct {
UINT16 RemotePort; UINT16 RemotePort;
} UDP_POINTS; } UDP_POINTS;
// /**
// This prototype is used by both receive and transmission. Prototype called when receiving or sending packets from/to a UDP point.
// When receiving Netbuf is allocated by UDP access point, and
// released by user. When transmitting, the NetBuf is from user, This prototype is used by both receive and sending when calling
// and provided to the callback as a reference. UdpIoRecvDatagram or UdpIoSendDatagram. When receiving, Netbuf is allocated by
// UDP access point, and released by user. When sending, the NetBuf is from user,
and provided to the callback as a reference.
@param Packet Packet received or sent
@param Points The Udp4 address pair corresponds to the Udp4 IO
@param IoStatus Packet receiving or sending status
@param Context User-defined data when calling UdpIoRecvDatagram or
UdpIoSendDatagram
@return None
**/
typedef typedef
VOID VOID
(*UDP_IO_CALLBACK) ( (EFIAPI *UDP_IO_CALLBACK) (
IN NET_BUF *Packet, IN NET_BUF *Packet,
IN UDP_POINTS *Points, IN UDP_POINTS *Points,
IN EFI_STATUS IoStatus, IN EFI_STATUS IoStatus,
IN VOID *Context IN VOID *Context
); );
// ///
// Each receive request is wrapped in an UDP_RX_TOKEN. Upon completion, /// This structure is used internally by UdpIo Library.
// the CallBack will be called. Only one receive request is send to UDP. ///
// HeadLen gives the length of the application's header. UDP_IO will /// Each receive request is wrapped in an UDP_RX_TOKEN. Upon completion,
// make the application's header continous before delivery up. /// the CallBack will be called. Only one receive request is sent to UDP at a
// /// time. HeadLen gives the length of the application's header. UDP_IO will
/// make the application's header continuous before delivering up.
///
typedef struct { typedef struct {
UINT32 Signature; UINT32 Signature;
UDP_IO_PORT *UdpIo; UDP_IO_PORT *UdpIo;
@ -68,10 +86,13 @@ typedef struct {
EFI_UDP4_COMPLETION_TOKEN UdpToken; EFI_UDP4_COMPLETION_TOKEN UdpToken;
} UDP_RX_TOKEN; } UDP_RX_TOKEN;
// ///
// Each transmit request is wrapped in an UDP_TX_TOKEN. Upon completion, /// This structure is used internally by UdpIo Library.
// the CallBack will be called. There can be several transmit requests. ///
// /// Each transmit request is wrapped in an UDP_TX_TOKEN. Upon completion,
/// the CallBack will be called. There can be several transmit requests and they
/// are linked in a list.
///
typedef struct { typedef struct {
UINT32 Signature; UINT32 Signature;
LIST_ENTRY Link; LIST_ENTRY Link;
@ -88,6 +109,12 @@ typedef struct {
EFI_UDP4_TRANSMIT_DATA UdpTxData; EFI_UDP4_TRANSMIT_DATA UdpTxData;
} UDP_TX_TOKEN; } UDP_TX_TOKEN;
///
/// Type defined as UDP_IO_PORT.
///
/// The data structure wraps Udp4 instance and its configuration. It is used by
/// UdpIo Library to do all Udp4 operations.
///
struct _UDP_IO_PORT { struct _UDP_IO_PORT {
UINT32 Signature; UINT32 Signature;
LIST_ENTRY Link; LIST_ENTRY Link;
@ -100,21 +127,43 @@ struct _UDP_IO_PORT {
EFI_HANDLE Image; EFI_HANDLE Image;
EFI_HANDLE UdpHandle; EFI_HANDLE UdpHandle;
EFI_UDP4_PROTOCOL *Udp; EFI_UDP4_PROTOCOL *Udp; ///< The wrapped Udp4 instance.
EFI_UDP4_CONFIG_DATA UdpConfig; EFI_UDP4_CONFIG_DATA UdpConfig;
EFI_SIMPLE_NETWORK_MODE SnpMode; EFI_SIMPLE_NETWORK_MODE SnpMode;
LIST_ENTRY SentDatagram; LIST_ENTRY SentDatagram; ///< A list of UDP_TX_TOKEN.
UDP_RX_TOKEN *RecvRequest; UDP_RX_TOKEN *RecvRequest;
}; };
/**
Prototype called when UdpIo Library configures a Udp4 instance.
The prototype is set and called when creating a UDP_IO_PORT in UdpIoCreatePort.
@param UdpIo The UDP_IO_PORT to configure
@param Context User-defined data when calling UdpIoCreatePort
@retval EFI_SUCCESS The configure process succeeds
@retval Others The UDP_IO_PORT fails to configure indicating
UdpIoCreatePort should fail
**/
typedef typedef
EFI_STATUS EFI_STATUS
(*UDP_IO_CONFIG) ( (EFIAPI *UDP_IO_CONFIG) (
IN UDP_IO_PORT *UdpIo, IN UDP_IO_PORT *UdpIo,
IN VOID *Context IN VOID *Context
); );
/**
The select function to decide whether to cancel the UDP_TX_TOKEN. It is used
@param Token The UDP_TX_TOKEN to decide whether to cancel
@param Context User-defined data in UdpIoCancelDgrams
@retval TRUE To cancel the UDP_TX_TOKEN
@retval FALSE Do not cancel this UDP_TX_TOKEN
**/
typedef typedef
BOOLEAN BOOLEAN
(*UDP_IO_TO_CANCEL) ( (*UDP_IO_TO_CANCEL) (
@ -123,8 +172,14 @@ BOOLEAN
); );
/** /**
Create a UDP IO port to access the UDP service. It will Create a UDP_IO_PORT to access the UDP service. It will create and configure
create and configure a UDP child. a UDP child.
The function will locate the UDP service binding prototype on the Controller
parameter and use it to create a UDP child (aka Udp instance). Then the UDP
child will be configured by calling Configure function prototype. Any failures
in creating or configure the UDP child will lead to the failure of UDP_IO_PORT
creation.
@param Controller The controller that has the UDP service binding @param Controller The controller that has the UDP service binding
protocol installed. protocol installed.
@ -132,7 +187,7 @@ BOOLEAN
@param Configure The function to configure the created UDP child @param Configure The function to configure the created UDP child
@param Context The opaque parameter for the Configure funtion. @param Context The opaque parameter for the Configure funtion.
@return A point to just created UDP IO port or NULL if some error happened. @return Newly-created UDP_IO_PORT or NULL if failed.
**/ **/
UDP_IO_PORT * UDP_IO_PORT *
@ -145,12 +200,13 @@ UdpIoCreatePort (
); );
/** /**
Free the UDP IO port and all its related resources including Free the UDP_IO_PORT and all its related resources.
all the transmitted packet.
The function will cancel all sent datagram and receive request.
@param UdpIo The UDP IO port to free. @param UdpIo The UDP_IO_PORT to free.
@retval EFI_SUCCESS The UDP IO port is freed. @retval EFI_SUCCESS The UDP_IO_PORT is freed.
**/ **/
EFI_STATUS EFI_STATUS
@ -160,11 +216,13 @@ UdpIoFreePort (
); );
/** /**
Clean up the UDP IO port. It will release all the transmitted Clean up the UDP_IO_PORT without freeing it. The function is called when
datagrams and receive request. It will also configure NULL the user wants to re-use the UDP_IO_PORT later.
UDP child.
It will release all the transmitted datagrams and receive request. It will
also configure NULL for the UDP instance.
@param UdpIo UDP IO port to clean up. @param UdpIo The UDP_IO_PORT to clean up.
**/ **/
VOID VOID
@ -174,15 +232,20 @@ UdpIoCleanPort (
); );
/** /**
Send a packet through the UDP IO port. Send a packet through the UDP_IO_PORT.
The packet will be wrapped in UDP_TX_TOKEN. Function Callback will be called
when the packet is sent. The optional parameter EndPoint overrides the default
address pair if specified.
@param UdpIo The UDP IO Port to send the packet through @param UdpIo The UDP_IO_PORT to send the packet through
@param Packet The packet to send @param Packet The packet to send
@param EndPoint The local and remote access point @param EndPoint The local and remote access point. Override the
default address pair set during configuration.
@param Gateway The gateway to use @param Gateway The gateway to use
@param CallBack The call back function to call when packet is @param CallBack The function being called when packet is
transmitted or failed. transmitted or failed.
@param Context The opque parameter to the CallBack @param Context The opaque parameter passed to CallBack
@retval EFI_OUT_OF_RESOURCES Failed to allocate resource for the packet @retval EFI_OUT_OF_RESOURCES Failed to allocate resource for the packet
@retval EFI_SUCCESS The packet is successfully delivered to UDP for @retval EFI_SUCCESS The packet is successfully delivered to UDP for
@ -194,7 +257,7 @@ EFIAPI
UdpIoSendDatagram ( UdpIoSendDatagram (
IN UDP_IO_PORT *UdpIo, IN UDP_IO_PORT *UdpIo,
IN NET_BUF *Packet, IN NET_BUF *Packet,
IN UDP_POINTS *EndPoint, OPTIONAL IN UDP_POINTS *EndPoint OPTIONAL,
IN IP4_ADDR Gateway, IN IP4_ADDR Gateway,
IN UDP_IO_CALLBACK CallBack, IN UDP_IO_CALLBACK CallBack,
IN VOID *Context IN VOID *Context
@ -203,7 +266,7 @@ UdpIoSendDatagram (
/** /**
Cancel a single sent datagram. Cancel a single sent datagram.
@param UdpIo The UDP IO port to cancel the packet from @param UdpIo The UDP_IO_PORT to cancel the packet from
@param Packet The packet to cancel @param Packet The packet to cancel
**/ **/
@ -215,17 +278,22 @@ UdpIoCancelSentDatagram (
); );
/** /**
Issue a receive request to the UDP IO port. Issue a receive request to the UDP_IO_PORT.
This function is called when upper-layer needs packet from UDP for processing.
Only one receive request is acceptable at a time so a common usage model is
to invoke this function inside its Callback function when the former packet
is processed.
@param UdpIo The UDP IO port to recieve the packet from. @param UdpIo The UDP_IO_PORT to receive the packet from.
@param CallBack The call back function to execute when receive @param CallBack The call back function to execute when the packet
finished. is received.
@param Context The opque context to the call back @param Context The opaque context passed to Callback
@param HeadLen The lenght of the application's header @param HeadLen The length of the upper-layer's protocol header
@retval EFI_ALREADY_STARTED There is already a pending receive request. Only @retval EFI_ALREADY_STARTED There is already a pending receive request. Only
one receive request is supported. one receive request is supported at a time.
@retval EFI_OUT_OF_RESOURCES Failed to allocate some resource. @retval EFI_OUT_OF_RESOURCES Failed to allocate needed resources.
@retval EFI_SUCCESS The receive request is issued successfully. @retval EFI_SUCCESS The receive request is issued successfully.
**/ **/

View File

@ -4,7 +4,7 @@
Copyright (c) 2005 - 2007, Intel Corporation.<BR> Copyright (c) 2005 - 2007, Intel Corporation.<BR>
All rights reserved. This program and the accompanying materials All rights reserved. This program and the accompanying materials
are licensed and made available under the terms and conditions of the BSD License are licensed and made available under the terms and conditions of the BSD License
which accompanies this distribution. The full text of the license may be found at which accompanies this distribution. The full text of the license may be found at<BR>
http://opensource.org/licenses/bsd-license.php http://opensource.org/licenses/bsd-license.php
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
@ -24,7 +24,7 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
/** /**
Free a UDP_TX_TOKEN. The event is closed and memory released. Free a UDP_TX_TOKEN. The TX event is closed.
@param Token The UDP_TX_TOKEN to release. @param Token The UDP_TX_TOKEN to release.
@ -39,9 +39,9 @@ UdpIoFreeTxToken (
} }
/** /**
Free a receive request wrap. Free a UDP_RX_TOKEN. The RX event is closed.
@param Token The receive request to release. @param Token The UDP_RX_TOKEN to release.
**/ **/
VOID VOID
@ -55,8 +55,9 @@ UdpIoFreeRxToken (
/** /**
The callback function when the packet is sent by UDP. The callback function when the packet is sent by UDP.
It will remove the packet from the local list then call It will remove the packet from the local list then call
the packet owner's callback function. the packet owner's callback function set by UdpIoSendDatagram.
@param Context The UDP TX Token. @param Context The UDP TX Token.
@ -117,8 +118,9 @@ UdpIoRecycleDgram (
} }
/** /**
The event handle for UDP receive request. It will build The event handle for UDP receive request.
a NET_BUF from the recieved UDP data, then deliver it
It will build a NET_BUF from the recieved UDP data, then deliver it
to the receiver. to the receiver.
@param Context The UDP RX token. @param Context The UDP RX token.
@ -363,12 +365,15 @@ UdpIoWrapTx (
return Token; return Token;
} }
/** /**
Create a UDP IO port to access the UDP service. It will Create a UDP_IO_PORT to access the UDP service. It will create and configure
create and configure a UDP child. a UDP child.
The function will locate the UDP service binding prototype on the Controller
parameter and use it to create a UDP child (aka Udp instance). Then the UDP
child will be configured by calling Configure function prototype. Any failures
in creating or configure the UDP child will lead to the failure of UDP_IO_PORT
creation.
@param Controller The controller that has the UDP service binding @param Controller The controller that has the UDP service binding
protocol installed. protocol installed.
@ -376,7 +381,7 @@ UdpIoWrapTx (
@param Configure The function to configure the created UDP child @param Configure The function to configure the created UDP child
@param Context The opaque parameter for the Configure funtion. @param Context The opaque parameter for the Configure funtion.
@return A point to just created UDP IO port or NULL if some error happened. @return Newly-created UDP_IO_PORT or NULL if failed.
**/ **/
UDP_IO_PORT * UDP_IO_PORT *
@ -465,12 +470,11 @@ FREE_MEM:
return NULL; return NULL;
} }
/** /**
Cancel all the sent datagram that pass the selection of ToCancel. Cancel all the sent datagram that pass the selection criteria of ToCancel.
If ToCancel is NULL, all the datagrams are cancelled. If ToCancel is NULL, all the datagrams are cancelled.
@param UdpIo The UDP IO port to cancel packet @param UdpIo The UDP_IO_PORT to cancel packet
@param IoStatus The IoStatus to return to the packet owners. @param IoStatus The IoStatus to return to the packet owners.
@param ToCancel The select funtion to test whether to cancel this @param ToCancel The select funtion to test whether to cancel this
packet or not. packet or not.
@ -498,14 +502,14 @@ UdpIoCancelDgrams (
} }
} }
/** /**
Free the UDP IO port and all its related resources including Free the UDP_IO_PORT and all its related resources.
all the transmitted packet.
The function will cancel all sent datagram and receive request.
@param UdpIo The UDP IO port to free. @param UdpIo The UDP_IO_PORT to free.
@retval EFI_SUCCESS The UDP IO port is freed. @retval EFI_SUCCESS The UDP_IO_PORT is freed.
**/ **/
EFI_STATUS EFI_STATUS
@ -557,11 +561,13 @@ UdpIoFreePort (
/** /**
Clean up the UDP IO port. It will release all the transmitted Clean up the UDP_IO_PORT without freeing it. The function is called when
datagrams and receive request. It will also configure NULL the user wants to re-use the UDP_IO_PORT later.
UDP child.
It will release all the transmitted datagrams and receive request. It will
also configure NULL for the UDP instance.
@param UdpIo UDP IO port to clean up. @param UdpIo The UDP_IO_PORT to clean up.
**/ **/
VOID VOID
@ -585,15 +591,20 @@ UdpIoCleanPort (
} }
/** /**
Send a packet through the UDP IO port. Send a packet through the UDP_IO_PORT.
The packet will be wrapped in UDP_TX_TOKEN. Function Callback will be called
when the packet is sent. The optional parameter EndPoint overrides the default
address pair if specified.
@param UdpIo The UDP IO Port to send the packet through @param UdpIo The UDP_IO_PORT to send the packet through
@param Packet The packet to send @param Packet The packet to send
@param EndPoint The local and remote access point @param EndPoint The local and remote access point. Override the
default address pair set during configuration.
@param Gateway The gateway to use @param Gateway The gateway to use
@param CallBack The call back function to call when packet is @param CallBack The function being called when packet is
transmitted or failed. transmitted or failed.
@param Context The opque parameter to the CallBack @param Context The opaque parameter passed to CallBack
@retval EFI_OUT_OF_RESOURCES Failed to allocate resource for the packet @retval EFI_OUT_OF_RESOURCES Failed to allocate resource for the packet
@retval EFI_SUCCESS The packet is successfully delivered to UDP for @retval EFI_SUCCESS The packet is successfully delivered to UDP for
@ -637,10 +648,10 @@ UdpIoSendDatagram (
/** /**
The selection function to cancel a single sent datagram. The select function to cancel a single sent datagram.
@param Token The UDP TX token to test againist. @param Token The UDP_TX_TOKEN to test against
@param Context The context @param Context The NET_BUF of the sent datagram
@retval TRUE The packet is to be cancelled. @retval TRUE The packet is to be cancelled.
@retval FALSE The packet is not to be cancelled. @retval FALSE The packet is not to be cancelled.
@ -662,11 +673,10 @@ UdpIoCancelSingleDgram (
return FALSE; return FALSE;
} }
/** /**
Cancel a single sent datagram. Cancel a single sent datagram.
@param UdpIo The UDP IO port to cancel the packet from @param UdpIo The UDP_IO_PORT to cancel the packet from
@param Packet The packet to cancel @param Packet The packet to cancel
**/ **/
@ -681,17 +691,22 @@ UdpIoCancelSentDatagram (
} }
/** /**
Issue a receive request to the UDP IO port. Issue a receive request to the UDP_IO_PORT.
This function is called when upper-layer needs packet from UDP for processing.
Only one receive request is acceptable at a time so a common usage model is
to invoke this function inside its Callback function when the former packet
is processed.
@param UdpIo The UDP IO port to recieve the packet from. @param UdpIo The UDP_IO_PORT to receive the packet from.
@param CallBack The call back function to execute when receive @param CallBack The call back function to execute when the packet
finished. is received.
@param Context The opque context to the call back @param Context The opaque context passed to Callback
@param HeadLen The lenght of the application's header @param HeadLen The length of the upper-layer's protocol header
@retval EFI_ALREADY_STARTED There is already a pending receive request. Only @retval EFI_ALREADY_STARTED There is already a pending receive request. Only
one receive request is supported. one receive request is supported at a time.
@retval EFI_OUT_OF_RESOURCES Failed to allocate some resource. @retval EFI_OUT_OF_RESOURCES Failed to allocate needed resources.
@retval EFI_SUCCESS The receive request is issued successfully. @retval EFI_SUCCESS The receive request is issued successfully.
**/ **/