| // |
| // 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_MTD_FILE_DESCRIPTOR_H_ |
| #define UPDATE_ENGINE_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 <mtdutils.h> |
| |
| #include "update_engine/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; |
| bool BlkIoctl(int request, |
| uint64_t start, |
| uint64_t length, |
| int* result) override { |
| return false; |
| } |
| bool Close() override; |
| |
| private: |
| std::unique_ptr<MtdReadContext, decltype(&mtd_read_close)> read_ctx_; |
| std::unique_ptr<MtdWriteContext, decltype(&mtd_write_close)> 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; |
| 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_MTD_FILE_DESCRIPTOR_H_ |