/* * Copyright (c) 2006-2016, ARM Limited, All Rights Reserved * SPDX-License-Identifier: Apache-2.0 * * 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 __FLASH_JOURNAL_PRIVATE_H__ #define __FLASH_JOURNAL_PRIVATE_H__ #ifdef __cplusplus extern "C" { #endif // __cplusplus #include "flash-journal/flash_journal.h" #include "flash-journal-strategy-sequential/config.h" static const uint32_t SEQUENTIAL_FLASH_JOURNAL_INVALD_NEXT_SEQUENCE_NUMBER = 0xFFFFFFFFUL; static const uint32_t SEQUENTIAL_FLASH_JOURNAL_VERSION = 1; static const uint32_t SEQUENTIAL_FLASH_JOURNAL_MAGIC = 0xCE02102AUL; typedef enum { SEQUENTIAL_JOURNAL_STATE_NOT_INITIALIZED, SEQUENTIAL_JOURNAL_STATE_INIT_SCANNING_LOG_HEADERS, SEQUENTIAL_JOURNAL_STATE_INITIALIZED, SEQUENTIAL_JOURNAL_STATE_RESETING, SEQUENTIAL_JOURNAL_STATE_LOGGING_ERASE, SEQUENTIAL_JOURNAL_STATE_LOGGING_HEAD, SEQUENTIAL_JOURNAL_STATE_LOGGING_BODY, SEQUENTIAL_JOURNAL_STATE_LOGGING_TAIL, SEQUENTIAL_JOURNAL_STATE_READING, } SequentialFlashJournalState_t; /** * Meta-data placed at the head of a sequential-log entry. */ typedef struct _SequentialFlashJournalLogHead { uint32_t version; uint32_t magic; uint32_t sequenceNumber; uint32_t reserved; } SequentialFlashJournalLogHead_t; #define SEQUENTIAL_JOURNAL_VALID_HEAD(PTR) \ (((PTR)->version == SEQUENTIAL_FLASH_JOURNAL_VERSION) && ((PTR)->magic == SEQUENTIAL_FLASH_JOURNAL_MAGIC)) /** * Meta-data placed at the tail of a sequential-log entry. * * @note the most crucial items (the ones which play a role in the validation of * the log-entry) are placed at the end of this structure; this ensures that * a partially written log-entry-tail won't be accepted as valid. */ typedef struct _SequentialFlashJournalLogTail { uint64_t sizeofBlob; /**< the size of the payload in this blob. */ uint32_t magic; uint32_t sequenceNumber; } SequentialFlashJournalLogTail_t; #define SEQUENTIAL_JOURNAL_VALID_TAIL(TAIL_PTR) ((TAIL_PTR)->magic == SEQUENTIAL_FLASH_JOURNAL_MAGIC) typedef struct _SequentialFlashJournal_t { FlashJournal_Ops_t ops; /**< the mandatory OPS table defining the strategy. */ FlashJournal_Callback_t callback; /**< command completion callback. */ FlashJournal_Info_t info; /**< the info structure returned from GetInfo(). */ ARM_DRIVER_STORAGE *mtd; /**< The underlying Memory-Technology-Device. */ ARM_STORAGE_CAPABILITIES mtdCapabilities; /**< the return from mtd->GetCapabilities(); held for quick reference. */ uint64_t mtdStartOffset; /**< the start of the address range maintained by the underlying MTD. */ uint32_t sequentialSkip; /**< size of the log stride. */ uint32_t nextSequenceNumber; /**< the next valid sequence number to be used when logging the next blob. */ uint32_t currentBlobIndex; /**< index of the most recently written blob. */ SequentialFlashJournalState_t state; /**< state of the journal. SEQUENTIAL_JOURNAL_STATE_INITIALIZED being the default. */ FlashJournal_OpCode_t prevCommand; /**< the last command issued to the journal. */ /** * The following is a union of sub-structures meant to keep state relevant * to the commands during their execution. */ union { /** state relevant to initialization. */ struct { uint64_t currentOffset; union { SequentialFlashJournalLogHead_t head; struct { uint32_t headSequenceNumber; SequentialFlashJournalLogTail_t tail; }; }; } initScan; /** state relevant to logging of data. */ struct { const uint8_t *blob; /**< the original buffer holding source data. */ size_t sizeofBlob; union { struct { uint64_t eraseOffset; }; struct { uint64_t offset; /**< the current offset at which data is being written. */ uint64_t tailOffset; /**< offset at which the SequentialFlashJournalLogTail_t will be logged for this log-entry. */ const uint8_t *dataBeingLogged; /**< temporary pointer aimed at the next data to be logged. */ size_t amountLeftToLog; union { SequentialFlashJournalLogHead_t head; SequentialFlashJournalLogTail_t tail; }; }; }; } log; /** state relevant to read-back of data. */ struct { const uint8_t *blob; /**< the original buffer holding source data. */ size_t sizeofBlob; uint64_t offset; /**< the current offset at which data is being written. */ uint8_t *dataBeingRead; /**< temporary pointer aimed at the next data to be read-into. */ size_t amountLeftToRead; size_t totalDataRead; /**< the total data that has been read off the blob so far. */ } read; }; } SequentialFlashJournal_t; /**< * A static assert to ensure that the size of SequentialJournal is smaller than * FlashJournal_t. The caller will only allocate a FlashJournal_t and expect the * Sequential Strategy to reuse that space for a SequentialFlashJournal_t. */ typedef char AssertSequentialJournalSizeLessThanOrEqualToGenericJournal[sizeof(SequentialFlashJournal_t)<=sizeof(FlashJournal_t)?1:-1]; #ifdef __cplusplus } #endif // __cplusplus #endif /* __FLASH_JOURNAL_PRIVATE_H__ */