/* * cache.h : deal with indexed LRU caches * * Copyright (c) 2008-2009 Jean-Pierre Andre * * This program/include file is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License as published * by the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program/include file is distributed in the hope that it will be * useful, but WITHOUT ANY WARRANTY; without even the implied warranty * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program (in the main directory of the NTFS-3G * distribution in the file COPYING); if not, write to the Free Software * Foundation,Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #ifndef _NTFS_CACHE_H_ #define _NTFS_CACHE_H_ #include "volume.h" struct CACHED_GENERIC { struct CACHED_GENERIC *next; struct CACHED_GENERIC *previous; void *variable; size_t varsize; union { /* force alignment for pointers and u64 */ u64 u64align; void *ptralign; } fixed[0]; } ; struct CACHED_INODE { struct CACHED_INODE *next; struct CACHED_INODE *previous; const char *pathname; size_t varsize; /* above fields must match "struct CACHED_GENERIC" */ u64 inum; } ; struct CACHED_NIDATA { struct CACHED_NIDATA *next; struct CACHED_NIDATA *previous; const char *pathname; /* not used */ size_t varsize; /* not used */ /* above fields must match "struct CACHED_GENERIC" */ u64 inum; ntfs_inode *ni; } ; struct CACHED_LOOKUP { struct CACHED_LOOKUP *next; struct CACHED_LOOKUP *previous; const char *name; size_t namesize; /* above fields must match "struct CACHED_GENERIC" */ u64 parent; u64 inum; } ; enum { CACHE_FREE = 1, CACHE_NOHASH = 2 } ; typedef int ( *cache_compare )( const struct CACHED_GENERIC *cached, const struct CACHED_GENERIC *item ); typedef void ( *cache_free )( const struct CACHED_GENERIC *cached ); typedef int ( *cache_hash )( const struct CACHED_GENERIC *cached ); struct HASH_ENTRY { struct HASH_ENTRY *next; struct CACHED_GENERIC *entry; } ; struct CACHE_HEADER { const char *name; struct CACHED_GENERIC *most_recent_entry; struct CACHED_GENERIC *oldest_entry; struct CACHED_GENERIC *free_entry; struct HASH_ENTRY *free_hash; struct HASH_ENTRY **first_hash; cache_free dofree; cache_hash dohash; unsigned long reads; unsigned long writes; unsigned long hits; int fixed_size; int max_hash; struct CACHED_GENERIC entry[0]; } ; /* cast to generic, avoiding gcc warnings */ #define GENERIC(pstr) ((const struct CACHED_GENERIC*)(const void*)(pstr)) struct CACHED_GENERIC *ntfs_fetch_cache( struct CACHE_HEADER *cache, const struct CACHED_GENERIC *wanted, cache_compare compare ); struct CACHED_GENERIC *ntfs_enter_cache( struct CACHE_HEADER *cache, const struct CACHED_GENERIC *item, cache_compare compare ); int ntfs_invalidate_cache( struct CACHE_HEADER *cache, const struct CACHED_GENERIC *item, cache_compare compare, int flags ); int ntfs_remove_cache( struct CACHE_HEADER *cache, struct CACHED_GENERIC *item, int flags ); void ntfs_create_lru_caches( ntfs_volume *vol ); void ntfs_free_lru_caches( ntfs_volume *vol ); #endif /* _NTFS_CACHE_H_ */