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

Shim 15.8 + extra patch for EgoSecure (Matrix42) #353

Open
8 tasks done
BogdanAriton opened this issue Nov 10, 2023 · 76 comments
Open
8 tasks done

Shim 15.8 + extra patch for EgoSecure (Matrix42) #353

BogdanAriton opened this issue Nov 10, 2023 · 76 comments
Assignees
Labels
blocked Blocked on upstream / other project contacts verified OK Contact verification is complete here (or in an earlier submission) custom second-stage Second-stage image is not GRUB

Comments

@BogdanAriton
Copy link

BogdanAriton commented Nov 10, 2023

Confirm the following are included in your repo, checking each box:

  • completed README.md file with the necessary information
  • shim.efi to be signed
  • public portion of your certificate(s) embedded in shim (the file passed to VENDOR_CERT_FILE)
  • binaries, for which hashes are added to vendor_db ( if you use vendor_db and have hashes allow-listed )
  • any extra patches to shim via your own git tree or as files
  • any extra patches to grub via your own git tree or as files
  • build logs
  • a Dockerfile to reproduce the build of the provided shim EFI binaries

What is the link to your tag in a repo cloned from rhboot/shim-review?


https://github.com/Matrix42AG/shim-review/releases/tag/2024-07-31_15-20-09


What is the SHA256 hash of your final SHIM binary?


7409c799415b69dfc6222a844b072f79aa14f5b57f1bea07a442c17d74390b33


What is the link to your previous shim review request (if any, otherwise N/A)?


#199
#169
#7

@THS-on THS-on added the custom second-stage Second-stage image is not GRUB label Nov 14, 2023
@MuthuvelKuppusamy
Copy link

  1. This recommended patch (0001-Enable-the-NX-compatibility-flag-by-default.patch) is missing.

  2. Custom patch included.

  3. Build & sha256sum is good.

  4. f75973853cbdbb95190efdc61fd7a044fc6dd61f0138fbeaa0e3ec44d69211ff shimx64.efi

  5. Contents of section .sbat:
    d5000 73626174 2c312c53 42415420 56657273 sbat,1,SBAT Vers
    d5010 696f6e2c 73626174 2c312c68 74747073 ion,sbat,1,https
    d5020 3a2f2f67 69746875 622e636f 6d2f7268 ://github.com/rh
    d5030 626f6f74 2f736869 6d2f626c 6f622f6d boot/shim/blob/m
    d5040 61696e2f 53424154 2e6d640a 7368696d ain/SBAT.md.shim
    d5050 2c332c55 45464920 7368696d 2c736869 ,3,UEFI shim,shi
    d5060 6d2c312c 68747470 733a2f2f 67697468 m,1,https://gith
    d5070 75622e63 6f6d2f72 68626f6f 742f7368 ub.com/rhboot/sh
    d5080 696d0a73 68696d2e 65676f73 65637572 im.shim.egosecur
    d5090 652c312c 4d617472 69783432 20476d62 e,1,Matrix42 Gmb
    d50a0 482c7368 696d2c31 352e342c 68747470 H,shim,15.4,http
    d50b0 733a2f2f 6d617472 69783432 2e636f6d s://matrix42.com
    d50c0 0a .

  6. Contents of section .sbatlevel:
    88000 00000000 08000000 26000000 73626174 ........&...sbat
    88010 2c00312c 00323032 32303532 34303000 ,.1,.2022052400.
    88020 0a006772 75622c32 0a007362 61742c00 ..grub,2..sbat,.
    88030 312c0032 30323231 31313530 30000a00 1,.2022111500...
    88040 7368696d 2c320a67 7275622c 330a00 shim,2.grub,3..

@BogdanAriton
Copy link
Author

BogdanAriton commented Nov 20, 2023

Hi, thank you for the response!

  1. This recommended patch (0001-Enable-the-NX-compatibility-flag-by-default.patch) is missing.

