// // Copyright (C) 2014 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. // #ifndef UPDATE_ENGINE_PAYLOAD_CONSUMER_MTD_FILE_DESCRIPTOR_H_ #define UPDATE_ENGINE_PAYLOAD_CONSUMER_MTD_FILE_DESCRIPTOR_H_ // This module defines file descriptors that deal with NAND media. We are // concerned with raw NAND access (as MTD device), and through UBI layer. #include #include #include "update_engine/payload_consumer/file_descriptor.h" namespace chromeos_update_engine { // A class defining the file descriptor API for raw MTD device. This file // descriptor supports either random read, or sequential write but not both at // once. class MtdFileDescriptor : public EintrSafeFileDescriptor { public: MtdFileDescriptor(); static bool IsMtd(const char* path); bool Open(const char* path, int flags, mode_t mode) override; bool Open(const char* path, int flags) override; ssize_t Read(void* buf, size_t count) override; ssize_t Write(const void* buf, size_t count) override; off64_t Seek(off64_t offset, int whence) override; uint64_t BlockDevSize() override { return 0; } bool BlkIoctl(int request, uint64_t start, uint64_t length, int* result) override { return false; } bool Close() override; private: std::unique_ptr read_ctx_; std::unique_ptr write_ctx_; uint64_t nr_written_; }; struct UbiVolumeInfo { // Number of eraseblocks. uint64_t reserved_ebs; // Size of each eraseblock. uint64_t eraseblock_size; }; // A file descriptor to update a UBI volume, similar to MtdFileDescriptor. // Once the file descriptor is opened for write, the volume is marked as being // updated. The volume will not be usable until an update is completed. See // UBI_IOCVOLUP ioctl operation. class UbiFileDescriptor : public EintrSafeFileDescriptor { public: // Perform some queries about |path| to see if it is a UBI volume. static bool IsUbi(const char* path); bool Open(const char* path, int flags, mode_t mode) override; bool Open(const char* path, int flags) override; ssize_t Read(void* buf, size_t count) override; ssize_t Write(const void* buf, size_t count) override; off64_t Seek(off64_t offset, int whence) override; uint64_t BlockDevSize() override { return 0; } bool BlkIoctl(int request, uint64_t start, uint64_t length, int* result) override { return false; } bool Close() override; private: enum Mode { kReadOnly, kWriteOnly }; uint64_t usable_eb_blocks_; uint64_t eraseblock_size_; uint64_t volume_size_; uint64_t nr_written_; Mode mode_; }; } // namespace chromeos_update_engine #endif // UPDATE_ENGINE_PAYLOAD_CONSUMER_MTD_FILE_DESCRIPTOR_H_