MdeModulePkg: Add a check for metadata size in NvmExpress Driver

Ref: https://bugzilla.tianocore.org/show_bug.cgi?id=3856

Currently this NvmeExpress Driver do not support metadata handling.
According to the NVME specs, metadata may be transferred to the host after
the logical block data. It can overrun the input buffer which may only
be the size of logical block data.

Add a check to return not support for the namespaces formatted with
metadata.

v2 changes:
 - Change debug log level from INFO to ERROR
 - Change to if (NamespaceData->LbaFormat[LbaFmtIdx].Ms != 0)

v1: https://edk2.groups.io/g/devel/message/87242

Cc: Jian J Wang <jian.j.wang@intel.com>
Cc: Liming Gao <gaoliming@byosoft.com.cn>
Cc: Hao A Wu <hao.a.wu@intel.com>
Cc: Ray Ni <ray.ni@intel.com>

Signed-off-by: Hua Ma <hua.ma@intel.com>
Reviewed-by: Hao A Wu <hao.a.wu@intel.com>
This commit is contained in:
Ma, Hua 2022-03-03 13:06:04 +08:00 committed by mergify[bot]
parent 4adc364c75
commit 79f2734e5a
2 changed files with 33 additions and 3 deletions

View File

@ -139,6 +139,21 @@ EnumerateNvmeDevNamespace (
Flbas = NamespaceData->Flbas;
LbaFmtIdx = Flbas & 0xF;
//
// Currently this NVME driver only suport Metadata Size == 0
//
if (NamespaceData->LbaFormat[LbaFmtIdx].Ms != 0) {
DEBUG ((
DEBUG_ERROR,
"NVME IDENTIFY NAMESPACE [%d] Ms(%d) is not supported.\n",
NamespaceId,
NamespaceData->LbaFormat[LbaFmtIdx].Ms
));
Status = EFI_UNSUPPORTED;
goto Exit;
}
Lbads = NamespaceData->LbaFormat[LbaFmtIdx].Lbads;
Device->Media.BlockSize = (UINT32)1 << Lbads;

View File

@ -104,6 +104,21 @@ EnumerateNvmeDevNamespace (
//
Flbas = NamespaceData->Flbas;
LbaFmtIdx = Flbas & 0xF;
//
// Currently this NVME driver only suport Metadata Size == 0
//
if (NamespaceData->LbaFormat[LbaFmtIdx].Ms != 0) {
DEBUG ((
DEBUG_ERROR,
"NVME IDENTIFY NAMESPACE [%d] Ms(%d) is not supported.\n",
NamespaceId,
NamespaceData->LbaFormat[LbaFmtIdx].Ms
));
Status = EFI_UNSUPPORTED;
goto Exit;
}
Lbads = NamespaceData->LbaFormat[LbaFmtIdx].Lbads;
NamespaceInfo->Media.InterfaceType = MSG_NVME_NAMESPACE_DP;