I've updated the repo with the recommended patch and I've rebuild the shim and updated README and ISSUE_TEMPLATE with the latest sha256 value.

I've also update the sbat value from :

shim.egosecure | 1 | Matrix42 GmbH | shim | 15.4 | https://matrix42.com
to
shim.egosecure | 1 | Matrix42 GmbH | shim | 15.7 | https://matrix42.com

Thanks for looking into this!

@BogdanAriton
Copy link
Author

BogdanAriton commented Nov 28, 2023

Hi @MuthuvelKuppusamy, @THS-on, could we have a review over the latest change? We are trying to fix current problems for our customers. Thanks!

@THS-on
Copy link
Collaborator

THS-on commented Nov 28, 2023

@BogdanAriton there was quite a big queue of submissions and we are still working through it, mostly in our spare time. I'll try to have a look at it, once most of the old submissions got some updates and I find some free time :)

In the meantime it would be awesome, if you can help with the submission process by taking a look at other submissions and adding an (unofficial) review (see here for guidelines https://github.com/rhboot/shim-review/blob/main/docs/reviewer-guidelines.md or have look at the accepted submissions).

@BogdanAriton
Copy link
Author

BogdanAriton commented Nov 29, 2023

@THS-on - sure I've went through the reviewer-guidelines.md, hopefully I'm not missing anything. Thank you for you're effort! 👍
[Edit] - I read this on the diagonal :)
Sure, I can take a look over other submissions and help with the process.

@aronowski
Copy link
Collaborator

I haven't checked the shim binary checksums and reproducibility, since the .sbatlevel section has the binutils bug.

Please, fix it and I'll perform further review. If you need help with this, feel free to ping me here.

@aronowski aronowski added the bug Problem with the review that must be fixed before it will be accepted label Dec 4, 2023
@aronowski aronowski self-assigned this Dec 4, 2023
@BogdanAriton
Copy link
Author

I haven't checked the shim binary checksums and reproducibility, since the .sbatlevel section has the binutils bug.

Please, fix it and I'll perform further review. If you need help with this, feel free to ping me here.

@aronowski - I need help here because I'm not sure what I need to fix. The issue you are referencing has been merged a while back, so it should be part of the current version I presume.

@dennis-tseng99
Copy link
Collaborator

@BogdanAriton, some mistakes are shown in the following:

00000000 08000000 26000000 73626174 ........&...sbat
2c00312c 00323032 32303532 34303000 ,.1,.2022052400.  <-- should be 2c31
0a006772 75622c32 0a007362 61742c00 ..grub,2..sbat,.
312c0032 30323231 31313530 30000a00 1,.2022111500...  <-- should be 2c32
7368696d 2c320a67 7275622c 330a00   shim,2.grub,3..

@aronowski
Copy link
Collaborator

@BogdanAriton, it's a matter of integrating the changes, I linked to, to your build process.

I did something like this by porting that patch, naming it buggy-binutils.patch and adding to my review here.

The integration part might be what I'd need to dive deeper into, as I'm more familiar with the Fedora/RHEL family, rather than Debian.

@BogdanAriton
Copy link
Author

@aronowski - thanks for the help! I've made the update. I've also checked the .sbatlevel and it looks fine now.

objdump shim.efi -s -j .sbatlevel

Contents of section .sbatlevel:
 88000 00000000 08000000 22000000 73626174  ........"...sbat
 88010 2c312c32 30323230 35323430 300a6772  ,1,2022052400.gr
 88020 75622c32 0a007362 61742c31 2c323032  ub,2..sbat,1,202
 88030 32313131 3530300a 7368696d 2c320a67  2111500.shim,2.g
 88040 7275622c 330a00                      rub,3..     

@BogdanAriton
Copy link
Author

@aronowski - any chance we can have a review? 💯 , we're trying to solve some of the issues we have for our clients. Thank you!

@aronowski
Copy link
Collaborator

