https://bugzilla.tianocore.org/show_bug.cgi?id=1373 Replace BSD 2-Clause License with BSD+Patent License. This change is based on the following emails: https://lists.01.org/pipermail/edk2-devel/2019-February/036260.html https://lists.01.org/pipermail/edk2-devel/2018-October/030385.html RFCs with detailed process for the license change: V3: https://lists.01.org/pipermail/edk2-devel/2019-March/038116.html V2: https://lists.01.org/pipermail/edk2-devel/2019-March/037669.html V1: https://lists.01.org/pipermail/edk2-devel/2019-March/037500.html Contributed-under: TianoCore Contribution Agreement 1.1 Signed-off-by: Michael D Kinney <michael.d.kinney@intel.com> Reviewed-by: Jaben Carsey <jaben.carsey@intel.com>
112 lines
2.7 KiB
C
112 lines
2.7 KiB
C
/** @file
|
|
Implement the constructor and destructor for the EFI socket library
|
|
|
|
Copyright (c) 2011, Intel Corporation. All rights reserved.
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
|
|
|
**/
|
|
|
|
#include "Socket.h"
|
|
|
|
|
|
/**
|
|
EFI Socket Library Constructor
|
|
|
|
This routine supports an implementation dependent constructor
|
|
depending upon whether the library is linked to a socket
|
|
application or the SocketDxe driver. The following modules
|
|
declare the redirection for the constructor in ::mpfnEslConstructor:
|
|
<ul>
|
|
<li>StdLib/EfiSocketLib/UseSocketLib.c - Application links against EfiSocketLib</li>
|
|
<li>StdLib/SocketDxe/EntryUnload.c - SocketDxe links against EfiSocketLib</li>
|
|
</ul>
|
|
|
|
The EfiSocketLib.inf file lists ::EslConstructor as the CONSTRUCTOR
|
|
in the [Defines] section. As a result, this routine is called by
|
|
the ProcessLibraryConstructorList routine of the AutoGen.c module
|
|
in the Build directory associated with the socket application or
|
|
the SocketDxe driver.
|
|
|
|
@retval EFI_SUCCESS The socket layer initialization was successful
|
|
|
|
**/
|
|
EFI_STATUS
|
|
EFIAPI
|
|
EslConstructor (
|
|
VOID
|
|
)
|
|
{
|
|
EFI_STATUS Status;
|
|
|
|
DBG_ENTER ( );
|
|
|
|
//
|
|
// Assume success
|
|
//
|
|
Status = EFI_SUCCESS;
|
|
|
|
//
|
|
// Call the image dependent constructor if available
|
|
//
|
|
if ( NULL != mpfnEslConstructor ) {
|
|
Status = mpfnEslConstructor ( );
|
|
}
|
|
|
|
//
|
|
// Return the constructor status
|
|
//
|
|
DBG_EXIT_STATUS ( Status );
|
|
return Status;
|
|
}
|
|
|
|
|
|
/**
|
|
EFI Socket Library Destructor
|
|
|
|
This routine supports an implementation dependent destructor
|
|
depending upon whether the library is linked to a socket
|
|
application or the SocketDxe driver. The following modules
|
|
declare the redirection for the destructor in ::mpfnEslDestructor:
|
|
<ul>
|
|
<li>StdLib/EfiSocketLib/UseSocketLib.c - Application links against EfiSocketLib</li>
|
|
<li>StdLib/SocketDxe/EntryUnload.c - SocketDxe links against EfiSocketLib</li>
|
|
</ul>
|
|
|
|
The EfiSocketLib.inf file lists ::EslDestructor as the DESTRUCTOR
|
|
in the [Defines] section. As a result, this routine is called by
|
|
the ProcessLibraryDestructorList routine of the AutoGen.c module
|
|
in the Build directory associated with the socket application or
|
|
the SocketDxe driver.
|
|
|
|
@retval EFI_SUCCESS The socket layer shutdown was successful
|
|
|
|
**/
|
|
EFI_STATUS
|
|
EFIAPI
|
|
EslDestructor (
|
|
VOID
|
|
)
|
|
{
|
|
EFI_STATUS Status;
|
|
|
|
DBG_ENTER ( );
|
|
|
|
//
|
|
// Assume success
|
|
//
|
|
Status = EFI_SUCCESS;
|
|
|
|
//
|
|
// Call the image dependent destructor if available
|
|
//
|
|
if ( NULL != mpfnEslDestructor ) {
|
|
Status = mpfnEslDestructor ( );
|
|
}
|
|
|
|
//
|
|
// Return the constructor status
|
|
//
|
|
DBG_EXIT_STATUS ( Status );
|
|
return Status;
|
|
}
|