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