@BogdanAriton, yes, I'll try my best, but considering that the bootchain is different from what I know and that I'm not a low-level programmer to have an authority to speak about the shim PR 620, it's not going to be easy for me to verify everything thoroughly.

First, I'll just scratch the surface and focus on the easier parts. The good thing is that some older shims were already signed and the applications accepted.

@kukrimate
Copy link
Contributor

kukrimate commented Dec 11, 2023

We do not employ ephemeral keys. Our practice does not involve granting shell access to the kernel. Instead, we utilize a minimal kernel configuration with a login dialog exclusively for user authentication purposes.

Why is not providing shell access to your users relevant to your kernel's implication on the secure boot attack surface.

If your kernel is signed with a key inside your shim, a hyptohetical malware author can take your shim and kernel by themselves and glue any userspace on it.

This is true unless your kernel is only executable as part of a signed UKI-like image containing an initrd and cmdline. Otherwise all command line options, the entire initrd, and syscalls from userspace are part of your attack surface.

It's worth noting that we only utilize the Linux kernel to display a login dialog for user authentication, allowing them to proceed to boot into Windows. We do not grant shell access or permit any actions that involve modifying kernel modules or similar activities.

Does this mean that you execute a Linux based environment prior to Windows as a login dialog, then you chainload Windows?

If so, how do you verify that your bootloader cannot be used to load backdoored copies of Windows?

@aronowski
Copy link
Collaborator

OK, I did scratch the surface as promised. Some entries will need fixing, but let's start with the good ones:

Shim build reproduces file, checksum matches. Its characteristics are alright, but there are ongoing discussions about the handling of the bootchain in the context of NX support. If it turns out it shall not be present in this case, it's just a matter of rolling back the patch that applies the related flag.


*******************************************************************************
### If your SHIM launches any other components, please provide further details on what is launched.
*******************************************************************************
The shim loads our custom loader (the DEFAULT_LOADER provided to the shim). We use a custom second-stage loader. According to business logic, the loader can start Microsoft Windows Boot Manager or own Linux Kernel image. All of the files we load are code-signed with the EV vendor certificate provided to the shim.
To start the loader we create our own EFI boot entry.

Yes, it's the esbootmg.efi file. While I have never worked with it, the same software resulted in a successful previous application. Therefore, I'd say this is OK.


And now the things that need fixing:

*******************************************************************************
### Do you use an ephemeral key for signing kernel modules?
### If not, please describe how you ensure that one kernel build does not load modules built for another kernel.
*******************************************************************************
We do not employ ephemeral keys. Our practice does not involve granting shell access to the kernel. Instead, we utilize a minimal kernel configuration with a login dialog exclusively for user authentication purposes.

A proper strategy will be needed to be implemented if using ephemeral keys is not possible. It's required.

You can base one on these proposals by @THS-on and ask for help if needed.


*******************************************************************************
### If your boot chain of trust includes a Linux kernel:
### Is upstream commit [1957a85b0032a81e6482ca4aab883643b8dae06e "efi: Restrict efivar_ssdt_load when the kernel is locked down"](https://git.kernel.org/pub/scm
/linux/kernel/git/torvalds/linux.git/commit/?id=1957a85b0032a81e6482ca4aab883643b8dae06e) applied?
### Is upstream commit [75b0cea7bf307f362057cc778efe89af4c615354 "ACPI: configfs: Disallow loading ACPI tables when locked down"](https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=75b0cea7bf307f362057cc778efe89af4c615354) applied?
### Is upstream commit [eadb2f47a3ced5c64b23b90fd2a3463f63726066 "lockdown: also lock down previous kgdb use"](https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=eadb2f47a3ced5c64b23b90fd2a3463f63726066) applied?
*******************************************************************************
We are currently running Kernel version 5.5.7. Our intention is to upgrade to the latest kernel version and apply the most recent security patches. However, our current priority is to address the issue involving a certificate mismatch under the shim. Resolving this problem is crucial for unblocking our clients.

