From nobody Mon Feb 9 09:43:25 2026 Delivered-To: importer@patchew.org Received-SPF: pass (zohomail.com: domain of groups.io designates 66.175.222.108 as permitted sender) client-ip=66.175.222.108; envelope-from=bounce+27952+79662+1787277+3901457@groups.io; helo=mail02.groups.io; Authentication-Results: mx.zohomail.com; dkim=pass; spf=pass (zohomail.com: domain of groups.io designates 66.175.222.108 as permitted sender) smtp.mailfrom=bounce+27952+79662+1787277+3901457@groups.io; dmarc=fail(p=none dis=none) header.from=gmail.com ARC-Seal: i=1; a=rsa-sha256; t=1629557301; cv=none; d=zohomail.com; s=zohoarc; b=XMCwGBrL1Xv9W3fdJreSgvoa2NbSAZMw7oDH1CTr90094OgsbeKWy9U9J5guvX4klSGG03lmpxDYFdEIANoXww58YhIHy8G2bh7FLneKab5n7718Z1Qm4gSKa/JkT3ns3Coa2zEwL98D9kNatH3qkcUYT6WSfSQENOQoD7zBDac= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1629557301; h=Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Id:List-Help:List-Unsubscribe:MIME-Version:Message-ID:Reply-To:References:Sender:Subject:To; bh=UL+4Uj48RzL/uTF8UP5+r9mtk5YTDqWfS/jG3wOEslg=; b=UR/nsfNjSn0DUf9C31PSRG0efM8/xn1/hG1lNPBs9QRKXsFFjfrAGf5x6yHmOe4/D2hOeDRxIcT/i0FUf7dqn+um33AigSpGNlmRcnz4p++aQvxVZo1gS/A5T0brrCdzIhPCvy3rHeZVeu3XmO1fuAlJv18rW9tC0c0YfdTlNeU= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; spf=pass (zohomail.com: domain of groups.io designates 66.175.222.108 as permitted sender) smtp.mailfrom=bounce+27952+79662+1787277+3901457@groups.io; dmarc=fail header.from= (p=none dis=none) Received: from mail02.groups.io (mail02.groups.io [66.175.222.108]) by mx.zohomail.com with SMTPS id 1629557301126765.8887113607669; Sat, 21 Aug 2021 07:48:21 -0700 (PDT) Return-Path: X-Received: by 127.0.0.2 with SMTP id aF8dYY1788612xfJPuqtG9f3; Sat, 21 Aug 2021 07:48:20 -0700 X-Received: from mail-wr1-f46.google.com (mail-wr1-f46.google.com [209.85.221.46]) by mx.groups.io with SMTP id smtpd.web09.11631.1629557300023258598 for ; Sat, 21 Aug 2021 07:48:20 -0700 X-Received: by mail-wr1-f46.google.com with SMTP id r7so18669112wrs.0 for ; Sat, 21 Aug 2021 07:48:19 -0700 (PDT) X-Gm-Message-State: ipOX51iUzFo31qlAsm8nRsAAx1787277AA= X-Google-Smtp-Source: ABdhPJzlbVmpHwhto2PyltRf9vA2HEclXNpIbdWQQYQvPpLhoiDMPYKs3YZDh5a+3NJTePIp4Zfn8A== X-Received: by 2002:adf:d083:: with SMTP id y3mr4321585wrh.56.1629557298305; Sat, 21 Aug 2021 07:48:18 -0700 (PDT) X-Received: from PC-PEDRO.lan (bl8-253-151.dsl.telepac.pt. [85.241.253.151]) by smtp.gmail.com with ESMTPSA id j17sm9118036wrt.69.2021.08.21.07.48.17 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 21 Aug 2021 07:48:18 -0700 (PDT) From: "Pedro Falcato" To: devel@edk2.groups.io Cc: Pedro Falcato , Leif Lindholm , Michael D Kinney , Bret Barkelew Subject: [edk2-devel] [edk2-platforms PATCH v2 1/5] Ext4Pkg: Fix incorrect usage of Ext4InitExtentsMap. Date: Sat, 21 Aug 2021 15:47:06 +0100 Message-Id: <20210821144711.39546-2-pedro.falcato@gmail.com> In-Reply-To: <20210821144711.39546-1-pedro.falcato@gmail.com> References: <20210821144711.39546-1-pedro.falcato@gmail.com> MIME-Version: 1.0 Precedence: Bulk List-Unsubscribe: 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 Content-Transfer-Encoding: quoted-printable DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=groups.io; q=dns/txt; s=20140610; t=1629557300; bh=9V1VLRO7vNRBeXwhWldsR/pXauMuFw6Z6TCufc0bblU=; h=Cc:Date:From:Reply-To:Subject:To; b=ISSWTuvM+oCYj4yNuAtMaiWoMaelGpy54dDXB1hhPDaRQACROvvlnGtgXHh8nZ466vP NrM65uhTj3Ot0GBH0WYi/esWOnZ/f9jv/8PNgNNk9ssgwDCJV4++Hq8Fm7ejGV5Y+WaZ9 fNA0CTsdaMOJLLzNkNX/Ys7hCrAPQTJXELM= X-ZohoMail-DKIM: pass (identity @groups.io) X-ZM-MESSAGEID: 1629557303128100006 Content-Type: text/plain; charset="utf-8" Fixes bug triggered by ShellPkg code, in usage of EFI_FILE_PROTOCOL's Open(). Cc: Leif Lindholm Cc: Michael D Kinney Cc: Bret Barkelew Signed-off-by: Pedro Falcato --- Features/Ext4Pkg/Ext4Dxe/File.c | 29 ++++++++++++++++++++++------- 1 file changed, 22 insertions(+), 7 deletions(-) diff --git a/Features/Ext4Pkg/Ext4Dxe/File.c b/Features/Ext4Pkg/Ext4Dxe/Fil= e.c index 0f5fa6f73fb6..a3eff2b48a07 100644 --- a/Features/Ext4Pkg/Ext4Dxe/File.c +++ b/Features/Ext4Pkg/Ext4Dxe/File.c @@ -207,6 +207,11 @@ Ext4Open ( =20 FileName +=3D Length; =20 + if (StrCmp(PathSegment, L".") =3D=3D 0) { + // Opens of "." are a no-op + continue; + } + DEBUG ((DEBUG_FS, "[ext4] Opening %s\n", PathSegment)); =20 if (!Ext4FileIsDir (Current)) { @@ -512,12 +517,20 @@ Ext4GetFileInfo ( IN EXT4_FILE *File, OUT EFI_FILE_INFO *Info, IN OUT UINTN *BufferSize ) { - UINTN FileNameLen; - UINTN FileNameSize; - UINTN NeededLength; + UINTN FileNameLen; + UINTN FileNameSize; + UINTN NeededLength; + CONST CHAR16 *FileName; =20 - FileNameLen =3D StrLen (File->FileName); - FileNameSize =3D StrSize (File->FileName); + if (File->InodeNum =3D=3D 2) { + // Root inode gets a filename of "", regardless of how it was opened. + FileName =3D L""; + } else { + FileName =3D File->FileName; + } + + FileNameLen =3D StrLen (FileName); + FileNameSize =3D StrSize (FileName); =20 NeededLength =3D SIZE_OF_EFI_FILE_INFO + FileNameSize; =20 @@ -540,7 +553,7 @@ Ext4GetFileInfo ( =20 *BufferSize =3D NeededLength; =20 - return StrCpyS (Info->FileName, FileNameLen + 1, File->FileName); + return StrCpyS (Info->FileName, FileNameLen + 1, FileName); } =20 /** @@ -687,6 +700,7 @@ Ext4DuplicateFile ( { EXT4_PARTITION *Partition; EXT4_FILE *File; + EFI_STATUS Status; =20 Partition =3D Original->Partition; File =3D AllocateZeroPool (sizeof (EXT4_FILE)); @@ -717,7 +731,8 @@ Ext4DuplicateFile ( File->InodeNum =3D Original->InodeNum; File->OpenMode =3D 0; // Will be filled by other code =20 - if (!Ext4InitExtentsMap (File)) { + Status =3D Ext4InitExtentsMap (File); + if (EFI_ERROR (Status)) { FreePool (File->FileName); FreePool (File->Inode); FreePool (File); --=20 2.33.0 -=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 (#79662): https://edk2.groups.io/g/devel/message/79662 Mute This Topic: https://groups.io/mt/85043011/1787277 Group Owner: devel+owner@edk2.groups.io Unsubscribe: https://edk2.groups.io/g/devel/unsub [importer@patchew.org] -=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-