]> git.proxmox.com Git - mirror_edk2.git/commit
MdeModulePkg/UdfDxe: Add more check when getting PD from LongAd
authorHao Wu <hao.a.wu@intel.com>
Tue, 16 Oct 2018 04:16:02 +0000 (12:16 +0800)
committerHao Wu <hao.a.wu@intel.com>
Tue, 23 Oct 2018 06:24:58 +0000 (14:24 +0800)
commit85acb5e8ffef026b80241b1657ed4fba26e382b1
treeccc0e770198aa4803d14931fa49bd63e9fb0d9b6
parent32698a8f013140b8f77f18a03c64c40ba04c2e18
MdeModulePkg/UdfDxe: Add more check when getting PD from LongAd

REF:https://bugzilla.tianocore.org/show_bug.cgi?id=1254

This commit will add an additional check within function GetPdFromLongAd()
when getting a Partition Descriptor from given a Long Allocation
Descriptor.

According to UDF 2.60 Spec, Section 2.2.13:

> The partition reference numbers used are determined by the order of the
> Partition Maps in the LVD.

(Also the picture comes before the above contents)

And a more detailed explanation of the partition reference numbers is at
https://sites.google.com/site/udfintro/ (seems not a formal documentation
though), Section 5.3.6.

Based on the above findings, the 'PartitionReferenceNumber' field in a
Long Allocation Descriptor is used as an index to access the Partition
Maps data within a Logical Volume Descriptor.

Hence, the new check focuses on the validity of this
'PartitionReferenceNumber' field in a Long Allocation Descriptor. Since
the current implementation of UdfDxe driver supports only one partition on
a Logical Volume, so the value of 'PartitionReferenceNumber' should be 0.

Cc: Ruiyu Ni <ruiyu.ni@intel.com>
Contributed-under: TianoCore Contribution Agreement 1.1
Signed-off-by: Hao Wu <hao.a.wu@intel.com>
Reviewed-by: Paulo Alcantara <palcantara@suse.de>
Acked-by: Star Zeng <star.zeng@intel.com>
MdeModulePkg/Universal/Disk/UdfDxe/FileSystemOperations.c