It's worth noting that we only utilize the Linux kernel to display a login dialog for user authentication, allowing them to proceed to boot into Windows. We do not grant shell access or permit any actions that involve modifying kernel modules or similar activities.

As far as I can see, only the first commit would be present in that kernel. Please, upgrade to the most recent version possible, as these patches will be required in most cases (most common configurations).


*******************************************************************************
### What patches are being applied and why:
*******************************************************************************
[We need to check if "loader_str" is an actual path or not](https://github.com/rhboot/shim/commit/fc26b47924e6c46e6391552014fc6b4f716f6e65)
Reason for the patch: Because our shim is replacing the windows boot loader: bootmgfw.efi, the paramters sent to windows boot loader cannot be considered a path to secondary boot loader. Our default boot loader is set while building the shim.

I don't have the experience needed to verify, if this patch won't sometimes be causing a behavior that Microsoft wouldn't approve - I'll leave this one for the experts here.


There's also a curiosity that wasn't there in the last time you got your successful application - there's no tag referring to the commit to be reviewed. I suppose this makes it easier for Microsoft to handle things, so please add it and edit the issue's entry message, so the links point to it.

Also remember to update the answer to the "What is the SHA256 hash of your final SHIM binary?" question in that message.


I can see the contacts changed since the last review - I'll send verification emails soon.

@aronowski aronowski added the contact verification needed Contact verification is needed for this review label Dec 11, 2023
@BogdanAriton
Copy link
Author

@aronowski - Thank you for the notes and the review! (also very good points from @kukrimate )
I'm out for a couple of days and will try to address everything when I come back. I'll just add a few things that I can address right now:

It's worth noting that we only utilize the Linux kernel to display a login dialog for user authentication, allowing them to proceed to boot into Windows. We do not grant shell access or permit any actions that involve modifying kernel modules or similar activities.


As far as I can see, only the first commit would be present in that kernel. Please, upgrade to the most recent version possible, as these patches will be required in most cases (most common configurations).

Upgrading the Kernel will potentially impact the product and, as I've mentioned in the template, the chain of trust got broken at some point because the old cert expired and part of the pipeline that builds the product just updated the cert we used to sign our efi apps and other cab files, but the shim got left behind. This happened at the start of the year and we have a lot of clients that can't enable secure boot because of this problem.


What patches are being applied and why:


We need to check if "loader_str" is an actual path or not
Reason for the patch: Because our shim is replacing the windows boot loader: bootmgfw.efi, the paramters sent to windows boot loader cannot be considered a path to secondary boot loader. Our default boot loader is set while building the shim.


I don't have the experience needed to verify, if this patch won't sometimes be causing a behavior that Microsoft wouldn't approve - I'll leave this one for the experts here.

This particular patch is in debate, there is another method I can use and that is to avoid loading options all together, until an actual patch can be made for this particular issue and I will make that change when I come back. ( I can add more details about the patch if you think is necessary)

There's also a curiosity that wasn't there in the last time you got your successful application - there's no tag referring to the commit to be reviewed. I suppose this makes it easier for Microsoft to handle things, so please add it and edit the issue's entry message, so the links point to it.

Can you elaborate further, which commit are you referring to?

Also remember to update the answer to the "What is the SHA256 hash of your final SHIM binary?" question in that message.

Ups! I updated in the readme, but left the old one in the template. (will make the update as soon as possible)

I can see the contacts changed since the last review - I'll send verification emails soon.

Thank you!

@aronowski
Copy link
Collaborator

Verification emails sent.

@aronowski
Copy link
Collaborator

@BogdanAriton,

I'm out for a couple of days and will try to address everything when I come back.

Unsure if this will be a well-deserved rest or dealing with other tough stuff, but hopefully the former - this review process and the software maintenance is hard already.

Upgrading the Kernel will potentially impact the product and, as I've mentioned in the template, the chain of trust got broken at some point because the old cert expired and part of the pipeline that builds the product just updated the cert we used to sign our efi apps and other cab files, but the shim got left behind.

Unless someone at Microsoft or from the committee says otherwise, I think that maybe that kernel could be patched with the "75b0cea7bf307f362057cc778efe89af4c615354 "ACPI: configfs: Disallow loading ACPI tables when locked down"" patch and a laboratory setting arranged to see if the proof-of-concept exploit linked there works or does not work. If I had more time and a trial access to EgoSecure Full Disk Encryption, I'd test this out myself.

The issue that "eadb2f47a3ced5c64b23b90fd2a3463f63726066 "lockdown: also lock down previous kgdb use"" fixes can be, as far as I'm concerned, fixed by simply setting CONFIG_KDB_DEFAULT_ENABLE=0x0 for the building process. Although don't believe me blindly and verify things with the kernel experts we have here. I can ping one if you want. ;-)

