xref: /aosp_15_r20/external/angle/src/libANGLE/IndexRangeCache.cpp (revision 8975f5c5ed3d1c378011245431ada316dfb6f244)
1*8975f5c5SAndroid Build Coastguard Worker //
2*8975f5c5SAndroid Build Coastguard Worker // Copyright 2013 The ANGLE Project Authors. All rights reserved.
3*8975f5c5SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
4*8975f5c5SAndroid Build Coastguard Worker // found in the LICENSE file.
5*8975f5c5SAndroid Build Coastguard Worker //
6*8975f5c5SAndroid Build Coastguard Worker 
7*8975f5c5SAndroid Build Coastguard Worker // IndexRangeCache.cpp: Defines the gl::IndexRangeCache class which stores information about
8*8975f5c5SAndroid Build Coastguard Worker // ranges of indices.
9*8975f5c5SAndroid Build Coastguard Worker 
10*8975f5c5SAndroid Build Coastguard Worker #include "libANGLE/IndexRangeCache.h"
11*8975f5c5SAndroid Build Coastguard Worker 
12*8975f5c5SAndroid Build Coastguard Worker #include "common/debug.h"
13*8975f5c5SAndroid Build Coastguard Worker #include "libANGLE/formatutils.h"
14*8975f5c5SAndroid Build Coastguard Worker 
15*8975f5c5SAndroid Build Coastguard Worker namespace gl
16*8975f5c5SAndroid Build Coastguard Worker {
17*8975f5c5SAndroid Build Coastguard Worker 
IndexRangeCache()18*8975f5c5SAndroid Build Coastguard Worker IndexRangeCache::IndexRangeCache() {}
19*8975f5c5SAndroid Build Coastguard Worker 
~IndexRangeCache()20*8975f5c5SAndroid Build Coastguard Worker IndexRangeCache::~IndexRangeCache() {}
21*8975f5c5SAndroid Build Coastguard Worker 
addRange(DrawElementsType type,size_t offset,size_t count,bool primitiveRestartEnabled,const IndexRange & range)22*8975f5c5SAndroid Build Coastguard Worker void IndexRangeCache::addRange(DrawElementsType type,
23*8975f5c5SAndroid Build Coastguard Worker                                size_t offset,
24*8975f5c5SAndroid Build Coastguard Worker                                size_t count,
25*8975f5c5SAndroid Build Coastguard Worker                                bool primitiveRestartEnabled,
26*8975f5c5SAndroid Build Coastguard Worker                                const IndexRange &range)
27*8975f5c5SAndroid Build Coastguard Worker {
28*8975f5c5SAndroid Build Coastguard Worker     mIndexRangeCache[IndexRangeKey(type, offset, count, primitiveRestartEnabled)] = range;
29*8975f5c5SAndroid Build Coastguard Worker }
30*8975f5c5SAndroid Build Coastguard Worker 
findRange(DrawElementsType type,size_t offset,size_t count,bool primitiveRestartEnabled,IndexRange * outRange) const31*8975f5c5SAndroid Build Coastguard Worker bool IndexRangeCache::findRange(DrawElementsType type,
32*8975f5c5SAndroid Build Coastguard Worker                                 size_t offset,
33*8975f5c5SAndroid Build Coastguard Worker                                 size_t count,
34*8975f5c5SAndroid Build Coastguard Worker                                 bool primitiveRestartEnabled,
35*8975f5c5SAndroid Build Coastguard Worker                                 IndexRange *outRange) const
36*8975f5c5SAndroid Build Coastguard Worker {
37*8975f5c5SAndroid Build Coastguard Worker     auto i = mIndexRangeCache.find(IndexRangeKey(type, offset, count, primitiveRestartEnabled));
38*8975f5c5SAndroid Build Coastguard Worker     if (i != mIndexRangeCache.end())
39*8975f5c5SAndroid Build Coastguard Worker     {
40*8975f5c5SAndroid Build Coastguard Worker         if (outRange)
41*8975f5c5SAndroid Build Coastguard Worker         {
42*8975f5c5SAndroid Build Coastguard Worker             *outRange = i->second;
43*8975f5c5SAndroid Build Coastguard Worker         }
44*8975f5c5SAndroid Build Coastguard Worker         return true;
45*8975f5c5SAndroid Build Coastguard Worker     }
46*8975f5c5SAndroid Build Coastguard Worker     else
47*8975f5c5SAndroid Build Coastguard Worker     {
48*8975f5c5SAndroid Build Coastguard Worker         if (outRange)
49*8975f5c5SAndroid Build Coastguard Worker         {
50*8975f5c5SAndroid Build Coastguard Worker             *outRange = IndexRange();
51*8975f5c5SAndroid Build Coastguard Worker         }
52*8975f5c5SAndroid Build Coastguard Worker         return false;
53*8975f5c5SAndroid Build Coastguard Worker     }
54*8975f5c5SAndroid Build Coastguard Worker }
55*8975f5c5SAndroid Build Coastguard Worker 
invalidateRange(size_t offset,size_t size)56*8975f5c5SAndroid Build Coastguard Worker void IndexRangeCache::invalidateRange(size_t offset, size_t size)
57*8975f5c5SAndroid Build Coastguard Worker {
58*8975f5c5SAndroid Build Coastguard Worker     size_t invalidateStart = offset;
59*8975f5c5SAndroid Build Coastguard Worker     size_t invalidateEnd   = offset + size;
60*8975f5c5SAndroid Build Coastguard Worker 
61*8975f5c5SAndroid Build Coastguard Worker     auto i = mIndexRangeCache.begin();
62*8975f5c5SAndroid Build Coastguard Worker     while (i != mIndexRangeCache.end())
63*8975f5c5SAndroid Build Coastguard Worker     {
64*8975f5c5SAndroid Build Coastguard Worker         size_t rangeStart = i->first.offset;
65*8975f5c5SAndroid Build Coastguard Worker         size_t rangeEnd =
66*8975f5c5SAndroid Build Coastguard Worker             i->first.offset + (GetDrawElementsTypeSize(i->first.type) * i->first.count);
67*8975f5c5SAndroid Build Coastguard Worker 
68*8975f5c5SAndroid Build Coastguard Worker         if (invalidateEnd < rangeStart || invalidateStart > rangeEnd)
69*8975f5c5SAndroid Build Coastguard Worker         {
70*8975f5c5SAndroid Build Coastguard Worker             ++i;
71*8975f5c5SAndroid Build Coastguard Worker         }
72*8975f5c5SAndroid Build Coastguard Worker         else
73*8975f5c5SAndroid Build Coastguard Worker         {
74*8975f5c5SAndroid Build Coastguard Worker             mIndexRangeCache.erase(i++);
75*8975f5c5SAndroid Build Coastguard Worker         }
76*8975f5c5SAndroid Build Coastguard Worker     }
77*8975f5c5SAndroid Build Coastguard Worker }
78*8975f5c5SAndroid Build Coastguard Worker 
clear()79*8975f5c5SAndroid Build Coastguard Worker void IndexRangeCache::clear()
80*8975f5c5SAndroid Build Coastguard Worker {
81*8975f5c5SAndroid Build Coastguard Worker     mIndexRangeCache.clear();
82*8975f5c5SAndroid Build Coastguard Worker }
83*8975f5c5SAndroid Build Coastguard Worker 
IndexRangeKey()84*8975f5c5SAndroid Build Coastguard Worker IndexRangeCache::IndexRangeKey::IndexRangeKey()
85*8975f5c5SAndroid Build Coastguard Worker     : IndexRangeCache::IndexRangeKey(DrawElementsType::InvalidEnum, 0, 0, false)
86*8975f5c5SAndroid Build Coastguard Worker {}
87*8975f5c5SAndroid Build Coastguard Worker 
IndexRangeKey(DrawElementsType type_,size_t offset_,size_t count_,bool primitiveRestartEnabled_)88*8975f5c5SAndroid Build Coastguard Worker IndexRangeCache::IndexRangeKey::IndexRangeKey(DrawElementsType type_,
89*8975f5c5SAndroid Build Coastguard Worker                                               size_t offset_,
90*8975f5c5SAndroid Build Coastguard Worker                                               size_t count_,
91*8975f5c5SAndroid Build Coastguard Worker                                               bool primitiveRestartEnabled_)
92*8975f5c5SAndroid Build Coastguard Worker     : type(type_), offset(offset_), count(count_), primitiveRestartEnabled(primitiveRestartEnabled_)
93*8975f5c5SAndroid Build Coastguard Worker {}
94*8975f5c5SAndroid Build Coastguard Worker 
operator <(const IndexRangeKey & rhs) const95*8975f5c5SAndroid Build Coastguard Worker bool IndexRangeCache::IndexRangeKey::operator<(const IndexRangeKey &rhs) const
96*8975f5c5SAndroid Build Coastguard Worker {
97*8975f5c5SAndroid Build Coastguard Worker     if (type != rhs.type)
98*8975f5c5SAndroid Build Coastguard Worker     {
99*8975f5c5SAndroid Build Coastguard Worker         return type < rhs.type;
100*8975f5c5SAndroid Build Coastguard Worker     }
101*8975f5c5SAndroid Build Coastguard Worker     if (offset != rhs.offset)
102*8975f5c5SAndroid Build Coastguard Worker     {
103*8975f5c5SAndroid Build Coastguard Worker         return offset < rhs.offset;
104*8975f5c5SAndroid Build Coastguard Worker     }
105*8975f5c5SAndroid Build Coastguard Worker     if (count != rhs.count)
106*8975f5c5SAndroid Build Coastguard Worker     {
107*8975f5c5SAndroid Build Coastguard Worker         return count < rhs.count;
108*8975f5c5SAndroid Build Coastguard Worker     }
109*8975f5c5SAndroid Build Coastguard Worker     if (primitiveRestartEnabled != rhs.primitiveRestartEnabled)
110*8975f5c5SAndroid Build Coastguard Worker     {
111*8975f5c5SAndroid Build Coastguard Worker         return primitiveRestartEnabled;
112*8975f5c5SAndroid Build Coastguard Worker     }
113*8975f5c5SAndroid Build Coastguard Worker     return false;
114*8975f5c5SAndroid Build Coastguard Worker }
115*8975f5c5SAndroid Build Coastguard Worker 
116*8975f5c5SAndroid Build Coastguard Worker }  // namespace gl
117