/** @file | |
Functions declaration related with Mtftp for UefiPxeBc Driver. | |
Copyright (c) 2007 - 2010, Intel Corporation. All rights reserved.<BR> | |
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 | |
#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 |