This happened at the start of the year and we have a lot of clients that can't enable secure boot because of this problem.

I know that feeling - will try my best to make the thing compliant with the current requirements.

This particular patch is in debate, there is another method I can use and that is to avoid loading options all together, until an actual patch can be made for this particular issue and I will make that change when I come back. ( I can add more details about the patch if you think is necessary)

We can give it a shot, but still, for a proper verification I'd need to become a low-level developer or prepare such a laboratory setting that could provide me with a definite answer.

Can you elaborate further, which commit are you referring to?

a8da6c3fbc2630a2034ffde4391172d7a5e875df - right now it's the tip of the branch main and no tags point to it.

If the update was to happen today, there should be a tag named egosecure-shim-x64-20231211 like in the earlier application.

Ups! I updated in the readme, but left the old one in the template. (will make the update as soon as possible)

👍

@AndreiVoicuM42
Copy link

@aronowski - Hi, and thanks for all the help and effort with our submission.
Here are my words from the verification email:
Alice relearn fries laboring giantess industries cacophony endeavor
spunk export

@julian-klode
Copy link
Collaborator

julian-klode commented Dec 11, 2023

Reviewers: Please refrain from accepting this for the time being, we are having some additional discussions in the keybase about this to make sure that MS is aware of this use case and comfortable with signing it this way. Because we're not sure this is well highlighted to them via this process, and it's not clear how the previous shim ended up signed despite strong rejection from multiple reviewers for the first submission.

Regarding the kernel patches, we do not care if this shim is crucial for unlocking your customers or not, including the patches is mandatory to get the shim signed, there is no discussion to be had there. I'd be open to signing the shim with an older sbat level that was valid at the time the patches were not included but I don't think this provides you a lot of value.

The shim also sets the NX bit as far as I can tell from the patch, so an NX-compatible kernel is mandatory, which we believe I think 6.7 now is, but due to lack of real actual hardware to test this for most people it's all a bit fuzzy, so that's another no-go. #359 has more details on this, and yes I'm aware this is a 360° turn from what @MuthuvelKuppusamy asked in his review, but sadly it's the reality that stuff with NX is not going well.

@BogdanAriton
Copy link
Author

@aronowski - here are the my words from the verification email:
"topples prefabricated heckling outmoded tailcoat waylays escapade
whomever evaporate deployed"

@AndreiVoicuM42
Copy link

@julian-klode Thanks for your input, we discussed internally, we will address the issues brought up asap and get back to you with an updated version for review.

@aronowski aronowski removed the contact verification needed Contact verification is needed for this review label Dec 17, 2023
@THS-on
Copy link
Collaborator

THS-on commented Feb 20, 2024

@AndreiVoicuM42 what the status? Please update the submission to 15.8 or create a new one.

@BogdanAriton
Copy link
Author

Hi @THS-on , thanks for the message, we've update our source to use Linux 6.6.9 (with the latest CVE patches and without the NX bit) and we're in the late stages of testing. Will make the necessary updates to the README as soon as possible. We will continue on this review if that's OK with you.

