Handle virtio in private fs mapping
When the vold core decides if a device is SD or USB, it checks for MMC or virtio, however when the filesystem type is decided, it does not check for virtio, only MMC. This causes virtio SD cards to be formatted with ext4 unconditionally. This fix is independently correct, but it incidentally gets adopted storage working on cuttlefish (and Android Emulator) because f2fs can support fscrypt and casefolding at the same time; ext4 currently cannot. Bug: 156286088 Change-Id: I0b41670d5f76b2506dad437917c2276f8e0aaccf
This commit is contained in:
parent
ff1fc9bc41
commit
c671731075
1 changed files with 5 additions and 3 deletions
|
@ -39,6 +39,7 @@
|
|||
#include <thread>
|
||||
|
||||
using android::base::StringPrintf;
|
||||
using android::vold::IsVirtioBlkDevice;
|
||||
|
||||
namespace android {
|
||||
namespace vold {
|
||||
|
@ -210,9 +211,10 @@ status_t PrivateVolume::doFormat(const std::string& fsType) {
|
|||
if (fsType == "auto") {
|
||||
// For now, assume that all MMC devices are flash-based SD cards, and
|
||||
// give everyone else ext4 because sysfs rotational isn't reliable.
|
||||
// Additionally, prefer f2fs for loop-bases devices
|
||||
if ((major(mRawDevice) == kMajorBlockMmc || major(mRawDevice) == kMajorBlockLoop) &&
|
||||
f2fs::IsSupported()) {
|
||||
// Additionally, prefer f2fs for loop-based devices
|
||||
if ((major(mRawDevice) == kMajorBlockMmc ||
|
||||
major(mRawDevice) == kMajorBlockLoop ||
|
||||
IsVirtioBlkDevice(major(mRawDevice))) && f2fs::IsSupported()) {
|
||||
resolvedFsType = "f2fs";
|
||||
} else {
|
||||
resolvedFsType = "ext4";
|
||||
|
|
Loading…
Reference in a new issue