[partition] Disentangle questions of suitability of ESP

- split into size, type, flags so the warning message can
  be tailored to what is wrong.
This commit is contained in:
Adriaan de Groot 2021-08-27 17:27:26 +02:00
parent 7d08770806
commit 6324fa3eb9
2 changed files with 54 additions and 21 deletions

View File

@ -447,31 +447,40 @@ isEfiSystem()
} }
bool bool
isEfiFilesystemSuitable(const Partition* candidate) isEfiFilesystemSuitableType( const Partition* candidate )
{ {
auto type = candidate->fileSystem().type(); auto type = candidate->fileSystem().type();
switch ( type )
{
case FileSystem::Type::Fat32:
return true;
#ifdef WITH_KPMCORE4API
case FileSystem::Type::Fat12:
#endif
case FileSystem::Type::Fat16:
cWarning() << "FAT12 and FAT16 are probably not supported by EFI";
return false;
default:
cWarning() << "EFI boot partition must be FAT32";
return false;
}
}
bool
isEfiFilesystemSuitableSize( const Partition* candidate )
{
auto size = candidate->capacity(); // bytes auto size = candidate->capacity(); // bytes
using CalamaresUtils::Units::operator""_MiB; using CalamaresUtils::Units::operator""_MiB;
if ( size >= 300_MiB )
switch( type )
{ {
case FileSystem::Type::Fat32: return true;
if ( size >= 300_MiB ) }
{ else
return true; {
} cWarning() << "Filesystem for EFI is too small (" << size << "bytes)";
cWarning() << "FAT32 filesystem for EFI is too small (" << size << "bytes)"; return false;
return false;
#ifdef WITH_KPMCORE4API
case FileSystem::Type::Fat12:
#endif
case FileSystem::Type::Fat16:
cWarning() << "FAT12 and FAT16 are probably not supported by EFI";
return false;
default:
cWarning() << "EFI boot partition must be FAT32";
return false;
} }
} }
@ -508,6 +517,15 @@ isEfiBootable( const Partition* candidate )
#endif #endif
} }
// TODO: this is configurable via the config file **already**
size_t
efiFilesystemMinimumSize()
{
using CalamaresUtils::Units::operator""_MiB;
return 300_MiB;
}
QString QString
canonicalFilesystemName( const QString& fsName, FileSystem::Type* fsType ) canonicalFilesystemName( const QString& fsName, FileSystem::Type* fsType )
{ {

View File

@ -84,9 +84,24 @@ bool isEfiSystem();
/** /**
* @brief Is the @p partition suitable as an EFI boot partition? * @brief Is the @p partition suitable as an EFI boot partition?
* Checks for filesystem type (FAT32) and size (300MiB at least). * Checks for filesystem type (FAT32).
*/ */
bool isEfiFilesystemSuitable( const Partition* candidate ); bool isEfiFilesystemSuitableType( const Partition* candidate );
/**
* @brief Is the @p partition suitable as an EFI boot partition?
* Checks for filesystem size (300MiB, see efiFilesystemMinimumSize).
*/
bool isEfiFilesystemSuitableSize( const Partition* candidate );
/** @brief Returns the minimum size of an EFI boot partition.
*
* This is determined as 300MiB, based on the FAT32 standard
* and EFI documentation (and not a little discussion in Calamares
* issues about what works, what is effective, and what is mandated
* by the standard and how all of those are different).
*/
size_t efiFilesystemMinimumSize();
/** /**
* @brief Is the given @p partition bootable in EFI? Depending on * @brief Is the given @p partition bootable in EFI? Depending on