@BogdanAriton
Copy link
Author

@THS-on , @aronowski - I've updated the review. Please let us know if we should change or update anything.

@steve-mcintyre steve-mcintyre added extra review wanted and removed question Reviewer(s) waiting on response labels Jul 31, 2024
@steve-mcintyre
Copy link
Collaborator

Based on the above we can confirm that we never signed GRUB binaries.

OK, sounds good!

* Please add dated tags on your review in future so that we can follow updates more easily.
* Added latest tag to our changes (I've added the sbat section for esboot in the README): https://github.com/Matrix42AG/shim-review/releases/tag/2024-07-31_15-20-09
* And one final question (sorry!). How would you revoke a kernel if you had to?

The option available to us right now is to generate an ESL file with the kernel's binary hashes and submit it to Microsoft for inclusion in the UEFI DBX.

Let's hope you don't need too many - DBX updates are expensive.

For future shims, you might be better off with an embedded
self-generated CA cert in your shim and intermediate signing
certificates for the rest of the boot chain. This is now the most
common way of handling SB keys and certs. It gives you much more
control of revocations of the later binaries (like Linux) that don't
have SBAT data included - you can quite easily revoke the intermediate
signing certificates and switch to new ones as and when you need to.

I'm not going to say you need to do this now, but it's an
attractive workflow that I'd recommend.

In the meantime, I think you're good here today. I'm happy!

You'll need a second reviewer to approve this now; I've just tagged
this submission to say that.

@BogdanAriton
Copy link
Author

BogdanAriton commented Jul 31, 2024

For future shims, you might be better off with an embedded self-generated CA cert in your shim and intermediate signing certificates for the rest of the boot chain. This is now the most common way of handling SB keys and certs. It gives you much more control of revocations of the later binaries (like Linux) that don't have SBAT data included - you can quite easily revoke the intermediate signing certificates and switch to new ones as and when you need to.

This sounds interesting, will explore this option for next review.

Thank you so much for the time and effort spent here!

@steve-mcintyre
Copy link
Collaborator

@julian-klode you raised concerns about this back in December. Any update there please?

1 similar comment
@steve-mcintyre
Copy link
Collaborator

@julian-klode you raised concerns about this back in December. Any update there please?

@AndreiVoicuM42
Copy link

Hi @steve-mcintyre , I think we made a great progress since @julian-klode 's comment in December, and addressed all the concerns raised back then. But it is not clear to us, did you discuss this further internally with him? Do we also need him to review this submission in the current state and approve it, or any other second approval would suffice?
Assuming any other second approval is sufficient, I kindly ask @SherifNagy , @THS-on , @aronowski , @kukrimate or anyone else if they could have a look at this submission.

@aronowski
Copy link
Collaborator

I could re-review the application, apart from any custom patches, as I mentioned some time ago.

I myself am impressed with all the descriptions and clarifications. I raised the discussion part already - please ping me, if no answer arrives in the next days.

@Foxboron
Copy link

Foxboron commented Aug 21, 2024

Some sideline comments as @SherifNagy asked for opinions from a broader audience.

I find it a bit weird that we are reviewing proprietary DRM solutions. The purpose of this review is not to boot a Linux distribution on a Secure Boot enabled machine for a consumer. It's to enable some convoluted DRM solution where Linux is a cheap iPXE bootloader for a consumer booting a... kiosk/terminal thing?

I don't think we, as the Linux distro community, should be signing products from companies like this. It seems more like a cheap way to get this signed, then something that belongs with the mandate that the Linux UEFI/shim community has.

It's also weird that we focus on reproducible builds, but allow proprietary components in this build chain. If we not enforcing a F/OSS bootchain already, we should ensure this is written down and checked for future reviews.

@SherifNagy SherifNagy added the blocked Blocked on upstream / other project label Aug 27, 2024
@SherifNagy
Copy link
Collaborator

Adding a blocked label for now, we are still waiting some info from MSFT folks and will update the ticket once we hear back.

@BogdanAriton
Copy link
Author

Hi @SherifNagy, I hope you're doing well. We wanted to check in and see if there's been any update from MSFT and if there's anything we can do to support the process.

Additionally, we wanted to bring to your attention that on August 13, Microsoft released KB5041580 (OS Builds 19044.4780 and 19045.4780), which impacts users of previous versions of SHIM and also affects earlier releases of our product.

@AndreiVoicuM42
Copy link

Hi @SherifNagy , @steve-mcintyre . It has been almost 3 weeks since this was blocked, is there no update from MSFT side?
Would it help if you also include us in your conversation with MSFT?

Thank you,
Andrei.

@BogdanAriton
Copy link
Author

@SherifNagy , @steve-mcintyre - Since we've encountered delays with the review, and the issue seems related to the custom second-stage boot loader, we believe it is worth exploring the removal of our second stage entirely, replacing it with GRUB2.

I've created a diagram that outlines our proposed approach:

FDE_boot-Page-With-Grub2

In summary, we are removing esbootmg.efi and replacing it with GRUB2. GRUB2 will handle loading either our custom GUI/Text interface, Linux, or Windows based on flags stored in an encrypted KEK sector, which will be saved in memory.

The new EFI app, manage_kek.efi , will provide controlled access to the KEK sector and manage partition start and end values for GRUB via predefined callbacks. This approach helps to avoid introducing unnecessary logic into GRUB itself. The only custom code added to GRUB will be a module that utilizes the predefined callbacks from manage_kek.efi .

Please let us know if this proposal would help with the current status of the review.

Thank you!
Bogdan

@Foxboron
Copy link

@BogdanAriton I think part of the issue here is that nothing is actually open-source, thus we can only trust what you are telling us on the flow diagrams, we have way to validate nor review what we are actually approving.

@BogdanAriton
Copy link
Author

@BogdanAriton I think part of the issue here is that nothing is actually open-source, thus we can only trust what you are telling us on the flow diagrams, we have way to validate nor review what we are actually approving.

@Foxboron - I'm not sure I follow, which part would be the issue? (Grub/Shim/Linux are open source. The GUI/Text app (esboot), the manage_kek.efi and Windows, of course, will not be open source). The part where grub decides what to load will be opened (will be a simple if/then/else logic).

@Foxboron
Copy link

The GUI/Text app (esboot), the manage_kek.efi [...], will not be open source).

