OLD | NEW |
1 // Copyright (c) 2014 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2014 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
| 5 #include "gpu/command_buffer/service/gl_utils.h" |
| 6 #include "gpu/command_buffer/service/program_manager.h" |
5 #include "gpu/command_buffer/service/valuebuffer_manager.h" | 7 #include "gpu/command_buffer/service/valuebuffer_manager.h" |
6 | 8 |
7 #include "gpu/command_buffer/service/program_manager.h" | |
8 | |
9 namespace gpu { | 9 namespace gpu { |
10 namespace gles2 { | 10 namespace gles2 { |
11 | 11 |
12 Valuebuffer::Valuebuffer(ValuebufferManager* manager, GLuint client_id) | 12 Valuebuffer::Valuebuffer(ValuebufferManager* manager, unsigned int client_id) |
13 : manager_(manager), client_id_(client_id), has_been_bound_(false) { | 13 : manager_(manager), client_id_(client_id), has_been_bound_(false) { |
14 manager_->StartTracking(this); | 14 manager_->StartTracking(this); |
| 15 active_state_map_ = new ValueStateMap(); |
15 } | 16 } |
16 | 17 |
17 Valuebuffer::~Valuebuffer() { | 18 Valuebuffer::~Valuebuffer() { |
18 if (manager_) { | 19 if (manager_) { |
19 manager_->StopTracking(this); | 20 manager_->StopTracking(this); |
20 manager_ = NULL; | 21 manager_ = NULL; |
21 } | 22 } |
22 } | 23 } |
23 | 24 |
24 void Valuebuffer::AddSubscription(GLenum subscription) { | 25 void Valuebuffer::AddSubscription(unsigned int subscription) { |
25 subscriptions_.insert(subscription); | 26 subscriptions_.insert(subscription); |
26 } | 27 } |
27 | 28 |
28 void Valuebuffer::RemoveSubscription(GLenum subscription) { | 29 void Valuebuffer::RemoveSubscription(unsigned int subscription) { |
29 subscriptions_.erase(subscription); | 30 subscriptions_.erase(subscription); |
30 } | 31 } |
31 | 32 |
32 bool Valuebuffer::IsSubscribed(GLenum subscription) { | 33 bool Valuebuffer::IsSubscribed(unsigned int subscription) { |
33 return subscriptions_.find(subscription) != subscriptions_.end(); | 34 return subscriptions_.find(subscription) != subscriptions_.end(); |
34 } | 35 } |
35 | 36 |
36 const ValueState *Valuebuffer::GetState(GLenum target) const { | 37 const ValueState* Valuebuffer::GetState(unsigned int target) const { |
37 StateMap::const_iterator it = active_state_map_.find(target); | 38 return active_state_map_->GetState(target); |
38 return it != active_state_map_.end() ? &it->second : NULL; | |
39 } | 39 } |
40 | 40 |
41 void Valuebuffer::UpdateState(const StateMap& pending_state) { | 41 void Valuebuffer::UpdateState(const ValueStateMap* pending_state) { |
| 42 DCHECK(pending_state); |
42 for (SubscriptionSet::const_iterator it = subscriptions_.begin(); | 43 for (SubscriptionSet::const_iterator it = subscriptions_.begin(); |
43 it != subscriptions_.end(); ++it) { | 44 it != subscriptions_.end(); ++it) { |
44 StateMap::const_iterator pending_state_it = pending_state.find((*it)); | 45 const ValueState *state = pending_state->GetState(*it); |
45 if (pending_state_it != pending_state.end()) { | 46 if (state != NULL) { |
46 active_state_map_[pending_state_it->first] = pending_state_it->second; | 47 active_state_map_->UpdateState(*it, *state); |
47 } | 48 } |
48 } | 49 } |
49 } | 50 } |
50 | 51 |
51 ValuebufferManager::ValuebufferManager() | 52 ValuebufferManager::ValuebufferManager(ValueStateMap* state_map) |
52 : valuebuffer_count_(0) { | 53 : valuebuffer_count_(0), |
| 54 pending_state_map_(state_map) { |
53 } | 55 } |
54 | 56 |
55 ValuebufferManager::~ValuebufferManager() { | 57 ValuebufferManager::~ValuebufferManager() { |
56 DCHECK(valuebuffer_map_.empty()); | 58 DCHECK(valuebuffer_map_.empty()); |
57 DCHECK(pending_state_map_.empty()); | |
58 // If this triggers, that means something is keeping a reference to | 59 // If this triggers, that means something is keeping a reference to |
59 // a Valuebuffer belonging to this. | 60 // a Valuebuffer belonging to this. |
60 CHECK_EQ(valuebuffer_count_, 0u); | 61 CHECK_EQ(valuebuffer_count_, 0u); |
61 } | 62 } |
62 | 63 |
63 void ValuebufferManager::Destroy() { | 64 void ValuebufferManager::Destroy() { |
64 valuebuffer_map_.clear(); | 65 valuebuffer_map_.clear(); |
65 pending_state_map_.clear(); | |
66 } | 66 } |
67 | 67 |
68 void ValuebufferManager::StartTracking(Valuebuffer* /* valuebuffer */) { | 68 void ValuebufferManager::StartTracking(Valuebuffer* /* valuebuffer */) { |
69 ++valuebuffer_count_; | 69 ++valuebuffer_count_; |
70 } | 70 } |
71 | 71 |
72 void ValuebufferManager::StopTracking(Valuebuffer* /* valuebuffer */) { | 72 void ValuebufferManager::StopTracking(Valuebuffer* /* valuebuffer */) { |
73 --valuebuffer_count_; | 73 --valuebuffer_count_; |
74 } | 74 } |
75 | 75 |
76 void ValuebufferManager::CreateValuebuffer(GLuint client_id) { | 76 void ValuebufferManager::CreateValuebuffer(unsigned int client_id) { |
77 scoped_refptr<Valuebuffer> valuebuffer(new Valuebuffer(this, client_id)); | 77 scoped_refptr<Valuebuffer> valuebuffer(new Valuebuffer(this, client_id)); |
78 std::pair<ValuebufferMap::iterator, bool> result = | 78 std::pair<ValuebufferMap::iterator, bool> result = |
79 valuebuffer_map_.insert(std::make_pair(client_id, valuebuffer)); | 79 valuebuffer_map_.insert(std::make_pair(client_id, valuebuffer)); |
80 DCHECK(result.second); | 80 DCHECK(result.second); |
81 } | 81 } |
82 | 82 |
83 Valuebuffer* ValuebufferManager::GetValuebuffer(GLuint client_id) { | 83 Valuebuffer* ValuebufferManager::GetValuebuffer(unsigned int client_id) { |
84 ValuebufferMap::iterator it = valuebuffer_map_.find(client_id); | 84 ValuebufferMap::iterator it = valuebuffer_map_.find(client_id); |
85 return it != valuebuffer_map_.end() ? it->second.get() : NULL; | 85 return it != valuebuffer_map_.end() ? it->second.get() : NULL; |
86 } | 86 } |
87 | 87 |
88 void ValuebufferManager::RemoveValuebuffer(GLuint client_id) { | 88 void ValuebufferManager::RemoveValuebuffer(unsigned int client_id) { |
89 ValuebufferMap::iterator it = valuebuffer_map_.find(client_id); | 89 ValuebufferMap::iterator it = valuebuffer_map_.find(client_id); |
90 if (it != valuebuffer_map_.end()) { | 90 if (it != valuebuffer_map_.end()) { |
91 Valuebuffer* valuebuffer = it->second.get(); | 91 Valuebuffer* valuebuffer = it->second.get(); |
92 valuebuffer->MarkAsDeleted(); | 92 valuebuffer->MarkAsDeleted(); |
93 valuebuffer_map_.erase(it); | 93 valuebuffer_map_.erase(it); |
94 } | 94 } |
95 } | 95 } |
96 | 96 |
97 void ValuebufferManager::UpdateValuebufferState(Valuebuffer* valuebuffer) { | 97 void ValuebufferManager::UpdateValuebufferState(Valuebuffer* valuebuffer) { |
98 DCHECK(valuebuffer); | 98 DCHECK(valuebuffer); |
99 valuebuffer->UpdateState(pending_state_map_); | 99 valuebuffer->UpdateState(pending_state_map_.get()); |
100 } | 100 } |
101 | 101 |
102 void ValuebufferManager::UpdateValueState( | 102 uint32 ValuebufferManager::ApiTypeForSubscriptionTarget(unsigned int target) { |
103 GLenum target, const ValueState& state) { | |
104 pending_state_map_[target] = state; | |
105 } | |
106 | |
107 uint32 ValuebufferManager::ApiTypeForSubscriptionTarget(GLenum target) { | |
108 switch (target) { | 103 switch (target) { |
109 case GL_MOUSE_POSITION_CHROMIUM: | 104 case GL_MOUSE_POSITION_CHROMIUM: |
110 return Program::kUniform2i; | 105 return Program::kUniform2i; |
111 } | 106 } |
112 NOTREACHED() << "Unhandled uniform subscription target " << target; | 107 NOTREACHED() << "Unhandled uniform subscription target " << target; |
113 return Program::kUniformNone; | 108 return Program::kUniformNone; |
114 } | 109 } |
115 | 110 |
116 } // namespace gles2 | 111 } // namespace gles2 |
117 } // namespace gpu | 112 } // namespace gpu |
OLD | NEW |