[U-Boot] [PATCH 01/16] include: pe.h: add signature-related definitions
Heinrich Schuchardt
xypron.glpk at gmx.de
Mon Nov 18 06:26:55 UTC 2019
On 11/18/19 6:44 AM, AKASHI Takahiro wrote:
> Heinrich,
>
> On Sat, Nov 16, 2019 at 06:42:11PM +0100, Heinrich Schuchardt wrote:
>> On 11/13/19 1:52 AM, AKASHI Takahiro wrote:
>>> The index (IMAGE_DIRECTORY_ENTRY_CERTTABLE) in a table points to
>>> a region containing authentication information (image's signature)
>>> in PE format.
>>>
>>> WIN_CERTIFICATE structure defines an embedded signature format.
>>>
>>> Those definitions will be used in my UEFI secure boot patch.
>>>
>>> Signed-off-by: AKASHI Takahiro <takahiro.akashi at linaro.org>
>>> ---
>>> include/pe.h | 16 ++++++++++++++++
>>> 1 file changed, 16 insertions(+)
>>>
>>> diff --git a/include/pe.h b/include/pe.h
>>> index bff3b0aa7a6c..650478ca78af 100644
>>> --- a/include/pe.h
>>> +++ b/include/pe.h
>>> @@ -155,6 +155,7 @@ typedef struct _IMAGE_SECTION_HEADER {
>>> uint32_t Characteristics;
>>> } IMAGE_SECTION_HEADER, *PIMAGE_SECTION_HEADER;
>>>
>>
>> Please, add a comment here:
>>
>> /* Indices for Optional Header Data Directories */
>
> Okay.
>
>>> +#define IMAGE_DIRECTORY_ENTRY_CERTTABLE 4
>>
>> Yes, 4 is the index of the certificate table. But EDK II calls this
>> EFI_IMAGE_DIRECTORY_ENTRY_SECURITY. Should we use the same name to avoid
>> confusion?
>
> No. Because the naming is consistent with
>
>>> #define IMAGE_DIRECTORY_ENTRY_BASERELOC 5
>
> this existing one.
IMAGE_DIRECTORY_ENTRY_BASERELOC is a constant name used by EDK2 in
MdePkg/Include/IndustryStandard/PeImage.h. Why do you want to deviate
for EFI_IMAGE_DIRECTORY_ENTRY_SECURITY?
>
>>>
>>> typedef struct _IMAGE_BASE_RELOCATION
>>> @@ -252,4 +253,19 @@ typedef struct _IMAGE_RELOCATION
>>> #define IMAGE_REL_AMD64_PAIR 0x000F
>>> #define IMAGE_REL_AMD64_SSPAN32 0x0010
>>>
>>> +/* certificate appended to PE image */
>>> +typedef struct _WIN_CERTIFICATE {
>>
>> We do not capitalize structs. Please use 'win_certificate' (like Linux
>> does).
>>
>>> + uint32_t dwLength;
>>> + uint16_t wRevision;
>>> + uint16_t wCertificateType;
>>> + uint8_t bCertificate[];
>>
>> We do not use camelcase and type prefixes. Please, use the same
>> component names as Linux (plus 'certificate' for your extra field).
>
> nak.
> Have you looked at 'pe.h' at all?
> There are already bunch of use of camelcase's and capital names
> since this file was first introduced by Alex.
This shouldn't have happened in the first place.
Best regards
Heinrich
>
>>> +} WIN_CERTIFICATE, *LPWIN_CERTIFICATE;
>>
>> Please, always make use of scripts/checkpatch.pl before submitting
>> patches. It says 'WARNING: do not add new typedefs'.
>
> ditto.
> I have run scripts/cehckpatch.pl and dare to leave them unchanged.
>
>> Please, avoid the typedefs.
>
> No. this is also consistent with other typedef's.
>
>
>>> +
>>
>> The following defines are verbatim copies from Linux. Please, also copy
>> the comment:
>>
>> /* Definitions for the contents of the certs data block */
>
> Okay.
>
>>> +#define WIN_CERT_TYPE_PKCS_SIGNED_DATA 0x0002
>>> +#define WIN_CERT_TYPE_EFI_OKCS115 0x0EF0
>>> +#define WIN_CERT_TYPE_EFI_GUID 0x0EF1
>>> +
>>> +#define WIN_CERT_REVISION_1_0 0x0100
>>> +#define WIN_CERT_REVISION_2_0 0x0200
>>> +
>>> #endif /* _PE_H */
>>>
>>
>> Except for the style issues this looks ok.
>
> Thank you for your comments.
> -Takahiro Akashi
>
>> Best regards
>>
>> Heinrich
>>
>
More information about the U-Boot
mailing list