That is the problem. You are at that point not operating with the same rules as the linux distroes where everything is free and open-source. I don't think shim-reviewers should be in the business of rubber stamping proprietary solutions when everyone else is operating by the customs of the Free and Open-Source communities.

@BogdanAriton
Copy link
Author

The GUI/Text app (esboot), the manage_kek.efi [...], will not be open source).

That is the problem. You are at that point not operating with the same rules as the linux distroes where everything is free and open-source. I don't think shim-reviewers should be in the business of rubber stamping proprietary solutions when everyone else is operating by the customs of the Free and Open-Source communities.

@Foxboron - I really appreciate your input, and, in general I agree with you, but I would like to narrow down on what the best approach should here. Since esboot.efi "is now" (or it will be) an endpoint like windows, then manage_kek.efi remains the problem? Eventually grub will be the only boot loader here.

@Foxboron
Copy link

I really appreciate your input, and, in general I agree with you, but I would like to narrow down on what the best approach should here. Since esboot.efi "is now" (or it will be) an endpoint like windows, then manage_kek.efi remains the problem? Eventually grub will be the only boot loader here.

I don't know. I don't think shim-reviewers should be responsible for signing this and I suspect it's better to get this signed by Microsoft directly. It puts the Linux community in an awkward spot that we are signing something that isn't inherently a Linux distribution.

