Add Socket Libraries.
Add Posix functions for porting compatibility. Fix compliance issues with ISO/IEC 9899:199409 New Functions: setenv(), fparseln(), GetFileNameFromPath(), rename(), realpath(), setprogname(), getprogname(), strlcat(), strlcpy(), strsep(), setitimer(), getitimer(), timegm(), getopt(), basename(), mkstemp(), ffs(), vsnprintf(), snprintf(), getpass(), usleep(), select(), writev(), strcasecmp(), getcwd(), chdir(), tcgetpgrp(), getpgrp(), gettimeofday(), bcopy(), git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@12061 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
190
StdLib/BsdSocketLib/SocketInternals.h
Normal file
190
StdLib/BsdSocketLib/SocketInternals.h
Normal file
@ -0,0 +1,190 @@
|
||||
/** @file
|
||||
Definitions for the socket library.
|
||||
|
||||
Copyright (c) 2011, Intel Corporation
|
||||
All rights reserved. This program and the accompanying materials
|
||||
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
|
||||
http://opensource.org/licenses/bsd-license.php
|
||||
|
||||
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
||||
|
||||
**/
|
||||
|
||||
#ifndef _SOCKET_INTERNALS_H_
|
||||
#define _SOCKET_INTERNALS_H_
|
||||
|
||||
#include <Uefi.h>
|
||||
|
||||
//----------------------------------------------------------------------
|
||||
//
|
||||
// The following private files are required to support file descriptors
|
||||
//
|
||||
|
||||
#include <kfile.h>
|
||||
#include <MainData.h>
|
||||
|
||||
#include <efi/SysEfi.h>
|
||||
|
||||
//
|
||||
// End of private files
|
||||
//
|
||||
//----------------------------------------------------------------------
|
||||
|
||||
#include <Library/DebugLib.h>
|
||||
#include <Library/UefiBootServicesTableLib.h>
|
||||
#include <Library/UefiLib.h>
|
||||
|
||||
#include <Protocol/EfiSocket.h>
|
||||
#include <Protocol/ServiceBinding.h>
|
||||
|
||||
#include <sys/errno.h>
|
||||
#include <sys/poll.h>
|
||||
#include <sys/EfiSysCall.h>
|
||||
#include <sys/socket.h>
|
||||
|
||||
//------------------------------------------------------------------------------
|
||||
// Support Routines
|
||||
//------------------------------------------------------------------------------
|
||||
|
||||
/**
|
||||
Translate from the socket file descriptor to the socket protocol.
|
||||
|
||||
@param [in] s Socket file descriptor returned from ::socket.
|
||||
|
||||
@param [in] ppDescriptor Address to receive the descriptor structure
|
||||
address for the file
|
||||
@param [in] pErrno Address of the errno variable
|
||||
|
||||
@returns A pointer to the socket protocol structure or NULL if
|
||||
an invalid file descriptor was passed in.
|
||||
|
||||
**/
|
||||
EFI_SOCKET_PROTOCOL *
|
||||
BslFdToSocketProtocol (
|
||||
int s,
|
||||
struct __filedes ** ppDescriptor,
|
||||
int * pErrno
|
||||
);
|
||||
|
||||
/**
|
||||
Close the socket
|
||||
|
||||
@param [in] pDescriptor Descriptor address for the file
|
||||
|
||||
@returns This routine returns 0 upon success and -1 upon failure.
|
||||
In the case of failure, errno contains more information.
|
||||
|
||||
**/
|
||||
INT32
|
||||
BslSocketClose (
|
||||
struct __filedes * pDescriptor
|
||||
);
|
||||
|
||||
/**
|
||||
Worker routine to close the socket.
|
||||
|
||||
@param [in] pSocketProtocol Socket protocol structure address
|
||||
|
||||
@param [in] pErrno Address of the errno variable
|
||||
|
||||
@retval EFI_SUCCESS Successfully closed the socket
|
||||
|
||||
**/
|
||||
EFI_STATUS
|
||||
BslSocketCloseWork (
|
||||
IN EFI_SOCKET_PROTOCOL * pSocketProtocol,
|
||||
IN int * pErrno
|
||||
);
|
||||
|
||||
/**
|
||||
Poll the socket for activity
|
||||
|
||||
@param [in] pDescriptor Descriptor address for the file
|
||||
|
||||
@param [in] Events Mask of events to detect
|
||||
|
||||
@returns Detected events for the socket
|
||||
|
||||
**/
|
||||
short
|
||||
BslSocketPoll (
|
||||
IN struct __filedes * pDescriptor,
|
||||
IN short Events
|
||||
);
|
||||
|
||||
/**
|
||||
Build a file descriptor for a socket.
|
||||
|
||||
@param [in] pSocketProtocol Socket protocol structure address
|
||||
|
||||
@param [in] pErrno Address of the errno variable
|
||||
|
||||
@returns The file descriptor for the socket or -1 if an error occurs.
|
||||
|
||||
**/
|
||||
int
|
||||
BslSocketProtocolToFd (
|
||||
IN EFI_SOCKET_PROTOCOL * pSocketProtocol,
|
||||
IN int * pErrno
|
||||
);
|
||||
|
||||
/**
|
||||
Read support routine for sockets
|
||||
|
||||
@param [in] pDescriptor Descriptor address for the file
|
||||
@param [in] pOffset File offset
|
||||
@param [in] LengthInBytes Number of bytes to read
|
||||
@param [in] pBuffer Address of the buffer to receive the data
|
||||
|
||||
@returns The number of bytes read or -1 if an error occurs.
|
||||
|
||||
**/
|
||||
ssize_t
|
||||
BslSocketRead (
|
||||
struct __filedes *pDescriptor,
|
||||
off_t * pOffset,
|
||||
size_t LengthInBytes,
|
||||
void * pBuffer
|
||||
);
|
||||
|
||||
/**
|
||||
Write support routine for sockets
|
||||
|
||||
@param [in] pDescriptor Descriptor address for the file
|
||||
@param [in] pOffset File offset
|
||||
@param [in] LengthInBytes Number of bytes to write
|
||||
@param [in] pBuffer Address of the data
|
||||
|
||||
@returns The number of bytes written or -1 if an error occurs.
|
||||
|
||||
**/
|
||||
ssize_t
|
||||
BslSocketWrite (
|
||||
struct __filedes *pDescriptor,
|
||||
off_t * pOffset,
|
||||
size_t LengthInBytes,
|
||||
const void * pBuffer
|
||||
);
|
||||
|
||||
/**
|
||||
Validate the socket's file descriptor
|
||||
|
||||
@param [in] pDescriptor Descriptor for the file
|
||||
|
||||
@param [in] pErrno Address of the errno variable
|
||||
|
||||
@returns A pointer to the socket protocol structure or NULL if
|
||||
an invalid file descriptor was passed in.
|
||||
|
||||
**/
|
||||
EFI_SOCKET_PROTOCOL *
|
||||
BslValidateSocketFd (
|
||||
struct __filedes * pDescriptor,
|
||||
int * pErrno
|
||||
);
|
||||
|
||||
//------------------------------------------------------------------------------
|
||||
|
||||
#endif // _SOCKET_INTERNALS_H_
|
Reference in New Issue
Block a user