106a99fe3SHajimu UMEMOTO /*- 206a99fe3SHajimu UMEMOTO * Copyright (c) 2005 Michael Bushkov <bushman@rsu.ru> 306a99fe3SHajimu UMEMOTO * All rights reserved. 406a99fe3SHajimu UMEMOTO * 506a99fe3SHajimu UMEMOTO * Redistribution and use in source and binary forms, with or without 606a99fe3SHajimu UMEMOTO * modification, are permitted provided that the following conditions 706a99fe3SHajimu UMEMOTO * are met: 806a99fe3SHajimu UMEMOTO * 1. Redistributions of source code must retain the above copyright 906a99fe3SHajimu UMEMOTO * notice, this list of conditions and the following disclaimer. 1006a99fe3SHajimu UMEMOTO * 2. Redistributions in binary form must reproduce the above copyright 1106a99fe3SHajimu UMEMOTO * notice, this list of conditions and the following disclaimer in the 1206a99fe3SHajimu UMEMOTO * documentation and/or other materials provided with the distribution. 1306a99fe3SHajimu UMEMOTO * 1406a99fe3SHajimu UMEMOTO * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 1506a99fe3SHajimu UMEMOTO * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 1606a99fe3SHajimu UMEMOTO * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 1706a99fe3SHajimu UMEMOTO * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 1806a99fe3SHajimu UMEMOTO * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 1906a99fe3SHajimu UMEMOTO * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 2006a99fe3SHajimu UMEMOTO * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 2106a99fe3SHajimu UMEMOTO * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 2206a99fe3SHajimu UMEMOTO * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 2306a99fe3SHajimu UMEMOTO * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 2406a99fe3SHajimu UMEMOTO * SUCH DAMAGE. 2506a99fe3SHajimu UMEMOTO */ 2606a99fe3SHajimu UMEMOTO 27db1bdf2bSMichael Bushkov #ifndef __NSCD_CACHEPLCS_H__ 28db1bdf2bSMichael Bushkov #define __NSCD_CACHEPLCS_H__ 2906a99fe3SHajimu UMEMOTO 3006a99fe3SHajimu UMEMOTO #include <sys/queue.h> 3106a99fe3SHajimu UMEMOTO 3206a99fe3SHajimu UMEMOTO /* common policy definitions */ 3306a99fe3SHajimu UMEMOTO #define CACHELIB_MAX_FREQUENCY 100 3406a99fe3SHajimu UMEMOTO 3506a99fe3SHajimu UMEMOTO /* 3606a99fe3SHajimu UMEMOTO * cache_policy_item_ represents some abstract cache element in the policy 3706a99fe3SHajimu UMEMOTO * queue. connected_item pointers to the corresponding cache_policy_item_ in 3806a99fe3SHajimu UMEMOTO * another policy queue. 3906a99fe3SHajimu UMEMOTO */ 40d2432adbSDag-Erling Smørgrav struct cache_policy_item_ { 4106a99fe3SHajimu UMEMOTO char *key; 4206a99fe3SHajimu UMEMOTO size_t key_size; 4306a99fe3SHajimu UMEMOTO 4406a99fe3SHajimu UMEMOTO size_t request_count; 4506a99fe3SHajimu UMEMOTO struct timeval last_request_time; 4606a99fe3SHajimu UMEMOTO struct timeval creation_time; 4706a99fe3SHajimu UMEMOTO 4806a99fe3SHajimu UMEMOTO struct cache_policy_item_ *connected_item; 4906a99fe3SHajimu UMEMOTO }; 5006a99fe3SHajimu UMEMOTO 5106a99fe3SHajimu UMEMOTO /* 5206a99fe3SHajimu UMEMOTO * cache_policy_ represents an abstract policy queue. It can be customized by 5306a99fe3SHajimu UMEMOTO * setting appropriate function pointers 5406a99fe3SHajimu UMEMOTO */ 55d2432adbSDag-Erling Smørgrav struct cache_policy_ { 5634ecf97aSDag-Erling Smørgrav struct cache_policy_item_* (*create_item_func)(void); 5706a99fe3SHajimu UMEMOTO void (*destroy_item_func)(struct cache_policy_item_ *); 5806a99fe3SHajimu UMEMOTO 5906a99fe3SHajimu UMEMOTO void (*add_item_func)(struct cache_policy_ *, 6006a99fe3SHajimu UMEMOTO struct cache_policy_item_ *); 6106a99fe3SHajimu UMEMOTO void (*remove_item_func)(struct cache_policy_ *, 6206a99fe3SHajimu UMEMOTO struct cache_policy_item_ *); 6306a99fe3SHajimu UMEMOTO void (*update_item_func)(struct cache_policy_ *, 6406a99fe3SHajimu UMEMOTO struct cache_policy_item_ *); 6506a99fe3SHajimu UMEMOTO 6606a99fe3SHajimu UMEMOTO struct cache_policy_item_ *(*get_first_item_func)( 6706a99fe3SHajimu UMEMOTO struct cache_policy_ *); 6806a99fe3SHajimu UMEMOTO struct cache_policy_item_ *(*get_last_item_func)( 6906a99fe3SHajimu UMEMOTO struct cache_policy_ *); 7006a99fe3SHajimu UMEMOTO struct cache_policy_item_ *(*get_next_item_func)( 7106a99fe3SHajimu UMEMOTO struct cache_policy_ *, struct cache_policy_item_ *); 7206a99fe3SHajimu UMEMOTO struct cache_policy_item_ *(*get_prev_item_func)( 7306a99fe3SHajimu UMEMOTO struct cache_policy_ *, struct cache_policy_item_ *); 7406a99fe3SHajimu UMEMOTO }; 7506a99fe3SHajimu UMEMOTO 7606a99fe3SHajimu UMEMOTO /* 7706a99fe3SHajimu UMEMOTO * LFU cache policy item "inherited" from cache_policy_item_ structure 7806a99fe3SHajimu UMEMOTO */ 79d2432adbSDag-Erling Smørgrav struct cache_lfu_policy_item_ { 8006a99fe3SHajimu UMEMOTO struct cache_policy_item_ parent_data; 8106a99fe3SHajimu UMEMOTO int frequency; 8206a99fe3SHajimu UMEMOTO 8306a99fe3SHajimu UMEMOTO TAILQ_ENTRY(cache_lfu_policy_item_) entries; 8406a99fe3SHajimu UMEMOTO }; 8506a99fe3SHajimu UMEMOTO 8606a99fe3SHajimu UMEMOTO TAILQ_HEAD(cache_lfu_policy_group_, cache_lfu_policy_item_); 8706a99fe3SHajimu UMEMOTO 8806a99fe3SHajimu UMEMOTO /* 8906a99fe3SHajimu UMEMOTO * LFU policy queue "inherited" from cache_policy_. 9006a99fe3SHajimu UMEMOTO */ 91d2432adbSDag-Erling Smørgrav struct cache_lfu_policy_ { 9206a99fe3SHajimu UMEMOTO struct cache_policy_ parent_data; 9306a99fe3SHajimu UMEMOTO struct cache_lfu_policy_group_ groups[CACHELIB_MAX_FREQUENCY]; 9406a99fe3SHajimu UMEMOTO }; 9506a99fe3SHajimu UMEMOTO 9606a99fe3SHajimu UMEMOTO /* 9706a99fe3SHajimu UMEMOTO * LRU and FIFO policies item "inherited" from cache_policy_item_ 9806a99fe3SHajimu UMEMOTO */ 99d2432adbSDag-Erling Smørgrav struct cache_queue_policy_item_ { 10006a99fe3SHajimu UMEMOTO struct cache_policy_item_ parent_data; 10106a99fe3SHajimu UMEMOTO TAILQ_ENTRY(cache_queue_policy_item_) entries; 10206a99fe3SHajimu UMEMOTO }; 10306a99fe3SHajimu UMEMOTO 10406a99fe3SHajimu UMEMOTO /* 10506a99fe3SHajimu UMEMOTO * LRU and FIFO policies "inherited" from cache_policy_ 10606a99fe3SHajimu UMEMOTO */ 107d2432adbSDag-Erling Smørgrav struct cache_queue_policy_ { 10806a99fe3SHajimu UMEMOTO struct cache_policy_ parent_data; 10906a99fe3SHajimu UMEMOTO TAILQ_HEAD(cache_queue_policy_head_, cache_queue_policy_item_) head; 11006a99fe3SHajimu UMEMOTO }; 11106a99fe3SHajimu UMEMOTO 11206a99fe3SHajimu UMEMOTO typedef struct cache_queue_policy_ cache_fifo_policy_; 11306a99fe3SHajimu UMEMOTO typedef struct cache_queue_policy_ cache_lru_policy_; 11406a99fe3SHajimu UMEMOTO 11506a99fe3SHajimu UMEMOTO /* fifo policy routines */ 116d2432adbSDag-Erling Smørgrav struct cache_policy_ *init_cache_fifo_policy(void); 117d2432adbSDag-Erling Smørgrav void destroy_cache_fifo_policy(struct cache_policy_ *); 11806a99fe3SHajimu UMEMOTO 11906a99fe3SHajimu UMEMOTO /* lru policy routines */ 120d2432adbSDag-Erling Smørgrav struct cache_policy_ *init_cache_lru_policy(void); 121d2432adbSDag-Erling Smørgrav void destroy_cache_lru_policy(struct cache_policy_ *); 12206a99fe3SHajimu UMEMOTO 12306a99fe3SHajimu UMEMOTO /* lfu policy routines */ 124d2432adbSDag-Erling Smørgrav struct cache_policy_ *init_cache_lfu_policy(void); 125d2432adbSDag-Erling Smørgrav void destroy_cache_lfu_policy(struct cache_policy_ *); 12606a99fe3SHajimu UMEMOTO 12706a99fe3SHajimu UMEMOTO #endif 128