/* * Copyright 2006 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #pragma once #include #include #include #include #include "rangeset.h" // This class holds the content of a block map file. class BlockMapData { public: // A "block map" which looks like this (from uncrypt/uncrypt.cpp): // // /dev/block/platform/msm_sdcc.1/by-name/userdata # block device // 49652 4096 # file size in bytes, block size // 3 # count of block ranges // 1000 1008 # block range 0 // 2100 2102 # ... block range 1 // 30 33 # ... block range 2 // // Each block range represents a half-open interval; the line "30 33" reprents the blocks // [30, 31, 32]. static BlockMapData ParseBlockMapFile(const std::string& block_map_path); explicit operator bool() const { return !path_.empty(); } std::string path() const { return path_; } uint64_t file_size() const { return file_size_; } uint32_t block_size() const { return block_size_; } RangeSet block_ranges() const { return block_ranges_; } private: BlockMapData() = default; BlockMapData(const std::string& path, uint64_t file_size, uint32_t block_size, RangeSet block_ranges) : path_(path), file_size_(file_size), block_size_(block_size), block_ranges_(std::move(block_ranges)) {} std::string path_; uint64_t file_size_ = 0; uint32_t block_size_ = 0; RangeSet block_ranges_; }; /* * Use this to keep track of mapped segments. */ class MemMapping { public: ~MemMapping(); // Map a file into a private, read-only memory segment. If 'filename' begins with an '@' // character, it is a map of blocks to be mapped, otherwise it is treated as an ordinary file. bool MapFile(const std::string& filename); size_t ranges() const { return ranges_.size(); }; unsigned char* addr; // start of data size_t length; // length of data private: struct MappedRange { void* addr; size_t length; }; bool MapBlockFile(const std::string& filename); bool MapFD(int fd); std::vector ranges_; }; // Reboots the device into the specified target, by additionally handling quiescent reboot mode. // 'target' can be an empty string, which indicates booting into Android. bool Reboot(std::string_view target); // Triggers a shutdown. bool Shutdown(); // Returns a null-terminated char* array, where the elements point to the C-strings in the given // vector, plus an additional nullptr at the end. This is a helper function that facilitates // calling C functions (such as getopt(3)) that expect an array of C-strings. std::vector StringVectorToNullTerminatedArray(const std::vector& args);