Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

BaseTools/OverrideValidation: Sort files prior to hashing. #1145

Merged

Conversation

apop5
Copy link
Contributor

@apop5 apop5 commented Sep 19, 2024

Description

Override validation allows hashing a directory through the -t parameter.

When generating an override validation hash for a directory, it was found that the order of the files can be different when running under linux vs under windows.

To address this discrepancy, a new module hash has been crated ModuleHash2Cal, which sorts the files prior to hashing.

Since existing projects use hashes based on ModuleHashCal, when performing override validation checking, check against the original ModuleHashCal and the ModuleHash2Cal prior to generating an override validation failure.

Generating a new hash value will only use the ModuleHash2Cal.
 

  • Impacts functionality?
  • Impacts security?
  • Breaking change?
  • Includes tests?
  • Includes documentation?

How This Was Tested

Tested changes on a project using existing project (to ensure backward compatibility)
Tested changes on the project under linux that was failing

Tested latest modifications on mu_feature_mm_supv to ensure no regression.

Integration Instructions

N/A

@apop5 apop5 requested a review from Javagedes September 19, 2024 20:23
@github-actions github-actions bot added the language:python Pull requests that update Python code label Sep 19, 2024
@codecov-commenter
Copy link

codecov-commenter commented Sep 19, 2024

Codecov Report

All modified and coverable lines are covered by tests ✅

Project coverage is 1.60%. Comparing base (c599627) to head (d934f01).

Additional details and impacted files
@@             Coverage Diff             @@
##           dev/202405    #1145   +/-   ##
===========================================
  Coverage        1.60%    1.60%           
===========================================
  Files            1377     1377           
  Lines          359259   359259           
  Branches         5524     5524           
===========================================
  Hits             5760     5760           
  Misses         353392   353392           
  Partials          107      107           
Flag Coverage Δ
MdeModulePkg 0.67% <ø> (ø)
MdePkg 5.60% <ø> (ø)
NetworkPkg 0.55% <ø> (ø)
PolicyServicePkg 30.41% <ø> (ø)
UefiCpuPkg 4.75% <ø> (ø)

Flags with carried forward coverage won't be shown. Click here to find out more.

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@apop5 apop5 force-pushed the personal/apop5/updateoverridevalidatointosort branch 3 times, most recently from 1e941d2 to fb8e099 Compare September 20, 2024 17:03
@apop5 apop5 changed the base branch from release/202405 to dev/202405 September 20, 2024 17:04
@apop5 apop5 force-pushed the personal/apop5/updateoverridevalidatointosort branch from fb8e099 to f77c86c Compare September 20, 2024 17:07
@apop5 apop5 marked this pull request as ready for review September 20, 2024 17:08
@apop5 apop5 requested review from spbrogan and makubacki September 20, 2024 17:08
@apop5 apop5 force-pushed the personal/apop5/updateoverridevalidatointosort branch from 03a7327 to f77c86c Compare September 30, 2024 15:43
@apop5 apop5 changed the title Update override validation to sort files prior to hashing. BaseTools/OverrideValidation: Sort files prior to hashing. Oct 2, 2024
@apop5
Copy link
Contributor Author

apop5 commented Jan 24, 2025

This will be merged into dev/202405 and will be part of release/202411

@apop5 apop5 merged commit cd3334a into microsoft:dev/202405 Jan 24, 2025
31 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
language:python Pull requests that update Python code
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants