xref: /aosp_15_r20/external/mesa3d/src/panfrost/lib/pan_pool.h (revision 6104692788411f58d303aa86923a9ff6ecaded22)
1*61046927SAndroid Build Coastguard Worker /*
2*61046927SAndroid Build Coastguard Worker  * © Copyright 2017-2018 Alyssa Rosenzweig
3*61046927SAndroid Build Coastguard Worker  *
4*61046927SAndroid Build Coastguard Worker  * Permission is hereby granted, free of charge, to any person obtaining a
5*61046927SAndroid Build Coastguard Worker  * copy of this software and associated documentation files (the "Software"),
6*61046927SAndroid Build Coastguard Worker  * to deal in the Software without restriction, including without limitation
7*61046927SAndroid Build Coastguard Worker  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8*61046927SAndroid Build Coastguard Worker  * and/or sell copies of the Software, and to permit persons to whom the
9*61046927SAndroid Build Coastguard Worker  * Software is furnished to do so, subject to the following conditions:
10*61046927SAndroid Build Coastguard Worker  *
11*61046927SAndroid Build Coastguard Worker  * The above copyright notice and this permission notice (including the next
12*61046927SAndroid Build Coastguard Worker  * paragraph) shall be included in all copies or substantial portions of the
13*61046927SAndroid Build Coastguard Worker  * Software.
14*61046927SAndroid Build Coastguard Worker  *
15*61046927SAndroid Build Coastguard Worker  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16*61046927SAndroid Build Coastguard Worker  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17*61046927SAndroid Build Coastguard Worker  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18*61046927SAndroid Build Coastguard Worker  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19*61046927SAndroid Build Coastguard Worker  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20*61046927SAndroid Build Coastguard Worker  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21*61046927SAndroid Build Coastguard Worker  * SOFTWARE.
22*61046927SAndroid Build Coastguard Worker  *
23*61046927SAndroid Build Coastguard Worker  */
24*61046927SAndroid Build Coastguard Worker 
25*61046927SAndroid Build Coastguard Worker #ifndef __PAN_POOL_H__
26*61046927SAndroid Build Coastguard Worker #define __PAN_POOL_H__
27*61046927SAndroid Build Coastguard Worker 
28*61046927SAndroid Build Coastguard Worker #include <stddef.h>
29*61046927SAndroid Build Coastguard Worker #include <genxml/gen_macros.h>
30*61046927SAndroid Build Coastguard Worker 
31*61046927SAndroid Build Coastguard Worker #include "util/u_dynarray.h"
32*61046927SAndroid Build Coastguard Worker 
33*61046927SAndroid Build Coastguard Worker struct panfrost_ptr {
34*61046927SAndroid Build Coastguard Worker    /* CPU address */
35*61046927SAndroid Build Coastguard Worker    void *cpu;
36*61046927SAndroid Build Coastguard Worker 
37*61046927SAndroid Build Coastguard Worker    /* GPU address */
38*61046927SAndroid Build Coastguard Worker    mali_ptr gpu;
39*61046927SAndroid Build Coastguard Worker };
40*61046927SAndroid Build Coastguard Worker 
41*61046927SAndroid Build Coastguard Worker /* Represents grow-only memory. */
42*61046927SAndroid Build Coastguard Worker 
43*61046927SAndroid Build Coastguard Worker struct pan_pool {
44*61046927SAndroid Build Coastguard Worker    /* Minimum size for allocated BOs. */
45*61046927SAndroid Build Coastguard Worker    size_t slab_size;
46*61046927SAndroid Build Coastguard Worker };
47*61046927SAndroid Build Coastguard Worker 
48*61046927SAndroid Build Coastguard Worker static inline void
pan_pool_init(struct pan_pool * pool,size_t slab_size)49*61046927SAndroid Build Coastguard Worker pan_pool_init(struct pan_pool *pool, size_t slab_size)
50*61046927SAndroid Build Coastguard Worker {
51*61046927SAndroid Build Coastguard Worker    pool->slab_size = slab_size;
52*61046927SAndroid Build Coastguard Worker }
53*61046927SAndroid Build Coastguard Worker 
54*61046927SAndroid Build Coastguard Worker /* Represents a fat pointer for GPU-mapped memory, returned from the transient
55*61046927SAndroid Build Coastguard Worker  * allocator and not used for much else */
56*61046927SAndroid Build Coastguard Worker 
57*61046927SAndroid Build Coastguard Worker struct panfrost_ptr pan_pool_alloc_aligned(struct pan_pool *pool, size_t sz,
58*61046927SAndroid Build Coastguard Worker                                            unsigned alignment);
59*61046927SAndroid Build Coastguard Worker 
60*61046927SAndroid Build Coastguard Worker #define PAN_POOL_ALLOCATOR(pool_subclass, alloc_func)                          \
61*61046927SAndroid Build Coastguard Worker    struct panfrost_ptr pan_pool_alloc_aligned(struct pan_pool *p, size_t sz,   \
62*61046927SAndroid Build Coastguard Worker                                               unsigned alignment)              \
63*61046927SAndroid Build Coastguard Worker    {                                                                           \
64*61046927SAndroid Build Coastguard Worker       pool_subclass *pool = container_of(p, pool_subclass, base);              \
65*61046927SAndroid Build Coastguard Worker       return alloc_func(pool, sz, alignment);                                  \
66*61046927SAndroid Build Coastguard Worker    }
67*61046927SAndroid Build Coastguard Worker 
68*61046927SAndroid Build Coastguard Worker static inline mali_ptr
pan_pool_upload_aligned(struct pan_pool * pool,const void * data,size_t sz,unsigned alignment)69*61046927SAndroid Build Coastguard Worker pan_pool_upload_aligned(struct pan_pool *pool, const void *data, size_t sz,
70*61046927SAndroid Build Coastguard Worker                         unsigned alignment)
71*61046927SAndroid Build Coastguard Worker {
72*61046927SAndroid Build Coastguard Worker    struct panfrost_ptr transfer = pan_pool_alloc_aligned(pool, sz, alignment);
73*61046927SAndroid Build Coastguard Worker    memcpy(transfer.cpu, data, sz);
74*61046927SAndroid Build Coastguard Worker    return transfer.gpu;
75*61046927SAndroid Build Coastguard Worker }
76*61046927SAndroid Build Coastguard Worker 
77*61046927SAndroid Build Coastguard Worker static inline mali_ptr
pan_pool_upload(struct pan_pool * pool,const void * data,size_t sz)78*61046927SAndroid Build Coastguard Worker pan_pool_upload(struct pan_pool *pool, const void *data, size_t sz)
79*61046927SAndroid Build Coastguard Worker {
80*61046927SAndroid Build Coastguard Worker    return pan_pool_upload_aligned(pool, data, sz, sz);
81*61046927SAndroid Build Coastguard Worker }
82*61046927SAndroid Build Coastguard Worker 
83*61046927SAndroid Build Coastguard Worker struct pan_desc_alloc_info {
84*61046927SAndroid Build Coastguard Worker    unsigned size;
85*61046927SAndroid Build Coastguard Worker    unsigned align;
86*61046927SAndroid Build Coastguard Worker    unsigned nelems;
87*61046927SAndroid Build Coastguard Worker };
88*61046927SAndroid Build Coastguard Worker 
89*61046927SAndroid Build Coastguard Worker #define PAN_DESC_ARRAY(count, name)                                            \
90*61046927SAndroid Build Coastguard Worker    {                                                                           \
91*61046927SAndroid Build Coastguard Worker       .size = pan_size(name), .align = pan_alignment(name), .nelems = count,   \
92*61046927SAndroid Build Coastguard Worker    }
93*61046927SAndroid Build Coastguard Worker 
94*61046927SAndroid Build Coastguard Worker #define PAN_DESC(name) PAN_DESC_ARRAY(1, name)
95*61046927SAndroid Build Coastguard Worker 
96*61046927SAndroid Build Coastguard Worker #define PAN_DESC_AGGREGATE(...)                                                \
97*61046927SAndroid Build Coastguard Worker    (struct pan_desc_alloc_info[])                                              \
98*61046927SAndroid Build Coastguard Worker    {                                                                           \
99*61046927SAndroid Build Coastguard Worker       __VA_ARGS__, {0},                                                        \
100*61046927SAndroid Build Coastguard Worker    }
101*61046927SAndroid Build Coastguard Worker 
102*61046927SAndroid Build Coastguard Worker static inline struct panfrost_ptr
pan_pool_alloc_descs(struct pan_pool * pool,const struct pan_desc_alloc_info * descs)103*61046927SAndroid Build Coastguard Worker pan_pool_alloc_descs(struct pan_pool *pool,
104*61046927SAndroid Build Coastguard Worker                      const struct pan_desc_alloc_info *descs)
105*61046927SAndroid Build Coastguard Worker {
106*61046927SAndroid Build Coastguard Worker    unsigned size = 0;
107*61046927SAndroid Build Coastguard Worker    unsigned align = descs[0].align;
108*61046927SAndroid Build Coastguard Worker 
109*61046927SAndroid Build Coastguard Worker    for (unsigned i = 0; descs[i].size; i++) {
110*61046927SAndroid Build Coastguard Worker       assert(!(size & (descs[i].align - 1)));
111*61046927SAndroid Build Coastguard Worker       size += descs[i].size * descs[i].nelems;
112*61046927SAndroid Build Coastguard Worker    }
113*61046927SAndroid Build Coastguard Worker 
114*61046927SAndroid Build Coastguard Worker    return pan_pool_alloc_aligned(pool, size, align);
115*61046927SAndroid Build Coastguard Worker }
116*61046927SAndroid Build Coastguard Worker 
117*61046927SAndroid Build Coastguard Worker #define pan_pool_alloc_desc(pool, name)                                        \
118*61046927SAndroid Build Coastguard Worker    pan_pool_alloc_descs(pool, PAN_DESC_AGGREGATE(PAN_DESC(name)))
119*61046927SAndroid Build Coastguard Worker 
120*61046927SAndroid Build Coastguard Worker #define pan_pool_alloc_desc_array(pool, count, name)                           \
121*61046927SAndroid Build Coastguard Worker    pan_pool_alloc_descs(pool, PAN_DESC_AGGREGATE(PAN_DESC_ARRAY(count, name)))
122*61046927SAndroid Build Coastguard Worker 
123*61046927SAndroid Build Coastguard Worker #define pan_pool_alloc_desc_aggregate(pool, ...)                               \
124*61046927SAndroid Build Coastguard Worker    pan_pool_alloc_descs(pool, PAN_DESC_AGGREGATE(__VA_ARGS__))
125*61046927SAndroid Build Coastguard Worker 
126*61046927SAndroid Build Coastguard Worker #endif
127