We shouldn't be signing chainloaders for Windows, shim was written to ensure Linux distributions can continue to book on Windows enabled laptops for consumers to easily install Linux. Not as a way for companies to circumvent the paid signature process from Microsoft directly.

@SherifNagy
Copy link
Collaborator

We are still waiting on feedback from MSFT, but yes, as @Foxboron was saying, we are trying to figure out if this is something shim-reviewers should review in first place or not

@AndreiVoicuM42
Copy link

Hi @SherifNagy , could you shed some light on the discussion with MSFT? I think you can understand the frustration from our point of view, as we get back the exact same answer for months now. Is it an active discussion ongoing, with daily/weekly activity, or is this discussion stagnating?

We also reached out to [email protected], explaining the situation here (including the open source/closed source concerns, and linking to this review) and asked for clarifications/guidance. This is the answer we received:

I’ve confirmed nothing has changed at the policy level – so you’d still need to submit your product for review by the SHIM Board and when/if they accept that SHIM, then submit it for Microsoft UEFI Review via your Partner Center.

Additionally, @Foxboron suggests in his answers that we want to get this SHIM signed by the community, which I think deserves some clarification to ensure we are all on the same page and address any possible misunderstanding:

  1. We are trying to follow the process outlined here: https://techcommunity.microsoft.com/t5/hardware-dev-center/updated-uefi-signing-requirements/ba-p/1062916 , which I am sure you are all familiar with, and it specifies at point 12. that ANY shim needs to first be reviewed by this SHIM board, hence our submission.
  2. Once we would get the approval here, we will submit our SHIM for review and signing to Microsoft directly, through the MSFT Partner Center, as it was done before.

To our understanding, the SHIM board does not need to actually sign our shim, just review it before we submit it to MSFT directly. If we understood anything wrong, then please clarify and advise. And @Foxboron, could you expand on the paid option for signing you are referring to, as we could find no mention about it, neither in the article above or in the Partner Center.

Thanks,
Andrei

@AndreiVoicuM42
Copy link

Could you provide an update on the current status? Additionally, I would appreciate responses to the questions I asked three weeks ago.

@BogdanAriton
Copy link
Author

BogdanAriton commented Oct 25, 2024

Hi @Foxboron, @SherifNagy, @THS-on, @aronowski. I'm trying to understand the differences between this approved review (#385) and our review (same closed source second stage that loads windows). Could you help clarify? Thanks!

@aronowski
Copy link
Collaborator

aronowski commented Oct 27, 2024 via email

@aronowski
Copy link
Collaborator

aronowski commented Oct 27, 2024 via email

@BogdanAriton
Copy link
Author

Hi @aronowski - thank you so much for your replay! (lately we had replies few and far between)

  1. Regarding the comparison between our application and the one mentioned in my previous comment: I understand your answer about the patches, but, since we've received already an approval for our application, the problem presented was the fact that our second stage loader is not open source (grabbing one of the more relevant quotes regarding this issue: Shim 15.8 + extra patch for EgoSecure (Matrix42) #353 (comment)) - my point with the submission Shim 15.8 for Trusted Disk #385 was that, from what I could gather, it's the exact same situation and this wasn't an issue for this specific review. (was just something I wanted to clarify and learn from)

  2. Regarding the submission to Microsoft directly - this is actually something we're trying to figure out since the entire application was setup to work with the shim we need to redesign most of our application in order to move forward with this idea.

We've been learning from these submissions throughout the year and we really appreciate your time and effort!

@aronowski
Copy link
Collaborator

aronowski commented Oct 30, 2024 via email

@steve-mcintyre steve-mcintyre added Accredited review needed Needs a successful review by an accredited reviewer and removed extra review wanted Accredited review needed Needs a successful review by an accredited reviewer labels Nov 13, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
blocked Blocked on upstream / other project contacts verified OK Contact verification is complete here (or in an earlier submission) custom second-stage Second-stage image is not GRUB
Projects
None yet
Development

No branches or pull requests