1*e7c364b6SAndroid Build Coastguard Worker /* 2*e7c364b6SAndroid Build Coastguard Worker * Copyright (C) 2019 The Android Open Source Project 3*e7c364b6SAndroid Build Coastguard Worker * 4*e7c364b6SAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*e7c364b6SAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*e7c364b6SAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*e7c364b6SAndroid Build Coastguard Worker * 8*e7c364b6SAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*e7c364b6SAndroid Build Coastguard Worker * 10*e7c364b6SAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*e7c364b6SAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*e7c364b6SAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*e7c364b6SAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*e7c364b6SAndroid Build Coastguard Worker * limitations under the License. 15*e7c364b6SAndroid Build Coastguard Worker */ 16*e7c364b6SAndroid Build Coastguard Worker 17*e7c364b6SAndroid Build Coastguard Worker #pragma once 18*e7c364b6SAndroid Build Coastguard Worker 19*e7c364b6SAndroid Build Coastguard Worker #include <stdint.h> 20*e7c364b6SAndroid Build Coastguard Worker 21*e7c364b6SAndroid Build Coastguard Worker #include <memory> 22*e7c364b6SAndroid Build Coastguard Worker #include <string> 23*e7c364b6SAndroid Build Coastguard Worker 24*e7c364b6SAndroid Build Coastguard Worker #include <android-base/unique_fd.h> 25*e7c364b6SAndroid Build Coastguard Worker 26*e7c364b6SAndroid Build Coastguard Worker #include "otautil/rangeset.h" 27*e7c364b6SAndroid Build Coastguard Worker 28*e7c364b6SAndroid Build Coastguard Worker // This is the base class to read data from source and provide the data to FUSE. 29*e7c364b6SAndroid Build Coastguard Worker class FuseDataProvider { 30*e7c364b6SAndroid Build Coastguard Worker public: FuseDataProvider(uint64_t file_size,uint32_t block_size)31*e7c364b6SAndroid Build Coastguard Worker FuseDataProvider(uint64_t file_size, uint32_t block_size) 32*e7c364b6SAndroid Build Coastguard Worker : file_size_(file_size), fuse_block_size_(block_size) {} 33*e7c364b6SAndroid Build Coastguard Worker 34*e7c364b6SAndroid Build Coastguard Worker virtual ~FuseDataProvider() = default; 35*e7c364b6SAndroid Build Coastguard Worker file_size()36*e7c364b6SAndroid Build Coastguard Worker uint64_t file_size() const { 37*e7c364b6SAndroid Build Coastguard Worker return file_size_; 38*e7c364b6SAndroid Build Coastguard Worker } fuse_block_size()39*e7c364b6SAndroid Build Coastguard Worker uint32_t fuse_block_size() const { 40*e7c364b6SAndroid Build Coastguard Worker return fuse_block_size_; 41*e7c364b6SAndroid Build Coastguard Worker } 42*e7c364b6SAndroid Build Coastguard Worker 43*e7c364b6SAndroid Build Coastguard Worker // Reads |fetch_size| bytes data starting from |start_block|. Puts the result in |buffer|. 44*e7c364b6SAndroid Build Coastguard Worker virtual bool ReadBlockAlignedData(uint8_t* buffer, uint32_t fetch_size, 45*e7c364b6SAndroid Build Coastguard Worker uint32_t start_block) const = 0; 46*e7c364b6SAndroid Build Coastguard Worker 47*e7c364b6SAndroid Build Coastguard Worker virtual bool Valid() const = 0; 48*e7c364b6SAndroid Build Coastguard Worker Close()49*e7c364b6SAndroid Build Coastguard Worker virtual void Close() {} 50*e7c364b6SAndroid Build Coastguard Worker 51*e7c364b6SAndroid Build Coastguard Worker protected: 52*e7c364b6SAndroid Build Coastguard Worker FuseDataProvider() = default; 53*e7c364b6SAndroid Build Coastguard Worker 54*e7c364b6SAndroid Build Coastguard Worker // Size in bytes of the file to read. 55*e7c364b6SAndroid Build Coastguard Worker uint64_t file_size_ = 0; 56*e7c364b6SAndroid Build Coastguard Worker // Block size passed to the fuse, this is different from the block size of the block device. 57*e7c364b6SAndroid Build Coastguard Worker uint32_t fuse_block_size_ = 0; 58*e7c364b6SAndroid Build Coastguard Worker }; 59*e7c364b6SAndroid Build Coastguard Worker 60*e7c364b6SAndroid Build Coastguard Worker // This class reads data from a file. 61*e7c364b6SAndroid Build Coastguard Worker class FuseFileDataProvider : public FuseDataProvider { 62*e7c364b6SAndroid Build Coastguard Worker public: 63*e7c364b6SAndroid Build Coastguard Worker FuseFileDataProvider(const std::string& path, uint32_t block_size); 64*e7c364b6SAndroid Build Coastguard Worker 65*e7c364b6SAndroid Build Coastguard Worker static std::unique_ptr<FuseDataProvider> CreateFromFile(const std::string& path, 66*e7c364b6SAndroid Build Coastguard Worker uint32_t block_size); 67*e7c364b6SAndroid Build Coastguard Worker 68*e7c364b6SAndroid Build Coastguard Worker bool ReadBlockAlignedData(uint8_t* buffer, uint32_t fetch_size, 69*e7c364b6SAndroid Build Coastguard Worker uint32_t start_block) const override; 70*e7c364b6SAndroid Build Coastguard Worker Valid()71*e7c364b6SAndroid Build Coastguard Worker bool Valid() const override { 72*e7c364b6SAndroid Build Coastguard Worker return fd_ != -1; 73*e7c364b6SAndroid Build Coastguard Worker } 74*e7c364b6SAndroid Build Coastguard Worker 75*e7c364b6SAndroid Build Coastguard Worker void Close() override; 76*e7c364b6SAndroid Build Coastguard Worker 77*e7c364b6SAndroid Build Coastguard Worker private: 78*e7c364b6SAndroid Build Coastguard Worker // The underlying source to read data from. 79*e7c364b6SAndroid Build Coastguard Worker android::base::unique_fd fd_; 80*e7c364b6SAndroid Build Coastguard Worker }; 81*e7c364b6SAndroid Build Coastguard Worker 82*e7c364b6SAndroid Build Coastguard Worker // This class parses a block map and reads data from the underlying block device. 83*e7c364b6SAndroid Build Coastguard Worker class FuseBlockDataProvider : public FuseDataProvider { 84*e7c364b6SAndroid Build Coastguard Worker public: 85*e7c364b6SAndroid Build Coastguard Worker // Constructs the fuse provider from the block map. 86*e7c364b6SAndroid Build Coastguard Worker static std::unique_ptr<FuseDataProvider> CreateFromBlockMap(const std::string& block_map_path, 87*e7c364b6SAndroid Build Coastguard Worker uint32_t fuse_block_size); 88*e7c364b6SAndroid Build Coastguard Worker ranges()89*e7c364b6SAndroid Build Coastguard Worker RangeSet ranges() const { 90*e7c364b6SAndroid Build Coastguard Worker return ranges_; 91*e7c364b6SAndroid Build Coastguard Worker } 92*e7c364b6SAndroid Build Coastguard Worker 93*e7c364b6SAndroid Build Coastguard Worker bool ReadBlockAlignedData(uint8_t* buffer, uint32_t fetch_size, 94*e7c364b6SAndroid Build Coastguard Worker uint32_t start_block) const override; 95*e7c364b6SAndroid Build Coastguard Worker Valid()96*e7c364b6SAndroid Build Coastguard Worker bool Valid() const override { 97*e7c364b6SAndroid Build Coastguard Worker return fd_ != -1; 98*e7c364b6SAndroid Build Coastguard Worker } 99*e7c364b6SAndroid Build Coastguard Worker 100*e7c364b6SAndroid Build Coastguard Worker void Close() override; 101*e7c364b6SAndroid Build Coastguard Worker 102*e7c364b6SAndroid Build Coastguard Worker private: 103*e7c364b6SAndroid Build Coastguard Worker FuseBlockDataProvider(uint64_t file_size, uint32_t fuse_block_size, android::base::unique_fd&& fd, 104*e7c364b6SAndroid Build Coastguard Worker uint32_t source_block_size, RangeSet ranges); 105*e7c364b6SAndroid Build Coastguard Worker // The underlying block device to read data from. 106*e7c364b6SAndroid Build Coastguard Worker android::base::unique_fd fd_; 107*e7c364b6SAndroid Build Coastguard Worker // The block size of the source block device. 108*e7c364b6SAndroid Build Coastguard Worker uint32_t source_block_size_; 109*e7c364b6SAndroid Build Coastguard Worker // The block ranges from the source block device that consist of the file 110*e7c364b6SAndroid Build Coastguard Worker RangeSet ranges_; 111*e7c364b6SAndroid Build Coastguard Worker }; 112