public inbox for devel@edk2.groups.io
 help / color / mirror / Atom feed
From: "gaoliming via groups.io" <gaoliming=byosoft.com.cn@groups.io>
To: <devel@edk2.groups.io>, <lbfeng@kunluntech.com.cn>
Subject: 回复: [edk2-devel] Compatibility of PCIe UEFI option ROM
Date: Thu, 9 Jan 2025 12:33:31 +0800	[thread overview]
Message-ID: <02d001db624f$a3d90990$eb8b1cb0$@byosoft.com.cn> (raw)
In-Reply-To: <AOEApwAaLkM47FApRB7Rf4oi.3.1736155570212.Hmail.lbfeng@kunluntech.com.cn>

[-- Attachment #1: Type: text/plain, Size: 4372 bytes --]

UEFI Option ROM Driver only depends on MdePkg. If you meet with such device driver that has the additional dependency, you can raise this problem to the device vendor. 

 

Thanks

Liming

发件人: devel@edk2.groups.io <devel@edk2.groups.io> 代表 丰立波 via groups.io
发送时间: 2025年1月6日 17:26
收件人: gaoliming <gaoliming@byosoft.com.cn>
抄送: devel <devel@edk2.groups.io>
主题: 回复: [edk2-devel] Compatibility of PCIe UEFI option ROM

 

PCIe option ROMs are UEFI drivers, basiclly. UEFI drivers and UEFI applications all could encounter the compatibility issue. 

Consider this situation: build an UEFI driver comsuming some gEdkii****Protocol on EDKII development Kits, then under AMI shell, using "load" command to load the UEFI driver efi file, the UEFI couldn't work due to the absence of the gEdkii****Protocol. The same issue could occur on UEFI Application as well.

 

There is an example: SecurityPkg/HddPassword/HddPassworldDxe.inf is a general UEFI driver, but it consumes gEdkiiVariablePolicyProtocolGuid. Under the AMI UEFI shell, load the driver with the load command, it may not work. 

Vice versa, An AMI-built UEFI driver comsuming some AMI-specific protcotol couldn't run under the EDKII shell, that is the problem we are having.

 

PCIe option ROM are built on the AMI development kits, tranditionally. PCIe Option ROM is contained in PCIe card, deploy widely. The issue is more severe than UEFI driver and Application. 

 

Thanks

 

Feng Libo 

 

 

Original:

*	From:gaoliming <gaoliming@byosoft.com.cn <mailto:gaoliming@byosoft.com.cn> >
*	Date:2025-01-06 08:57:22(中国 (GMT+08:00))
*	To:devel<devel@edk2.groups.io <mailto:devel@edk2.groups.io> > , lbfeng<lbfeng@kunluntech.com.cn <mailto:lbfeng@kunluntech.com.cn> >
*	Cc:
*	Subject:回复: [edk2-devel] Compatibility of PCIe UEFI option ROM

UEFI Option Rom only consumes the protocols defined in UEFI spec, it doesn’t depend on other protocols. 

 

Thanks

Liming

发件人: devel@edk2.groups.io <mailto:devel@edk2.groups.io>  <devel@edk2.groups.io <mailto:devel@edk2.groups.io> > 代表 丰立波 via groups.io
发送时间: 2025年1月3日 17:45
收件人: devel <devel@edk2.groups.io <mailto:devel@edk2.groups.io> >
主题: [edk2-devel] Compatibility of PCIe UEFI option ROM

 

Hello,

 

  PCIe option ROM is an UEFI driver, basiclly. You can build an PCIe option ROM with any UEFI development kits, EDKII or AMI Aptio, burn a flash chip mounted on PCIe plugin card. At the moment of DXE driver dispatching, PCIe option ROM loads and runs in the UEFI enviroment of motherboard. The motherboard UEFI could be built with other UEFI development kits, the compatibilty issue could occur. 

  This actully happened in a project of ours: A PCIe network Option ROM is built with AMI UEFI development kits, having the driver health functionality. This PCIe network card plugin an EDKII UEFI motherboard, enter Setup utility, check the driver health, something is not working: a PopupBox was supposed to pop, but didn't. and many ASSERT are send out, reporting VFR STRING can't be found. I think the PCIe network Option ROM is using AMI-specific protocols and string resouces that are totally absent in the EDKII execution enviroment.

  Meanwhile, I look up the EDKII-implemented protocols, many EDKII_** prefixed protocols exist, these are not UEFI specified. Think about this situation: I build a PCIe option ROM with EDKII, using EDKII_FORM_DISPLAY_ENGINE_PROTOCOL, then plugin the PCIe card in an AMI UEFI motherboard, the PCIe option ROM can't locate the EDKII_FORM_DISPLAY_ENGINE_PROTOCOL, probably. Something is not working, either. 

  Making things worse, it is impossible for PCIe card vendors to deliver variants, it is impossible for the end-user to choose a proper variant as well.






Now, how can we address this issue?






Best Regards






Feng Libo

 

 





-=-=-=-=-=-=-=-=-=-=-=-
Groups.io Links: You receive all messages sent to this group.
View/Reply Online (#120974): https://edk2.groups.io/g/devel/message/120974
Mute This Topic: https://groups.io/mt/110449204/7686176
Group Owner: devel+owner@edk2.groups.io
Unsubscribe: https://edk2.groups.io/g/devel/unsub [rebecca@openfw.io]
-=-=-=-=-=-=-=-=-=-=-=-



[-- Attachment #2: Type: text/html, Size: 18266 bytes --]

      reply	other threads:[~2025-01-09  4:33 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2025-01-03  9:44 [edk2-devel] Compatibility of PCIe UEFI option ROM 丰立波 via groups.io
2025-01-06  0:57 ` 回复: " gaoliming via groups.io
2025-01-06  9:26   ` 丰立波 via groups.io
2025-01-09  4:33     ` gaoliming via groups.io [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-list from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to='02d001db624f$a3d90990$eb8b1cb0$@byosoft.com.cn' \
    --to=devel@edk2.groups.io \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox