2010-11-01 07:13:54 +01:00
|
|
|
/** @file
|
|
|
|
Functions declaration related with Mtftp for UefiPxeBc Driver.
|
|
|
|
|
2015-07-08 14:17:11 +02:00
|
|
|
Copyright (c) 2007 - 2015, Intel Corporation. All rights reserved.<BR>
|
2010-11-01 07:13:54 +01:00
|
|
|
|
|
|
|
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 __EFI_PXEBC_MTFTP_H__
|
|
|
|
#define __EFI_PXEBC_MTFTP_H__
|
|
|
|
|
|
|
|
#define PXE_MTFTP_OPTION_BLKSIZE_INDEX 0
|
|
|
|
#define PXE_MTFTP_OPTION_TIMEOUT_INDEX 1
|
|
|
|
#define PXE_MTFTP_OPTION_TSIZE_INDEX 2
|
|
|
|
#define PXE_MTFTP_OPTION_MULTICAST_INDEX 3
|
|
|
|
#define PXE_MTFTP_OPTION_MAXIMUM_INDEX 4
|
2015-07-08 14:17:11 +02:00
|
|
|
#define PXE_MTFTP_OPTBUF_MAXNUM_INDEX 128
|
2010-11-01 07:13:54 +01:00
|
|
|
|
|
|
|
#define PXE_MTFTP_ERROR_STRING_LENGTH 127 // refer to definition of struct EFI_PXE_BASE_CODE_TFTP_ERROR.
|
|
|
|
#define PXE_MTFTP_DEFAULT_BLOCK_SIZE 512 // refer to rfc-1350.
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
This function is wrapper to get the file size using TFTP.
|
|
|
|
|
|
|
|
@param[in] Private Pointer to PxeBc private data.
|
|
|
|
@param[in] Config Pointer to configure data.
|
|
|
|
@param[in] Filename Pointer to boot file name.
|
|
|
|
@param[in] BlockSize Pointer to required block size.
|
|
|
|
@param[in, out] BufferSize Pointer to buffer size.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS Successfully obtained the size of file.
|
|
|
|
@retval EFI_NOT_FOUND Parse the tftp ptions failed.
|
|
|
|
@retval EFI_DEVICE_ERROR The network device encountered an error during this operation.
|
|
|
|
@retval Others Did not obtain the size of the file.
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
PxeBcTftpGetFileSize (
|
|
|
|
IN PXEBC_PRIVATE_DATA *Private,
|
|
|
|
IN VOID *Config,
|
|
|
|
IN UINT8 *Filename,
|
|
|
|
IN UINTN *BlockSize,
|
|
|
|
IN OUT UINT64 *BufferSize
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
This function is a wrapper to get a file using TFTP.
|
|
|
|
|
|
|
|
@param[in] Private Pointer to PxeBc private data.
|
|
|
|
@param[in] Config Pointer to config data.
|
|
|
|
@param[in] Filename Pointer to boot file name.
|
|
|
|
@param[in] BlockSize Pointer to required block size.
|
|
|
|
@param[in] BufferPtr Pointer to buffer.
|
|
|
|
@param[in, out] BufferSize Pointer to buffer size.
|
|
|
|
@param[in] DontUseBuffer Indicates whether to use a receive buffer.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS Successfully read the data from the special file.
|
|
|
|
@retval EFI_DEVICE_ERROR The network device encountered an error during this operation.
|
|
|
|
@retval Others Read data from file failed.
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
PxeBcTftpReadFile (
|
|
|
|
IN PXEBC_PRIVATE_DATA *Private,
|
|
|
|
IN VOID *Config,
|
|
|
|
IN UINT8 *Filename,
|
|
|
|
IN UINTN *BlockSize,
|
|
|
|
IN UINT8 *BufferPtr,
|
|
|
|
IN OUT UINT64 *BufferSize,
|
|
|
|
IN BOOLEAN DontUseBuffer
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
This function is a wrapper to put file with TFTP.
|
|
|
|
|
|
|
|
@param[in] Private Pointer to PxeBc private data.
|
|
|
|
@param[in] Config Pointer to config data.
|
|
|
|
@param[in] Filename Pointer to boot file name.
|
|
|
|
@param[in] Overwrite Indicates whether to use an overwrite attribute.
|
|
|
|
@param[in] BlockSize Pointer to required block size.
|
|
|
|
@param[in] BufferPtr Pointer to buffer.
|
|
|
|
@param[in, out] BufferSize Pointer to buffer size.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS Successfully wrote the data into the special file.
|
|
|
|
@retval EFI_DEVICE_ERROR The network device encountered an error during this operation.
|
|
|
|
@retval other Write data into file failed.
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
PxeBcTftpWriteFile (
|
|
|
|
IN PXEBC_PRIVATE_DATA *Private,
|
|
|
|
IN VOID *Config,
|
|
|
|
IN UINT8 *Filename,
|
|
|
|
IN BOOLEAN Overwrite,
|
|
|
|
IN UINTN *BlockSize,
|
|
|
|
IN UINT8 *BufferPtr,
|
|
|
|
IN OUT UINT64 *BufferSize
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
This function is a wrapper to get the data (file) from a directory using TFTP.
|
|
|
|
|
|
|
|
@param[in] Private Pointer to PxeBc private data.
|
|
|
|
@param[in] Config Pointer to config data.
|
|
|
|
@param[in] Filename Pointer to boot file name.
|
|
|
|
@param[in] BlockSize Pointer to required block size.
|
|
|
|
@param[in] BufferPtr Pointer to buffer.
|
|
|
|
@param[in, out] BufferSize Pointer to buffer size.
|
|
|
|
@param[in] DontUseBuffer Indicates whether with a receive buffer.
|
|
|
|
|
|
|
|
@retval EFI_SUCCES Successfully obtained the data from the file included in directory.
|
|
|
|
@retval EFI_DEVICE_ERROR The network device encountered an error during this operation.
|
|
|
|
@retval Others Operation failed.
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
PxeBcTftpReadDirectory (
|
|
|
|
IN PXEBC_PRIVATE_DATA *Private,
|
|
|
|
IN VOID *Config,
|
|
|
|
IN UINT8 *Filename,
|
|
|
|
IN UINTN *BlockSize,
|
|
|
|
IN UINT8 *BufferPtr,
|
|
|
|
IN OUT UINT64 *BufferSize,
|
|
|
|
IN BOOLEAN DontUseBuffer
|
|
|
|
);
|
|
|
|
#endif
|