2020-04-16 09:15:26 +02:00
|
|
|
/*
|
|
|
|
* APFS.cpp
|
|
|
|
*
|
|
|
|
* Created on: 16 Apr 2020
|
|
|
|
* Author: jief
|
|
|
|
*/
|
|
|
|
|
2020-08-17 21:40:52 +02:00
|
|
|
#include <Platform.h> // Only use angled for Platform, else, xcode project won't compile
|
2020-04-16 09:15:26 +02:00
|
|
|
#include "guid.h"
|
2020-08-07 10:23:46 +02:00
|
|
|
#include "APFS.h"
|
2020-04-16 09:15:26 +02:00
|
|
|
|
|
|
|
|
|
|
|
/* S. Mitrofanov 08.06.2016
|
|
|
|
* APFS Container introduced new partitions structure
|
|
|
|
* Now we have, for example:
|
|
|
|
* /dev/disk0 (internal, physical):
|
|
|
|
* #: TYPE NAME SIZE IDENTIFIER
|
|
|
|
* 0: GUID_partition_scheme *240.1 GB disk0
|
|
|
|
* 1: EFI EFI 209.7 MB disk0s1
|
|
|
|
* 2: Apple_APFS Container disk1 239.2 GB disk0s2
|
|
|
|
* 3: Apple_KernelCoreDump 655.4 MB disk0s3
|
|
|
|
*
|
|
|
|
* /dev/disk1 (synthesized):
|
|
|
|
* #: TYPE NAME SIZE IDENTIFIER
|
|
|
|
* 0: APFS Container Scheme - +239.2 GB disk1
|
|
|
|
* Physical Store disk0s2
|
|
|
|
* 1: APFS Volume Macintosh SSD 170.8 GB disk1s1
|
|
|
|
* 2: APFS Volume Preboot 17.9 MB disk1s2
|
|
|
|
* 3: APFS Volume Recovery 521.1 MB disk1s3
|
|
|
|
* 4: APFS Volume VM 1.1 GB disk1s4
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
2020-08-07 10:23:46 +02:00
|
|
|
/*
|
|
|
|
* Function for obtaining unique part id from APFS partition
|
|
|
|
* IN: DevicePath
|
|
|
|
* OUT: EFI_GUID
|
|
|
|
* returns null if it is not APFS part
|
|
|
|
*/
|
2020-04-16 09:15:26 +02:00
|
|
|
EFI_GUID *APFSPartitionUUIDExtract(
|
2020-09-28 17:57:50 +02:00
|
|
|
const EFI_DEVICE_PATH_PROTOCOL *DevicePath
|
2020-04-16 09:15:26 +02:00
|
|
|
)
|
|
|
|
{
|
|
|
|
while (!IsDevicePathEndType(DevicePath) &&
|
|
|
|
!(DevicePathType(DevicePath) == MEDIA_DEVICE_PATH && DevicePathSubType (DevicePath) == MEDIA_VENDOR_DP)) {
|
|
|
|
DevicePath = NextDevicePathNode(DevicePath);
|
|
|
|
}
|
|
|
|
if (DevicePathType(DevicePath) == MEDIA_DEVICE_PATH && DevicePathSubType (DevicePath) == MEDIA_VENDOR_DP) {
|
|
|
|
//Check that vendor-assigned GUID defines APFS Container Partition
|
2020-09-23 15:47:47 +02:00
|
|
|
if ( GuidLEToXString8(*(EFI_GUID *)((UINT8 *)DevicePath+0x04)).equalIC(ApfsSignatureUUID) ) {
|
2020-04-16 09:15:26 +02:00
|
|
|
return (EFI_GUID *)((UINT8 *)DevicePath+0x14);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2020-08-07 10:23:46 +02:00
|
|
|
/*
|
|
|
|
* Function for obtaining unique part id from APFS partition
|
|
|
|
* IN: DevicePath
|
|
|
|
* OUT: EFI_GUID
|
|
|
|
* returns empty string if it is not APFS part
|
|
|
|
*/
|
|
|
|
XString8 APFSPartitionUUIDExtractAsXString8(
|
2020-09-28 17:57:50 +02:00
|
|
|
const EFI_DEVICE_PATH_PROTOCOL *DevicePath
|
2020-08-07 10:23:46 +02:00
|
|
|
)
|
|
|
|
{
|
|
|
|
EFI_GUID* uuid = APFSPartitionUUIDExtract(DevicePath);
|
2020-09-23 15:47:47 +02:00
|
|
|
if ( uuid ) return GuidLEToXString8(*uuid);
|
2020-08-07 10:23:46 +02:00
|
|
|
return ""_XS8;
|
2020-04-16 09:15:26 +02:00
|
|
|
}
|
|
|
|
|
2020-08-07 10:23:46 +02:00
|
|
|
|
|
|
|
//XStringW APFSPartitionUUIDExtractAsXStringW(
|
|
|
|
// IN EFI_DEVICE_PATH_PROTOCOL *DevicePath
|
|
|
|
// )
|
|
|
|
//{
|
|
|
|
// EFI_GUID* uuid = APFSPartitionUUIDExtract(DevicePath);
|
|
|
|
// if ( uuid ) return GuidLEToXStringW(uuid);
|
|
|
|
// return L""_XSW;
|
|
|
|
//}
|
|
|
|
|
|
|
|
|