Andrew:
I don't understand why you're claiming pointer corruption ? I don't think so.
I'm not "trying different APIs". I actually need the next SmbiosRecord->Length
bytescopied into foo. Can you elaborate ? Is it because I'm using UINT8 instead
of EFI_SMBIOS_TYPE in GENERAL_INFORMATION ? Why does that make a differencewhen
in fact EFI_SMBIOS_TYPE is a UINT8 ? Or that I'm using UINT16 instead of
EFI_SMBIOS_HANDLE ? I could make those changes in my GENERAL_INFORMATIONstruct
but I don't see them making a difference. That said, I think I should use the
EFI typedefs in GENERAL_INFORMATION structinstead of UINT8/UINT16 in case the
underlying types might change in the future.
Shubha D. [email protected]
[email protected]
On Thursday, July 23, 2015 3:56 PM, Andrew Fish <[email protected]> wrote:
On Jul 23, 2015, at 3:37 PM, Shubha Ramani <[email protected]> wrote:
I actually do want the size of the entire SMBIOS structure. It should match
sizeof (GENERAL_INFORMATION) and it in fact does.That's why I'm confused. Maybe
I need to AllocateZeroPool for foo and not create it on the stack ? I don't see
how that would makea difference but I'll try it.
Looks like pointer corruption to me. You really should assume your code is
broken 1st, and not start trying random other APIs. You may get lucky and leave
a time bomb for the developer that ends up having to maintain the code in the
future.
The code should be either:SmbiosRecord, SmbiosRecord->Length&SmbiosRecord,
SmbiosRecord.Lenght
or
Just use:
https://github.com/tianocore/edk2/blob/master/MdePkg/Include/IndustryStandard/SmBios.h
as it defined SMBIOS_STRUCTURE_POINTER.
All the spec based data structures already have types, that have been tested.
Thanks,
Andrew Fish
Shubha D. [email protected]
[email protected]
On Thursday, July 23, 2015 3:31 PM, Andrew Fish <[email protected]> wrote:
On Jul 23, 2015, at 3:13 PM, Shubha Ramani <[email protected]> wrote:
Thank You ! You are right. My pointer was incorrect and your correction fixed
it Aaron. Next question. I'm trying to use CopyMem.Can I do something like this
? It's not working right. Type, Length and Handle in my custom struct are
exactly the same types as in (from Smbios.h)
You are probably corrupting the stack with a buffer overflow on foo.
CopyMem ((VOID *)&foo, (VOID *)&SmbiosRecord, MIN (SmbiosRecord->Length, sizeof
(GENERAL_INFORMATION));
EFI_SMBIOS_TABLE_HEADER.Length is the length of the entire SMBIOS structure,
not the header. If you just want the header it would we be sizeof
(EFI_SMBIOS_TABLE_HEADER).
Sp just standard C bugs.
Thanks,
Andrew Fish
typedef struct { EFI_SMBIOS_TYPE Type; UINT8 Length;
EFI_SMBIOS_HANDLE Handle;} EFI_SMBIOS_TABLE_HEADER;
My custom struct:
#pragma pack(1)
typedef struct _GENERAL_INFORMATION{ UINT8 Type; UINT8
Length; UINT16 Handle; UINT16 MemberIdentifier; UINT8
MemberName; UINT8 Field_A UINT8 Field_B;
UINT8 Field_C; UINT8 FIeld_D, UINT8
Field_E;} GENERAL_INFORMATION; #pragma pack()
GENERAL_INFORMATION foo;
CopyMem ((VOID *)&foo, (VOID *)&SmbiosRecord, SmbiosRecord->Length);
Shubha D. [email protected]
[email protected]
On Thursday, July 23, 2015 2:08 PM, "[email protected]"
<[email protected]> wrote:
Your usage of pointers was incorrect. Pleasesee corrected code below:
EFI_STATUS
EFIAPI
SmbiosMain (
IN EFI_HANDLE ImageHandle,
IN EFI_SYSTEM_TABLE *SystemTable
)
{
EFI_SMBIOS_PROTOCOL *Smb;
EFI_STATUS Status = EFI_SUCCESS;
EFI_SMBIOS_HANDLE InSmbiosHandle =0xFFFE;
EFI_SMBIOS_TYPE Type=160;
EFI_SMBIOS_TABLE_HEADER *SmbiosRecord= NULL;
KNL_GENERAL_INFORMATION knl;
UINT16 size = 0;
Status = gBS->LocateProtocol (&gEfiSmbiosProtocolGuid,NULL, (VOID **) &Smb);
if (EFI_ERROR (Status)) {
return Status;
}
Print(L"Status after gBS->LocateProtocol:%r\n", Status);
SmbiosRecord = AllocateZeroPool (sizeof(EFI_SMBIOS_TABLE_HEADER));
Status = Smb->GetNext (Smb, &InSmbiosHandle,&Type, &SmbiosRecord, NULL);
Print(L"Status after SmbiosProtocol->GetNext:%r\n", Status);
if (EFI_ERROR (Status)) {
return Status;
}
Print(L"Smbios In Handle: %d\n",InSmbiosHandle);
Print(L"SmbiosRecord Address: 0X%llx\n", &SmbiosRecord);
Print(L"SmbiosRecord->Type: %d\n", SmbiosRecord->Type);
Print(L"SmbiosRecord->Length: %d\n\n", SmbiosRecord->Length);
Print(L"SmbiosRecord->Handle: %d\n\n", SmbiosRecord->Handle);
Print(L"Sizeof SmbiosRecord :%d\n", sizeof(SmbiosRecord));
FreePool (SmbiosRecord);
return EFI_SUCCESS;
Best Personal Regards,
Aaron Pop
Senior Software Engineer
Phone: +1 858-457-2600 Ext. 318
Fax: +1 858-457-2602 | Email:[email protected]
<Mail Attachment.gif>
congatec, Inc. | 6262Ferris Square | San Diego CA 92121 | USA |
www.congatec.us
Any e-mail sent from congatecmay contain information which is confidential. If
you are not the intendedrecipient, you may not
disclose, copy or useit; please notify the sender immediately and delete this
e-mail and anycopies from your systems.
From: Shubha Ramani <[email protected]>
To: "[email protected]"<[email protected]>,
Date: 07/23/2015 02:02 PM
Subject: [edk2] GetNextof Smbios protocol not working
Please see corrected code below:
EFI_STATUS
EFIAPI
SmbiosMain (
IN EFI_HANDLE ImageHandle,
IN EFI_SYSTEM_TABLE *SystemTable
)
{
EFI_SMBIOS_PROTOCOL *Smb;
EFI_STATUS Status = EFI_SUCCESS;
EFI_SMBIOS_HANDLE InSmbiosHandle =0xFFFE;
EFI_SMBIOS_TYPE Type=160;
EFI_SMBIOS_TABLE_HEADER *SmbiosRecord= NULL;
KNL_GENERAL_INFORMATION knl;
UINT16 size = 0;
Status = gBS->LocateProtocol (&gEfiSmbiosProtocolGuid,NULL, (VOID **) &Smb);
if (EFI_ERROR (Status)) {
return Status;
}
Print(L"Status after gBS->LocateProtocol:%r\n", Status);
SmbiosRecord = AllocateZeroPool (sizeof(EFI_SMBIOS_TABLE_HEADER));
Status = Smb->GetNext (&Smb,&InSmbiosHandle, &Type, &SmbiosRecord, NULL);
Print(L"Status after SmbiosProtocol->GetNext:%r\n", Status);
if (EFI_ERROR (Status)) {
return Status;
}
Print(L"Smbios In Handle: %d\n",InSmbiosHandle);
Print(L"SmbiosRecord Address: 0X%llx\n", &SmbiosRecord);
Print(L"SmbiosRecord->Type: %d\n", SmbiosRecord->Type);
Print(L"SmbiosRecord->Length: %d\n\n", SmbiosRecord->Length);
Print(L"SmbiosRecord->Handle: %d\n\n", SmbiosRecord->Handle);
Print(L"Sizeof SmbiosRecord :%d\n", sizeof(SmbiosRecord));
FreePool (SmbiosRecord);
return EFI_SUCCESS;
Please see my code below.
If you’ll notice, I’m passing
In EFI_SMBIOS_HANDLEInSmbiosHandle = 0xFFFE; EFI_SMBIOS_TYPE Type=160;
Which is as the header file “Smbios.h”and the protocol implementation
“SmbiosDxe.c”
Instruct. According to my understanding,GetNext should return the address of the
First table whose Type=160. I used SmbiosView.efiand saw that indeed such a
table
with Type=160 is present. I tried other validTypes too, though and the result
is the same.
What I expect to be returned is the EFI_STATUSof “Success” and the correct
Address for the SmbiosRecord with type=160.I’m getting neither. I’m getting an
EFI_STATUS
Code of 0xB58FBD02. At the very least, Iwould expect EFI_NOT_FOUND. According
To the protocol, this weird 0xB58FBD02 shouldnot be returned for EFI_STATUS.
I did search archives however, and it seemsthat others have had problems with
Smbios GetNext,
With no resolution that I saw.
The following two paths are the Smbios Protocolimplementation in the latest
EDK2 repo:
C:\edk2\MyWorkspace\MdeModulePkg\Universal\SmbiosDxe\SmbiosDxe.c
C:\edk2\MyWorkspace\MdeModulePkg\Universal\SmbiosDxe\Smbios.h
There is also a shell tool
C:\edk2\MyWorkspace\ShellPkg\Library\UefiShellDebug1CommandsLib\Sm
biosView which does not use the Smbios protocolat all. It seems to use a
backdoor approach of
internal data structures. I wonder why ?Is this because the Smbios protocol
doesn’t work ?
We would like to use the Smbios Protocolbecause it’s simple and provides what
we need.
We would like to avoid the backdoor approachembraced by Smbiosview if possible.
Can someone comment on my issue ? Am I usingGetNext incorrectly ?
EFI_STATUS
EFIAPI
SmbiosMain (
IN EFI_HANDLE ImageHandle,
IN EFI_SYSTEM_TABLE *SystemTable
)
{
EFI_SMBIOS_PROTOCOL Smb;
EFI_STATUS Status = EFI_SUCCESS;
EFI_SMBIOS_HANDLE InSmbiosHandle =0xFFFE;
EFI_SMBIOS_TYPE Type=160;
EFI_SMBIOS_TABLE_HEADER *SmbiosRecord= NULL;
KNL_GENERAL_INFORMATION knl;
UINT16 size = 0;
Status = gBS->LocateProtocol (&gEfiSmbiosProtocolGuid,NULL, (VOID **) &Smb);
if (EFI_ERROR (Status)) {
return Status;
}
Print(L"Status after gBS->LocateProtocol:%r\n", Status);
SmbiosRecord = AllocateZeroPool (sizeof(EFI_SMBIOS_TABLE_HEADER));
Status = Smb.GetNext (&Smb, &InSmbiosHandle,&Type, &SmbiosRecord, NULL);
Print(L"Status after SmbiosProtocol->GetNext:%r\n", Status);
if (EFI_ERROR (Status)) {
return Status;
}
Print(L"Smbios In Handle: %d\n",InSmbiosHandle);
Print(L"SmbiosRecord Address: 0X%llx\n", &SmbiosRecord);
Print(L"SmbiosRecord->Type: %d\n", SmbiosRecord->Type);
Print(L"SmbiosRecord->Length: %d\n\n", SmbiosRecord->Length);
Print(L"SmbiosRecord->Handle: %d\n\n", SmbiosRecord->Handle);
Print(L"Sizeof SmbiosRecord :%d\n", sizeof(SmbiosRecord));
FreePool (SmbiosRecord);
return EFI_SUCCESS;
Shubha D. Ramani
[email protected]
shubharam...@yahoo.com------------------------------------------------------------------------------
_______________________________________________
edk2-devel mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/edk2-devel
<Mail
Attachment.gif>------------------------------------------------------------------------------
_______________________________________________
edk2-devel mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/edk2-devel
------------------------------------------------------------------------------
_______________________________________________
edk2-devel mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/edk2-devel