| /** @file | |
| Implement the write API. | |
| 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. | |
| **/ | |
| #include <SocketInternals.h> | |
| /** | |
| 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 | |
| @return The number of bytes written or -1 if an error occurs. | |
| In the case of an error, ::errno contains more details. | |
| **/ | |
| ssize_t | |
| EFIAPI | |
| BslSocketWrite ( | |
| struct __filedes *pDescriptor, | |
| off_t * pOffset, | |
| size_t LengthInBytes, | |
| const void * pBuffer | |
| ) | |
| { | |
| ssize_t BytesWritten; | |
| // | |
| // Send the data using the socket | |
| // | |
| BytesWritten = send ( pDescriptor->MyFD, | |
| pBuffer, | |
| LengthInBytes, | |
| 0 ); | |
| // | |
| // Return the number of bytes written | |
| // | |
| return BytesWritten; | |
| } |