Hi,
I wrote this shell application(smalltest.efi),did some pipe function test,find 
some strange result.
boot into shell:


# test-1,the follow two command should has the same output ,but infact not the 
same in QEMU,and the second command failed WriteFile in real machine(AMI bios 
uefi 2.6):
ls | smalltest.efi
ls | smalltest.efi | smalltest.efi             # the ls command directory only 
has one file(this tool),so the tool's buffer 80x25*4 won't overflow.


#test-2
run smalltest.efi,
just key in  some chars and Enter,nothing output,why?


my test environment:
UDK2018 + vs2015
QEMU emulator version 2.10.95
OVMF_X64.fd( x64,release build)


the tool's build command:
D:\edk2-vUDK2018>build -p ShellPkg\ShellPkg.dsc -m 
ShellPkg\Application2\smalltest\smalltest.inf -a X64 -b RELEASE


//--------code---smalltest.c-------------


#include <Uefi.h>
#include <Library/UefiApplicationEntryPoint.h>
#include <Library/UefiLib.h>
#include <Library/UefiBootServicesTableLib.h>//global gST gBS gImageHandle
#include <Library/BaseMemoryLib.h>
#include <Library/MemoryAllocationLib.h>


#include <Protocol/Shell.h>
#include <Protocol/ShellParameters.h>



EFI_STATUS
EFIAPI
UefiMain (
IN EFI_HANDLE ImageHandle,
IN EFI_SYSTEM_TABLE *SystemTable
)
{
EFI_STATUS status;
EFI_SHELL_PROTOCOL* gShell;
EFI_SHELL_PARAMETERS_PROTOCOL*gParameters;
UINT16 Buffer[80*25*4]; //tool's buffer;
UINTN BufferSize=sizeof(Buffer);
UINTN BufferByteSize=BufferSize*sizeof(UINT16);


status=gBS->HandleProtocol(gImageHandle,&gEfiShellParametersProtocolGuid,&gParameters);
if(status!=EFI_SUCCESS)
{
Print(L"locate gEfiShellParametersProtocolGuid failed.\n");
return status;
}


status=gBS->LocateProtocol(&gEfiShellProtocolGuid,NULL,&gShell);
if(status!=EFI_SUCCESS)
{
Print(L"locate gEfiShellProtocolGuid failed.\n");
return status;
}


status=gShell->ReadFile(gParameters->StdIn,&BufferByteSize,(VOID*)Buffer);
if(status!=EFI_SUCCESS)
{
Print(L"read from gParameters->StdIn failed.\n");
return status;
}


status=gShell->WriteFile(gParameters->StdOut,&BufferByteSize,(VOID*)Buffer);
if(status!=EFI_SUCCESS)
{
Print(L"wirte gParameters->StdOut failed\n");
return status;
}


gShell->FlushFile(gParameters->StdOut);


return EFI_SUCCESS;
}


//--------code---smalltest.inf-------------


[Defines]
  INF_VERSION                    = 0x00010005
  BASE_NAME                      = smalltest
  FILE_GUID                      = 8F7D7B1D-0E1C-4c98-B12E-4EC99C400704
  MODULE_TYPE                    = UEFI_APPLICATION
  VERSION_STRING                 = 1.0
  ENTRY_POINT                    = UefiMain


[Sources]
  smalltest.c


[Packages]
  MdePkg/MdePkg.dec


[Protocols]
gEfiShellProtocolGuid
gEfiShellParametersProtocolGuid


[LibraryClasses]
  UefiApplicationEntryPoint
  UefiLib
//--------code---end----------------------------------------------------------






thank you, 
by krishna.
_______________________________________________
edk2-devel mailing list
[email protected]
https://lists.01.org/mailman/listinfo/edk2-devel

Reply via email to