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