| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195 | 
							- /*
 
-  * Copyright © 2014 Kosma Moczek <kosma@cloudyourcar.com>
 
-  * This program is free software. It comes without any warranty, to the extent
 
-  * permitted by applicable law. You can redistribute it and/or modify it under
 
-  * the terms of the Do What The Fuck You Want To Public License, Version 2, as
 
-  * published by Sam Hocevar. See the COPYING file for more details.
 
-  */
 
- #ifndef RINGFS_H
 
- #define RINGFS_H
 
- /**
 
-  * @defgroup ringfs_api RingFS API
 
-  * @{
 
-  */
 
- #include <stdint.h>
 
- #if defined ( __GNUC__ )
 
- #include <unistd.h>
 
- #endif
 
- #ifdef PRINTF_STDLIB
 
- #include <stdio.h>
 
- #endif
 
- #ifdef PRINTF_CUSTOM
 
- #include "tinystdio.h"
 
- #endif
 
- #if defined ( __ICCARM__ )
 
- typedef int ssize_t;
 
- #include <stdlib.h>
 
- #endif  
 
-    
 
- /**
 
-  * Flash memory+parition descriptor.
 
-  */
 
- struct ringfs_flash_partition
 
- {
 
-     int sector_size;            /**< Sector size, in bytes. */
 
-     int sector_offset;          /**< Partition offset, in sectors. */
 
-     int sector_count;           /**< Partition size, in sectors. */
 
-     /**
 
-      * Erase a sector.
 
-      * @param address Any address inside the sector.
 
-      * @returns Zero on success, -1 on failure.
 
-      */
 
-     int (*sector_erase)(struct ringfs_flash_partition *flash, int address);
 
-     /**
 
-      * Program flash memory bits by toggling them from 1 to 0.
 
-      * @param address Start address, in bytes.
 
-      * @param data Data to program.
 
-      * @param size Size of data.
 
-      * @returns size on success, -1 on failure.
 
-      */
 
-     ssize_t (*program)(struct ringfs_flash_partition *flash, int address, const void *data, size_t size);
 
-     /**
 
-      * Read flash memory.
 
-      * @param address Start address, in bytes.
 
-      * @param data Buffer to store read data.
 
-      * @param size Size of data.
 
-      * @returns size on success, -1 on failure.
 
-      */
 
-     ssize_t (*read)(struct ringfs_flash_partition *flash, int address, void *data, size_t size);
 
- };
 
- /** @private */
 
- struct ringfs_loc {
 
-     int sector;
 
-     int slot;
 
- };
 
- /**
 
-  * RingFS instance. Should be initialized with ringfs_init() befure use.
 
-  * Structure fields should not be accessed directly.
 
-  * */
 
- struct ringfs {
 
-     /* Constant values, set once at ringfs_init(). */
 
-     struct ringfs_flash_partition *flash;
 
-     uint32_t version;
 
-     int object_size;
 
-     /* Cached values. */
 
-     int slots_per_sector;
 
-     /* Read/write pointers. Modified as needed. */
 
-     struct ringfs_loc read;
 
-     struct ringfs_loc write;
 
-     struct ringfs_loc cursor;
 
-     int cursor_position;
 
- };
 
- /**
 
-  * Initialize a RingFS instance. Must be called before the instance can be used
 
-  * with the other ringfs_* functions.
 
-  *
 
-  * @param fs RingFS instance to be initialized.
 
-  * @param flash Flash memory interface. Must be implemented externally.
 
-  * @param version Object version. Should be incremented whenever the object's
 
-  *                semantics or size change in a backwards-incompatible way.
 
-  * @param object_size Size of one stored object, in bytes.
 
-  * @returns Zero on success, -1 on failure.
 
-  */
 
- int ringfs_init(struct ringfs *fs, struct ringfs_flash_partition *flash, uint32_t version, int object_size);
 
- /**
 
-  * Format the flash memory.
 
-  *
 
-  * @param fs Initialized RingFS instance.
 
-  * @returns Zero on success, -1 on failure.
 
-  */
 
- int ringfs_format(struct ringfs *fs);
 
- /**
 
-  * Scan the flash memory for a valid filesystem.
 
-  *
 
-  * @param fs Initialized RingFS instance.
 
-  * @returns Zero on success, -1 on failure.
 
-  */
 
- int ringfs_scan(struct ringfs *fs);
 
- /**
 
-  * Calculate maximum RingFS capacity.
 
-  *
 
-  * @param fs Initialized RingFS instance.
 
-  * @returns Maximum capacity on success, -1 on failure.
 
-  */
 
- int ringfs_capacity(struct ringfs *fs);
 
- /**
 
-  * Calculate approximate object count.
 
-  * Runs in O(1).
 
-  *
 
-  * @param fs Initialized RingFS instance.
 
-  * @returns Estimated object count on success, -1 on failure.
 
-  */
 
- int ringfs_count_estimate(struct ringfs *fs);
 
- /**
 
-  * Calculate exact object count.
 
-  * Runs in O(n).
 
-  *
 
-  * @param fs Initialized RingFS instance.
 
-  * @returns Exact object count on success, -1 on failure.
 
-  */
 
- int ringfs_count_exact(struct ringfs *fs);
 
- /**
 
-  * Get current cursor position.
 
-  *
 
-  * @param fs Initialized RingFS instance.
 
-  * @returns Current cursor position, -1 on failure.
 
-  */
 
- int ringfs_cursor_position(struct ringfs *fs);
 
- /**
 
-  * Append an object at the end of the ring. Deletes oldest objects as needed.
 
-  *
 
-  * @param fs Initialized RingFS instance.
 
-  * @param object Object to be stored.
 
-  * @returns Zero on success, -1 on failure.
 
-  */
 
- int ringfs_append(struct ringfs *fs, const void *object);
 
- /**
 
-  * Fetch next object from the ring, oldest-first. Advances read cursor.
 
-  *
 
-  * @param fs Initialized RingFS instance.
 
-  * @param object Buffer to store retrieved object.
 
-  * @returns Zero on success, -1 on failure.
 
-  */
 
- int ringfs_fetch(struct ringfs *fs, void *object);
 
- /**
 
-  * Discard all fetched objects up to the read cursor.
 
-  *
 
-  * @param fs Initialized RingFS instance.
 
-  * @returns Zero on success, -1 on failure.
 
-  */
 
- int ringfs_discard(struct ringfs *fs);
 
- /**
 
-  * Rewind the read cursor back to the oldest object.
 
-  *
 
-  * @param fs Initialized RingFS instance.
 
-  * @returns Zero on success, -1 on failure.
 
-  */
 
- int ringfs_rewind(struct ringfs *fs);
 
- /**
 
-  * @}
 
-  */
 
- #endif
 
- /* vim: set ts=4 sw=4 et: */
 
 
  |