1bf215546Sopenharmony_ci/************************************************************************** 2bf215546Sopenharmony_ci * 3bf215546Sopenharmony_ci * Copyright 2007-2008 VMware, Inc. 4bf215546Sopenharmony_ci * Copyright 2015 Advanced Micro Devices, Inc. 5bf215546Sopenharmony_ci * All Rights Reserved. 6bf215546Sopenharmony_ci * 7bf215546Sopenharmony_ci * Permission is hereby granted, free of charge, to any person obtaining a 8bf215546Sopenharmony_ci * copy of this software and associated documentation files (the 9bf215546Sopenharmony_ci * "Software"), to deal in the Software without restriction, including 10bf215546Sopenharmony_ci * without limitation the rights to use, copy, modify, merge, publish, 11bf215546Sopenharmony_ci * distribute, sub license, and/or sell copies of the Software, and to 12bf215546Sopenharmony_ci * permit persons to whom the Software is furnished to do so, subject to 13bf215546Sopenharmony_ci * the following conditions: 14bf215546Sopenharmony_ci * 15bf215546Sopenharmony_ci * The above copyright notice and this permission notice (including the 16bf215546Sopenharmony_ci * next paragraph) shall be included in all copies or substantial portions 17bf215546Sopenharmony_ci * of the Software. 18bf215546Sopenharmony_ci * 19bf215546Sopenharmony_ci * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS 20bf215546Sopenharmony_ci * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 21bf215546Sopenharmony_ci * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. 22bf215546Sopenharmony_ci * IN NO EVENT SHALL AUTHORS AND/OR ITS SUPPLIERS BE LIABLE FOR 23bf215546Sopenharmony_ci * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 24bf215546Sopenharmony_ci * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 25bf215546Sopenharmony_ci * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 26bf215546Sopenharmony_ci * 27bf215546Sopenharmony_ci **************************************************************************/ 28bf215546Sopenharmony_ci 29bf215546Sopenharmony_ci#ifndef PB_CACHE_H 30bf215546Sopenharmony_ci#define PB_CACHE_H 31bf215546Sopenharmony_ci 32bf215546Sopenharmony_ci#include "pb_buffer.h" 33bf215546Sopenharmony_ci#include "util/simple_mtx.h" 34bf215546Sopenharmony_ci#include "util/list.h" 35bf215546Sopenharmony_ci#include "os/os_thread.h" 36bf215546Sopenharmony_ci 37bf215546Sopenharmony_ci/** 38bf215546Sopenharmony_ci * Statically inserted into the driver-specific buffer structure. 39bf215546Sopenharmony_ci */ 40bf215546Sopenharmony_cistruct pb_cache_entry 41bf215546Sopenharmony_ci{ 42bf215546Sopenharmony_ci struct list_head head; 43bf215546Sopenharmony_ci struct pb_buffer *buffer; /**< Pointer to the structure this is part of. */ 44bf215546Sopenharmony_ci struct pb_cache *mgr; 45bf215546Sopenharmony_ci int64_t start, end; /**< Caching time interval */ 46bf215546Sopenharmony_ci unsigned bucket_index; 47bf215546Sopenharmony_ci}; 48bf215546Sopenharmony_ci 49bf215546Sopenharmony_cistruct pb_cache 50bf215546Sopenharmony_ci{ 51bf215546Sopenharmony_ci /* The cache is divided into buckets for minimizing cache misses. 52bf215546Sopenharmony_ci * The driver controls which buffer goes into which bucket. 53bf215546Sopenharmony_ci */ 54bf215546Sopenharmony_ci struct list_head *buckets; 55bf215546Sopenharmony_ci 56bf215546Sopenharmony_ci simple_mtx_t mutex; 57bf215546Sopenharmony_ci void *winsys; 58bf215546Sopenharmony_ci uint64_t cache_size; 59bf215546Sopenharmony_ci uint64_t max_cache_size; 60bf215546Sopenharmony_ci unsigned num_heaps; 61bf215546Sopenharmony_ci unsigned usecs; 62bf215546Sopenharmony_ci unsigned num_buffers; 63bf215546Sopenharmony_ci unsigned bypass_usage; 64bf215546Sopenharmony_ci float size_factor; 65bf215546Sopenharmony_ci 66bf215546Sopenharmony_ci void (*destroy_buffer)(void *winsys, struct pb_buffer *buf); 67bf215546Sopenharmony_ci bool (*can_reclaim)(void *winsys, struct pb_buffer *buf); 68bf215546Sopenharmony_ci}; 69bf215546Sopenharmony_ci 70bf215546Sopenharmony_civoid pb_cache_add_buffer(struct pb_cache_entry *entry); 71bf215546Sopenharmony_cistruct pb_buffer *pb_cache_reclaim_buffer(struct pb_cache *mgr, pb_size size, 72bf215546Sopenharmony_ci unsigned alignment, unsigned usage, 73bf215546Sopenharmony_ci unsigned bucket_index); 74bf215546Sopenharmony_civoid pb_cache_release_all_buffers(struct pb_cache *mgr); 75bf215546Sopenharmony_civoid pb_cache_init_entry(struct pb_cache *mgr, struct pb_cache_entry *entry, 76bf215546Sopenharmony_ci struct pb_buffer *buf, unsigned bucket_index); 77bf215546Sopenharmony_civoid pb_cache_init(struct pb_cache *mgr, uint num_heaps, 78bf215546Sopenharmony_ci uint usecs, float size_factor, 79bf215546Sopenharmony_ci unsigned bypass_usage, uint64_t maximum_cache_size, 80bf215546Sopenharmony_ci void *winsys, 81bf215546Sopenharmony_ci void (*destroy_buffer)(void *winsys, struct pb_buffer *buf), 82bf215546Sopenharmony_ci bool (*can_reclaim)(void *winsys, struct pb_buffer *buf)); 83bf215546Sopenharmony_civoid pb_cache_deinit(struct pb_cache *mgr); 84bf215546Sopenharmony_ci 85bf215546Sopenharmony_ci#endif 86