]> git.proxmox.com Git - mirror_edk2.git/blobdiff - MdeModulePkg/Universal/Network/Tcp4Dxe/SockImpl.c
[Change summary]:
[mirror_edk2.git] / MdeModulePkg / Universal / Network / Tcp4Dxe / SockImpl.c
index 14342dfff02ed37bec70f1d4712b225e65131855..dad64ae447d251ead855d39de0e3b9efcba91aed 100644 (file)
@@ -1,21 +1,15 @@
 /** @file\r
+  Implementation of the Socket.\r
 \r
-Copyright (c) 2005 - 2006, Intel Corporation\r
+Copyright (c) 2005 - 2009, Intel Corporation<BR>\r
 All rights reserved. This program and the accompanying materials\r
 are licensed and made available under the terms and conditions of the BSD License\r
 which accompanies this distribution.  The full text of the license may be found at\r
-http://opensource.org/licenses/bsd-license.php\r
+http://opensource.org/licenses/bsd-license.php<BR>\r
 \r
 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
 \r
-Module Name:\r
-\r
-  SockImpl.c\r
-\r
-Abstract:\r
-\r
-\r
 **/\r
 \r
 #include "SockImpl.h"\r
@@ -35,9 +29,9 @@ Abstract:
 **/\r
 UINT32\r
 SockTcpDataToRcv (\r
-  IN  SOCK_BUFFER   *SockBuffer,\r
-  OUT BOOLEAN       *IsOOB,\r
-  IN  UINT32        BufLen\r
+  IN     SOCK_BUFFER    *SockBuffer,\r
+     OUT BOOLEAN        *IsUrg,\r
+  IN     UINT32         BufLen\r
   );\r
   \r
 /**\r
@@ -48,12 +42,14 @@ SockTcpDataToRcv (
 **/\r
 VOID\r
 SockProcessSndToken (\r
-  IN SOCKET *Sock\r
+  IN OUT SOCKET *Sock\r
   );\r
 \r
 /**\r
-    \r
+  Supporting function for both SockImpl and SockInterface.\r
 \r
+  @param Event             The Event this notify function registered to, ignored.\r
+  \r
 **/\r
 VOID\r
 SockFreeFoo (\r
@@ -88,7 +84,6 @@ SockTcpDataToRcv (
   UINT32        DataLen;\r
   TCP_RSV_DATA  *TcpRsvData;\r
   BOOLEAN       Urg;\r
-\r
   ASSERT ((SockBuffer != NULL) && (IsUrg != NULL) && (BufLen > 0));\r
 \r
   RcvBufEntry = SockBufFirst (SockBuffer);\r
@@ -154,7 +149,7 @@ SockTcpDataToRcv (
   @param  Sock                  Pointer to the socket.\r
   @param  TcpRxData             Pointer to the application provided receive buffer.\r
   @param  RcvdBytes             The maximum length of the data can be copied.\r
-  @param  IsOOB                 If TURE the data is OOB, else the data is normal.\r
+  @param  IsOOB                 If TURE the data is OOB, FALSE the data is normal.\r
 \r
 **/\r
 VOID\r
@@ -210,8 +205,8 @@ SockSetTcpRxData (
 **/\r
 UINT32\r
 SockProcessRcvToken (\r
-  IN SOCKET        *Sock,\r
-  IN SOCK_IO_TOKEN *RcvToken\r
+  IN     SOCKET        *Sock,\r
+  IN OUT SOCK_IO_TOKEN *RcvToken\r
   )\r
 {\r
   UINT32                 TokenRcvdBytes;\r
@@ -220,7 +215,7 @@ SockProcessRcvToken (
 \r
   ASSERT (Sock != NULL);\r
 \r
-  ASSERT (SOCK_STREAM == Sock->Type);\r
+  ASSERT (SockStream == Sock->Type);\r
 \r
   RxData = RcvToken->Packet.RxData;\r
 \r
@@ -236,7 +231,7 @@ SockProcessRcvToken (
   //\r
   SockSetTcpRxData (Sock, RxData, TokenRcvdBytes, IsUrg);\r
 \r
-  SOCK_TRIM_RCV_BUFF (Sock, TokenRcvdBytes);\r
+  NetbufQueTrim (Sock->RcvBuffer.DataQueue, TokenRcvdBytes);\r
   SIGNAL_TOKEN (&(RcvToken->Token), EFI_SUCCESS);\r
 \r
   return TokenRcvdBytes;\r
@@ -248,7 +243,7 @@ SockProcessRcvToken (
   the buffer to socket send buffer,then try to send it.\r
 \r
   @param  Sock                  Pointer to the socket.\r
-  @param  TcpTxData             Pointer to the tcp txdata.\r
+  @param  TcpTxData             Pointer to the application provided send buffer.\r
 \r
   @retval EFI_SUCCESS           The operation is completed successfully.\r
   @retval EFI_OUT_OF_RESOURCES  Failed due to resource limit.\r
@@ -364,7 +359,7 @@ SockFlushPendingToken (
 **/\r
 VOID\r
 SockWakeConnToken (\r
-  IN SOCKET *Sock\r
+  IN OUT SOCKET *Sock\r
   )\r
 {\r
   ASSERT (Sock->ConnectionToken != NULL);\r
@@ -388,7 +383,7 @@ SockWakeConnToken (
 **/\r
 VOID\r
 SockWakeListenToken (\r
-  IN SOCKET *Sock\r
+  IN OUT SOCKET *Sock\r
   )\r
 {\r
   SOCKET                *Parent;\r
@@ -417,7 +412,7 @@ SockWakeListenToken (
     RemoveEntryList (&Sock->ConnectionList);\r
 \r
     Parent->ConnCnt--;\r
-    DEBUG ((EFI_D_WARN, "SockWakeListenToken: accept a socket, now conncnt is %d", Parent->ConnCnt));\r
+    DEBUG ((EFI_D_INFO, "SockWakeListenToken: accept a socket, now conncnt is %d", Parent->ConnCnt));\r
 \r
     Sock->Parent = NULL;\r
   }\r
@@ -476,7 +471,7 @@ SockWakeRcvToken (
 **/\r
 VOID\r
 SockProcessSndToken (\r
-  IN SOCKET *Sock\r
+  IN OUT SOCKET *Sock\r
   )\r
 {\r
   UINT32                  FreeSpace;\r
@@ -486,7 +481,7 @@ SockProcessSndToken (
   EFI_TCP4_TRANSMIT_DATA  *TxData;\r
   EFI_STATUS              Status;\r
 \r
-  ASSERT ((Sock != NULL) && (SOCK_STREAM == Sock->Type));\r
+  ASSERT ((Sock != NULL) && (SockStream == Sock->Type));\r
 \r
   FreeSpace = SockGetFreeSpace (Sock, SOCK_SND_BUF);\r
 \r
@@ -549,7 +544,7 @@ OnError:
 \r
   @param  SockInitData          Pointer to the initial data of the socket.\r
 \r
-  @return Pointer to the newly created socket.\r
+  @return Pointer to the newly created socket, return NULL when exception occured.\r
 \r
 **/\r
 SOCKET *\r
@@ -562,7 +557,7 @@ SockCreate (
   EFI_STATUS  Status;\r
 \r
   ASSERT ((SockInitData != NULL) && (SockInitData->ProtoHandler != NULL));\r
-  ASSERT (SockInitData->Type == SOCK_STREAM);\r
+  ASSERT (SockInitData->Type == SockStream);\r
   ASSERT ((SockInitData->ProtoData != NULL) && (SockInitData->DataSize <= PROTO_RESERVED_LEN));\r
 \r
   Parent = SockInitData->Parent;\r
@@ -668,7 +663,7 @@ SockCreate (
     Parent->ConnCnt++;\r
 \r
     DEBUG (\r
-      (EFI_D_WARN,\r
+      (EFI_D_INFO,\r
       "SockCreate: Create a new socket and add to parent, now conncnt is %d\n",\r
       Parent->ConnCnt)\r
       );\r
@@ -718,14 +713,14 @@ OnError:
 **/\r
 VOID\r
 SockDestroy (\r
-  IN SOCKET *Sock\r
+  IN OUT SOCKET *Sock\r
   )\r
 {\r
   VOID        *SockProtocol;\r
   EFI_GUID    *ProtocolGuid;\r
   EFI_STATUS  Status;\r
 \r
-  ASSERT (SOCK_STREAM == Sock->Type);\r
+  ASSERT (SockStream == Sock->Type);\r
 \r
   if (Sock->DestroyCallback != NULL) {\r
     Sock->DestroyCallback (Sock, Sock->Context);\r
@@ -757,7 +752,7 @@ SockDestroy (
     (Sock->Parent->ConnCnt)--;\r
 \r
     DEBUG (\r
-      (EFI_D_WARN,\r
+      (EFI_D_INFO,\r
       "SockDestory: Delete a unaccepted socket from parent"\r
       "now conncnt is %d\n",\r
       Sock->Parent->ConnCnt)\r
@@ -810,14 +805,14 @@ FreeSock:
 \r
 \r
 /**\r
-  Flush the socket.\r
+  Flush the sndBuffer and rcvBuffer of socket.\r
 \r
   @param  Sock                  Pointer to the socket.\r
 \r
 **/\r
 VOID\r
 SockConnFlush (\r
-  IN SOCKET *Sock\r
+  IN OUT SOCKET *Sock\r
   )\r
 {\r
   SOCKET  *Child;\r
@@ -878,13 +873,13 @@ SockConnFlush (
   Set the state of the socket.\r
 \r
   @param  Sock                  Pointer to the socket.\r
-  @param  State                 The new state to be set.\r
+  @param  State                 The new socket state to be set.\r
 \r
 **/\r
 VOID\r
 SockSetState (\r
-  IN SOCKET     *Sock,\r
-  IN SOCK_STATE State\r
+  IN OUT SOCKET     *Sock,\r
+  IN     UINT8      State\r
   )\r
 {\r
   Sock->State = State;\r
@@ -938,7 +933,9 @@ SockClone (
 \r
 /**\r
   Called by the low layer protocol to indicate the socket a connection is \r
-  established. This function just changes the socket's state to SO_CONNECTED \r
+  established. \r
+  \r
+  This function just changes the socket's state to SO_CONNECTED \r
   and signals the token used for connection establishment.\r
 \r
   @param  Sock                  Pointer to the socket associated with the\r
@@ -965,16 +962,18 @@ SockConnEstablished (
 \r
 \r
 /**\r
-  Called by the low layer protocol to indicate the connection is closed; This \r
-  function flushes the socket, sets the state to SO_CLOSED and signals the close \r
-  token.\r
+  Called by the low layer protocol to indicate the connection is closed.\r
+  \r
+  This function flushes the socket, sets the state to SO_CLOSED and signals \r
+  the close token.\r
 \r
   @param  Sock                  Pointer to the socket associated with the closed\r
                                 connection.\r
+                                \r
 **/\r
 VOID\r
 SockConnClosed (\r
-  IN SOCKET *Sock\r
+  IN OUT SOCKET *Sock\r
   )\r
 {\r
   if (Sock->CloseToken != NULL) {\r
@@ -993,7 +992,8 @@ SockConnClosed (
 \r
 \r
 /**\r
-  Called by low layer protocol to indicate that some data is sent or processed; \r
+  Called by low layer protocol to indicate that some data is sent or processed.\r
+   \r
   This function trims the sent data in the socket send buffer, signals the data \r
   token if proper.\r
 \r
@@ -1070,7 +1070,7 @@ SockGetDataToSend (
   IN UINT8       *Dest\r
   )\r
 {\r
-  ASSERT ((Sock != NULL) && SOCK_STREAM == Sock->Type);\r
+  ASSERT ((Sock != NULL) && SockStream == Sock->Type);\r
 \r
   return NetbufQueCopy (\r
           Sock->SndBuffer.DataQueue,\r
@@ -1082,7 +1082,8 @@ SockGetDataToSend (
 \r
 \r
 /**\r
-  Called by the low layer protocol to deliver received data to socket layer; \r
+  Called by the low layer protocol to deliver received data to socket layer.\r
+  \r
   This function will append the data to the socket receive buffer, set ther \r
   urgent data length and then check if any receive token can be signaled.\r
 \r
@@ -1094,9 +1095,9 @@ SockGetDataToSend (
 **/\r
 VOID\r
 SockDataRcvd (\r
-  IN SOCKET    *Sock,\r
-  IN NET_BUF   *NetBuffer,\r
-  IN UINT32    UrgLen\r
+  IN     SOCKET    *Sock,\r
+  IN OUT NET_BUF   *NetBuffer,\r
+  IN     UINT32    UrgLen\r
   )\r
 {\r
   ASSERT ((Sock != NULL) && (Sock->RcvBuffer.DataQueue != NULL) &&\r
@@ -1161,8 +1162,8 @@ SockGetFreeSpace (
 **/\r
 VOID\r
 SockRcvdErr (\r
-  IN SOCKET       *Sock,\r
-  IN EFI_STATUS   Error\r
+  IN OUT SOCKET       *Sock,\r
+  IN     EFI_STATUS   Error\r
   )\r
 {\r
   SOCK_TOKEN  *SockToken;\r
@@ -1188,18 +1189,18 @@ SockRcvdErr (
 \r
 \r
 /**\r
-  Called by the low layer protocol to indicate that there\r
-  will be no more data from the communication peer; This\r
-  function set the socket's state to SO_NO_MORE_DATA and\r
-  signal all queued IO tokens with the error status\r
-  EFI_CONNECTION_FIN.\r
+  Called by the low layer protocol to indicate that there will be no more data \r
+  from the communication peer.\r
+  \r
+  This function set the socket's state to SO_NO_MORE_DATA and signal all queued \r
+  IO tokens with the error status EFI_CONNECTION_FIN.\r
 \r
   @param  Sock                  Pointer to the socket.\r
 \r
 **/\r
 VOID\r
 SockNoMoreData (\r
-  IN SOCKET *Sock\r
+  IN OUT SOCKET *Sock\r
   )\r
 {\r
   EFI_STATUS  Err;\r