#cache #rom #ram #cpu #memory #data #store

rom_cache

Cache ROM in RAM like CPU caches RAM

13 releases

0.0.11 Aug 31, 2024
0.0.10 Aug 6, 2024
0.0.4 Jul 31, 2024

#88 in Caching

Download history 202/week @ 2024-07-21 820/week @ 2024-07-28 158/week @ 2024-08-04 46/week @ 2024-08-11 5/week @ 2024-08-18 166/week @ 2024-08-25 40/week @ 2024-09-01

261 downloads per month
Used in 2 crates (via encrypt_config)

MIT license

24KB
358 lines

Contributors Forks Stargazers Issues MIT License


rom-cache

A rust crate to cache ROM in RAM like CPU caches RAM.
Explore the docs »

View Demo · Report Bug · Request Feature

Table of Contents
  1. Import
  2. About The Project
  3. Usage
  4. Changelog
  5. Roadmap
  6. Contributing
  7. License
  8. Contact
  9. Acknowledgments

Import

[dependencies]
rom_cache = { version = "0.0.10" }

About The Project

A rust crate to cache ROM in memory like CPU caching RAM.

Trait Cacheable is provided to enable user define how to load and store data in Secondary Storage.

Cache is the main entry of this crate, which consists of CacheGroups. And CacheGroup consists of CacheLines.

Cache::get::<T>() and Cache::get_mut::<T>() are provided to retrieve data from Cache and storage. LRU is used to choose the CacheLine for T.

  1. get
  • cache hit: return CacheRef
  • cache busy: CacheError::Busy, LRU-chosen CacheLine is still being writting or reading so that unable to be evicted.
  • cache locked: CacheError::Locked, cannot read T while writing.
  1. get_mut
  • cache hit: return CacheMut, and dereferencing CacheMut will set CacheLine dirty.
  • cache busy: CacheError::Busy, cannot evict LRU-chosen CacheLine which is still being used.
  • cache locked: CacheError::Locked, cannot write T while reading or writing.

Any dirty CacheLine will be written back (Cacheable::store()) to Secondary Storage when evicted or Cache dropped.

Features

  • nightly: enable #![feature(trait_upcasting)] to simplify the Cacheable trait. (Nightly Rust is needed)

(back to top)

Built With

  • Rust
  • Miri (Testing)
  • Loom (Concurrency Testing)

(back to top)

Usage

Example

# use rom_cache::Cache;
// e.g 2-way set associative cache (8 sets/groups)
let cache: Cache<8, 2> = Default::default();
cache.get::<isize>().unwrap();
cache.get::<String>().unwrap();
{
    let mut s = cache.get_mut::<String>().unwrap();
    cache.get::<u64>().unwrap();
    cache.get::<usize>().unwrap();
    *s = "".to_string();    // set dirty
}
{
    let s = cache.get::<String>().unwrap(); // other threads may evict `String` and it's stored,
                                            // this will load it back
    assert_eq!(*s, "");                     // The `load` result is `""`
}

For more examples, please refer to the Tests, Example or Documentation

(back to top)

Changelog

todo

more detailed changelog

(back to top)

Roadmap

  • allow concurrent access
  • auto load when getting
  • benchmark

Contributing

Contributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated.

If you have a suggestion that would make this better, please fork the repo and create a pull request. You can also simply open an issue with the tag "enhancement". Don't forget to give the project a star! Thanks again!

  1. Fork the Project
  2. Create your Feature Branch (git checkout -b feature/AmazingFeature)
  3. Commit your Changes (git commit -m 'Add some AmazingFeature')
  4. Push to the Branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

(back to top)

License

Distributed under the MIT License. See LICENSE.txt for more information.

(back to top)

Contact

Louis - 836250617@qq.com

Project Link: https://github.com/kingwingfly/rom-cache

(back to top)

Dependencies

~0.3–25MB
~350K SLoC