blob: 98f35ae2aa018ac727479f272f8af6a0a32743c2 [file] [log] [blame] [edit]
// Copyright 2019 The Fuchsia Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef SRC_STORAGE_BLOBFS_BLOBFS_CHECKER_H_
#define SRC_STORAGE_BLOBFS_BLOBFS_CHECKER_H_
#ifdef __Fuchsia__
#include "src/storage/blobfs/blobfs.h"
#else
#include "src/storage/blobfs/host.h"
#endif
#include <memory>
namespace blobfs {
class BlobfsChecker {
public:
struct Options {
// If true, repair simple issues.
bool repair = true;
};
explicit BlobfsChecker(std::unique_ptr<Blobfs> blobfs) : BlobfsChecker(std::move(blobfs), {}) {}
explicit BlobfsChecker(std::unique_ptr<Blobfs> blobfs, Options option);
BlobfsChecker(const BlobfsChecker&) = delete;
BlobfsChecker& operator=(const BlobfsChecker&) = delete;
// Check validates the blobfs filesystem provided when the Checker was
// constructed. It walks each of the inode and block allocation bitmaps
// only once.
zx_status_t Check();
private:
std::unique_ptr<Blobfs> blobfs_;
uint32_t alloc_inodes_ = 0;
uint32_t alloc_blocks_ = 0;
uint32_t error_blobs_ = 0;
uint32_t inode_blocks_ = 0;
const Options options_;
zx_status_t CheckBackupSuperblock();
void TraverseInodeBitmap();
void TraverseBlockBitmap();
zx_status_t CheckAllocatedCounts() const;
};
#ifdef __Fuchsia__
// Validate that the contents of the superblock matches the results claimed in the underlying
// volume manager.
//
// If the results are inconsistent, update the FVM's allocation accordingly.
zx_status_t CheckFvmConsistency(const Superblock* info, BlockDevice* device, bool repair);
#endif // __Fuchsia__
} // namespace blobfs
#endif // SRC_STORAGE_BLOBFS_BLOBFS_CHECKER_H_