From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail02.groups.io (mail02.groups.io [66.175.222.108]) by spool.mail.gandi.net (Postfix) with ESMTPS id CA204D8081E for ; Sun, 29 Oct 2023 19:02:12 +0000 (UTC) DKIM-Signature: a=rsa-sha256; bh=mNRdYy1q5Q0OzMkpZ3rI1eEeWMrra7TEG1AmU38GdYU=; c=relaxed/simple; d=groups.io; h=MIME-Version:References:In-Reply-To:From:Date:Message-ID:Subject:To:Cc:Precedence:List-Subscribe:List-Help:Sender:List-Id:Mailing-List:Delivered-To:Reply-To:List-Unsubscribe-Post:List-Unsubscribe:Content-Type:Content-Transfer-Encoding; s=20140610; t=1698606131; v=1; b=wWLz0FBkL+qc30KnDeI+0E4TXODFfGpeaUXzMVqQ0lrby4li4Ic4aqLquxpTqo8OHn82IIDC J9tb7uPhk0ckjTMKxP1sEkDoIb3fUajKRg9PocKnEUb9Pxx2aB2GMp4GUwJIgtzm+tn30ZAlI+l qp8R0esx2K181YERvrwvoSHY= X-Received: by 127.0.0.2 with SMTP id 6iTMYY7687511x7Im6y3OnFz; Sun, 29 Oct 2023 12:02:11 -0700 X-Received: from mail-vk1-f180.google.com (mail-vk1-f180.google.com [209.85.221.180]) by mx.groups.io with SMTP id smtpd.web10.78320.1698606130694217059 for ; Sun, 29 Oct 2023 12:02:10 -0700 X-Received: by mail-vk1-f180.google.com with SMTP id 71dfb90a1353d-49d9ef118a5so1536315e0c.1 for ; Sun, 29 Oct 2023 12:02:10 -0700 (PDT) X-Gm-Message-State: QrauldVPCo8UvSu0LeTjL9Q8x7686176AA= X-Google-Smtp-Source: AGHT+IEFPi5wl0cONjVx+HxFSnfDqjplyTmCsR9QKM6sUPdJbLuoM3ZU3xNMytn0wcFN0itxKMSF2HYytm0KJUzvB4U= X-Received: by 2002:a67:b24a:0:b0:45a:9bd5:b38a with SMTP id s10-20020a67b24a000000b0045a9bd5b38amr4617515vsh.19.1698606129327; Sun, 29 Oct 2023 12:02:09 -0700 (PDT) MIME-Version: 1.0 References: <20231028192330.1031-1-michael.d.kinney@intel.com> In-Reply-To: From: "Pedro Falcato" Date: Sun, 29 Oct 2023 19:01:58 +0000 Message-ID: Subject: Re: [edk2-devel] [Patch 1/1] Maintainers.txt: Update based on active community members To: devel@edk2.groups.io, lersek@redhat.com Cc: michael.d.kinney@intel.com, Andrew Fish , Leif Lindholm , Andrei Warkentin , Catharine West , Dandan Bi , Daniel Schaefer , David Woodhouse , Debkumar De , Eric Dong , Guomin Jiang , Hao A Wu , James Bottomley , Jian J Wang , Jordan Justen , Julien Grall , Peter Grehan , Qi Zhang , Ray Han Lim Ng , Stefan Berger , Wenxing Hou , Xiaoyu Lu Precedence: Bulk List-Subscribe: List-Help: Sender: devel@edk2.groups.io List-Id: Mailing-List: list devel@edk2.groups.io; contact devel+owner@edk2.groups.io Reply-To: devel@edk2.groups.io,pedro.falcato@gmail.com List-Unsubscribe-Post: List-Unsubscribe=One-Click List-Unsubscribe: Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable X-GND-Status: LEGIT Authentication-Results: spool.mail.gandi.net; dkim=pass header.d=groups.io header.s=20140610 header.b=wWLz0FBk; spf=pass (spool.mail.gandi.net: domain of bounce@groups.io designates 66.175.222.108 as permitted sender) smtp.mailfrom=bounce@groups.io; dmarc=fail reason="SPF not aligned (relaxed), DKIM not aligned (relaxed)" header.from=gmail.com (policy=none) On Sun, Oct 29, 2023 at 1:30=E2=80=AFPM Laszlo Ersek wr= ote: > > On 10/29/23 03:16, Pedro Falcato wrote: > >> diff --git a/Maintainers.txt b/Maintainers.txt > >> index 3f40cdeb5554..2b03ccbe54aa 100644 > >> --- a/Maintainers.txt > >> +++ b/Maintainers.txt > >> @@ -93,7 +93,7 @@ M: Sami Mujawar [samimujawar] > >> RISCV64 > >> F: */RiscV64/ > >> M: Sunil V L [vlsunil] > >> -R: Daniel Schaefer [JohnAZoidberg] > >> +R: Andrei Warkentin [andreiw] > >> > >> LOONGARCH64 > >> F: */LoongArch64/ > >> @@ -157,16 +157,6 @@ R: Leif Lindholm [lei= flindholm] > >> R: Sami Mujawar [samimujawar] > >> R: Gerd Hoffmann [kraxel] > >> > >> -ArmVirtPkg: modules used on Xen > >> -F: ArmVirtPkg/ArmVirtXen.* > >> -F: ArmVirtPkg/Library/XenArmGenericTimerVirtCounterLib/ > >> -F: ArmVirtPkg/Library/XenVirtMemInfoLib/ > >> -F: ArmVirtPkg/PrePi/ > >> -F: ArmVirtPkg/XenAcpiPlatformDxe/ > >> -F: ArmVirtPkg/XenPlatformHasAcpiDtDxe/ > >> -F: ArmVirtPkg/XenioFdtDxe/ > >> -R: Julien Grall [jgrall] > > > > ArmVirtPkg Xen modules seize to have a dedicated maintainer. Can the > > generic ArmVirtPkg maintainers handle *more code* (particularly, > > functionality that's not trivial to test, unless you actively use > > Xen)? > > An alternative to removing this entire section is to replace Julien's > line with the following status line: > > S: Orphan > > The definition in Maintainers.txt is: > > Orphan: No current maintainer [but maybe you could take the > role as you write your new code]. > > I think this might be clearer for all three of: contributors, consumers, > and existent maintainers. > > - Contributors: An ArmVirtPkg maintainer may techincally merge your > code, but you won't get substantive feedback > > - Consumers: you can build and run this code, but if it breaks, you get > to keep both parts > > - Existent ArmVirtPkg maintainers: you can rest assured in the knowledge > that you are not saddled with deep technical reviews for this subsystem > that you can't even boot in your environment. You're only responsible > for the technical act of merging patches. I agree with this solution, but I do think there should be a "time limit" for orphaned code. You don't want to keep orphaned code for too long, this is not a practice we should support (which may lead to corporate code dumps where corps just dump a bunch of patches on the mailing list, fire and forget, and they're still "supported"). > > > > >> BaseTools > >> F: BaseTools/ > >> W: https://github.com/tianocore/tianocore.github.io/wiki/BaseTools > >> @@ -187,8 +177,7 @@ F: CryptoPkg/ > >> W: https://github.com/tianocore/tianocore.github.io/wiki/CryptoPkg > >> M: Jiewen Yao [jyao1] > >> M: Yi Li [liyi77] > >> -R: Xiaoyu Lu [xiaoyuxlu] > >> -R: Guomin Jiang [guominjia] > >> +R: Wenxing Hou [Wenxing-hou] > >> > >> DynamicTablesPkg > >> F: DynamicTablesPkg/ > >> @@ -202,7 +191,6 @@ W: https://github.com/tianocore/tianocore.github.i= o/wiki/EmbeddedPkg > >> M: Leif Lindholm [leiflindholm] > >> M: Ard Biesheuvel [ardbiesheuvel] > >> M: Abner Chang [changab] > >> -R: Daniel Schaefer [JohnAZoidberg] > >> > >> EmulatorPkg > >> F: EmulatorPkg/ > >> @@ -228,7 +216,6 @@ F: FmpDevicePkg/ > >> W: https://github.com/tianocore/tianocore.github.io/wiki/FmpDevicePkg > >> M: Liming Gao [lgao4] > >> M: Michael D Kinney [mdkinney] > >> -R: Guomin Jiang [guominjia] > >> R: Wei6 Xu [xuweiintel] > >> > >> IntelFsp2Pkg > >> @@ -237,7 +224,6 @@ W: https://github.com/tianocore/tianocore.github.i= o/wiki/IntelFsp2Pkg > >> M: Chasel Chiu [ChaselChiu] > >> M: Nate DeSimone [nate-desimone] > >> M: Duggapu Chinni B [cbduggap] > >> -M: Ray Han Lim Ng [rayhanlimng] > >> R: Star Zeng [lzeng14] > >> R: Ted Kuo [tedkuo1] > >> R: Ashraf Ali S [AshrafAliS] > >> @@ -258,7 +244,6 @@ R: Susovan Mohapatra = [susovanmohapatra] > >> MdeModulePkg > >> F: MdeModulePkg/ > >> W: https://github.com/tianocore/tianocore.github.io/wiki/MdeModulePkg > >> -M: Jian J Wang [jwang36] > >> M: Liming Gao [lgao4] > > > > MdeModulePkg now only has a single maintainer (Liming, who also > > handles a myriad of other tasks and packages) > > This leads me to my main point: it may be time for edk2 to adopt a > leaner contribution process. > > We can insist on no patch going in without maintainer approval, but that > -- i.e., maintainer authority -- only works as long as it goes hand in > hand with maintainer responsibility: timely reviews. If the community > cannot offer enough working hours for reviewing patches for a subsystem, > then the requirements to contribute to that subsystem should be relaxed. > The other alternative is that the subsystem goes into stasis, where it > becomes effectively impossible to contribute to a subsystem. > > (NB this "relaxation of contribution rules" is entirely orthogonal to > using a mailing list vs. github pull requests. I still strongly prefer > the mailing list.) > > So maybe we could say, if there is no patch review for like 7 working > days (approx. one and half calendar weeks), then the patch should be > merged by default. Put differently, switch from "rejected by default" to > "accepted by default". I understand your idea. I do, however, see it going in 2 different ways: 1) This pressures maintainers/corporations to be faster at reviewing patches, keeping a smooth flow of careful, reviewed patches. Things continue to work smoothly. 2) Maintainers keep being unresponsive, patches get "auto merged" and people need to deal with any ensuing breakage. Things /may/ regularly break. IMO, this solution does not solve anything. If maintainers are short on time (or simply spread too thin), they will still be short on time unless corps give them more time for FOSS work. This just adds a fear factor ("Complete shite may be automerged if you don't have people on it!!"). And frankly, I find it hard to find a solution for this problem, since the vast majority of the firmware product sits *outside* of the open-source repos, sometimes with gnarly forks in the way. How do we convince more people to engage out in the open? > > By the way, I would like to assist with MdeModulePkg reviews. I'm not > sure if I can *commit* to that, but right now, that is my intent. (As > always, I see maintainership / reviewership as a service, not as a > privilege.) Nice, thanks! I'll defer making any promises on my end, but I may end up helping out (as I sometimes do, anyway). > > >> > >> MdeModulePkg: ACPI modules > >> @@ -268,15 +253,6 @@ R: Zhiguang Liu [LiuZhig= uang001] > >> R: Dandan Bi [dandanbi] > >> R: Liming Gao [lgao4] > >> > >> -MdeModulePkg: ACPI modules related to S3 > >> -F: MdeModulePkg/*LockBox*/ > >> -F: MdeModulePkg/Include/*BootScript*.h > >> -F: MdeModulePkg/Include/*LockBox*.h > >> -F: MdeModulePkg/Include/*S3*.h > >> -F: MdeModulePkg/Library/*S3*/ > >> -R: Hao A Wu [hwu25] > >> -R: Eric Dong [ydong10] > >> - > >> MdeModulePkg: BDS modules > >> F: MdeModulePkg/*BootManager*/ > >> F: MdeModulePkg/Include/Library/UefiBootManagerLib.h > > Same story could apply here -- we could orphan S3 stuff as well. > > However, I can't deny I'm quite cranky at the thought of S3 breaking, at > least in my trusty old configurations, so I'd certainly like to keep an > eye on the S3 modules -- even if that only consisted of me > regression-testing patches under OVMF (and not providing "expert > feedback" on patch contents). > I know Intel has abandoned S3 over the (equally cursed!) S0ix/S2idle. I don't know how the situation is on AMD/ARM. Do QEMU/libvirt/whatever use S3 for anything useful? I know they do roughly support it. > >> @@ -326,7 +302,6 @@ F: MdeModulePkg/Library/DxeSecurityManagementLib/ > >> F: MdeModulePkg/Universal/PCD/ > >> F: MdeModulePkg/Universal/PlatformDriOverrideDxe/ > >> F: MdeModulePkg/Universal/SecurityStubDxe/SecurityStub.c > >> -R: Dandan Bi [dandanbi] > >> R: Liming Gao [lgao4] > > > > Down to one reviewer. > > I'll try to assist whenever I can, wherever I notice something > interesting -- I'm quite sure I'm going to be overwhelmed incredibly > quickly, but at least I have that intent right now. I really appreciate your involvement in EDK2, but if the alternative for "Liming 'owns' half of EDK2.git" is "Liming AND Laszlo 'own' half of EDK2.git", I don't see how this can be sustainable without maintainer burnout :/ > >> -OvmfPkg: CSM modules > >> -F: OvmfPkg/Csm/ > >> -R: David Woodhouse [dwmw2] > > > > 0 people dedicated to OVMF CSM (although relatively low maintenance > > overhead, from what it seems) > > In my view, we should orphan the CSM now. Or maybe even better, mark it a= s > > Obsolete: Old code. Something tagged obsolete generally means > it has been replaced by a better system and you > should be using that. > > Mid-term, we should figure out a "feature deprecation process" for edk2, > and then remove the CSM altogether. Other projects I'm somewhat familiar > with have deprecation policies; they announce / document a subsystem > deprecated in one release, and then a number of releases later, the > subsystem is removed completely. This gives users notice ahead of time, > and lets them migrate to different solutions gradually. > > Lots of edk2 code have been removed already (Itanium support, Intel > Framework stuff, etc); we didn't observe any deprecation policy back > then. I don't know if there was any backlash from that. I'd be OK with > removing the CSM at once (well, not in edk2-stable202311, but in the > release after), but that might not be perceived as overly polite. How is CSM looking in the virtualization space? Individual QEMU users probably wouldn't miss it much (since SeaBIOS exists and even is the default), but I don't know what you folks are using for firmware. > > >> - > >> OvmfPkg: Confidential Computing > >> F: OvmfPkg/AmdSev/ > >> F: OvmfPkg/AmdSevDxe/ > >> @@ -545,7 +505,6 @@ F: OvmfPkg/PlatformPei/AmdSev.c > >> F: OvmfPkg/ResetVector/ > >> F: OvmfPkg/Sec/ > >> R: Erdem Aktas [ruleof2] > >> -R: James Bottomley [jejb] > >> R: Jiewen Yao [jyao1] > >> R: Min Xu [mxu9] > >> R: Tom Lendacky [tlendacky] > > It's good for the project that CoCo has several reviewers still. Yes, OVMF in general still seems quite well staffed (probably because the development is done upstream!) > >> ShellPkg > >> @@ -648,12 +603,10 @@ M: Zhichao Gao [ZhichaoG= ao] > >> SignedCapsulePkg > >> F: SignedCapsulePkg/ > >> W: https://github.com/tianocore/tianocore.github.io/wiki/SignedCapsul= ePkg > >> -M: Jian J Wang [jwang36] > > > > Unmaintained > > Probably best to mark it as orphaned then! Wasn't Intel big on capsules? > >> SourceLevelDebugPkg > >> F: SourceLevelDebugPkg/ > >> W: https://github.com/tianocore/tianocore.github.io/wiki/SourceLevelD= ebugPkg > >> -M: Hao A Wu [hwu25] > > > > Unmaintained > >> > >> StandaloneMmPkg > >> F: StandaloneMmPkg/ > > I'd orphan this one as well. For one, I've never gotten > SOURCE_DEBUG_ENABLE to work in OVMF. > > (I'd not go as far as removing it, I'm sure this module has many > downstream users!) > > > >> @@ -664,7 +617,6 @@ M: Ray Ni [niruiyu] > >> UefiCpuPkg > >> F: UefiCpuPkg/ > >> W: https://github.com/tianocore/tianocore.github.io/wiki/UefiCpuPkg > >> -M: Eric Dong [ydong10] > >> M: Ray Ni [niruiyu] > >> R: Rahul Kumar [rahul1-kumar] > >> R: Gerd Hoffmann [kraxel] > >> @@ -672,7 +624,6 @@ R: Gerd Hoffmann [kraxel] > >> UefiCpuPkg: Sec related modules > >> F: UefiCpuPkg/SecCore/ > >> F: UefiCpuPkg/ResetVector/ > >> -R: Debkumar De [dde01] > >> R: Catharine West [catharine-intl] > > > > One reviewer. > > Not necessarily alarming IMO, UefiCpuPkg in general is not neglected > (Gerd is listed, and I would like to keep an eye on it too). So I'd > rather phrase this one as "we even have a dedicated reviewer for > 'UefiCpuPkg: Sec'!" :) Heh :) FWIW, when we tried to use it for QemuOpenBoardPkg we found multiple problems and instantly had to write our own SEC (although it may have been PEBKAC, I don't know if this SecCore is used in real platforms). > > > > > Some brief LoC (taking into account code, blank lines and comments) > > stats over some of the affected packages/modules: > > SignedCapsulePkg - 6,836 LoC > > SourceLevelDebugPkg - 15,208 LoC > > MdeModulePkg - 616,591 LoC (!!) > > Bus/ - 216,268 LoC (!!!) > > Yep, these two are heavy-weights. > > > (HII and UI was tough to actually measure, but I'm relatively sure > > it's 100,000+ LoC!) > > HII is unfortunately terribly difficult. The documentation is very > lacking IMO (in the spec). I tried to read Tim Lewis's blog posts on it: > > https://uefi.blogspot.com/search/label/UEFI%20HII > > but I didn't get far. It feels like one of the most over-engineered (or > at least most complex) parts of UEFI / edk2. I once authored > OvmfPkg/PlatformDxe, because Jordan really wanted me to; ever since I've > been steering as clear of it as I could :) At least Dandan continues as > a designated reviewer for HII! Overengineered and underreviewed? Yikes... > > Taking everything into account, I have two questions: > > 1) Should we go through these changes (that effectively reflect > > reality, that much I understand) and see what needs to be cut from > > EDK2 (i.e do we have an overabundance of features)? > > I'd say "yes". To reiterate, > > - I'd propose explicitly marking orphaned subsystems as such, rather > than merging them silently into parent subsystems, > > - certainly removing some subsystems, but for that, a "staged" > deprecation policy would be most polite. Agreed. --=20 Pedro -=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D- Groups.io Links: You receive all messages sent to this group. View/Reply Online (#110274): https://edk2.groups.io/g/devel/message/110274 Mute This Topic: https://groups.io/mt/102245264/7686176 Group Owner: devel+owner@edk2.groups.io Unsubscribe: https://edk2.groups.io/g/devel/unsub [rebecca@openfw.io] -=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-