// Copyright (c) 2012 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include "gpu/command_buffer/client/buffer_tracker.h" #include "gpu/command_buffer/client/cmd_buffer_helper.h" #include "gpu/command_buffer/client/mapped_memory.h" namespace gpu { namespace gles2 { BufferTracker::BufferTracker(MappedMemoryManager* manager) : mapped_memory_(manager) { } BufferTracker::~BufferTracker() { while (!buffers_.empty()) { RemoveBuffer(buffers_.begin()->first); } } BufferTracker::Buffer* BufferTracker::CreateBuffer( GLuint id, GLsizeiptr size) { DCHECK_NE(0u, id); DCHECK_LE(0, size); int32 shm_id = -1; uint32 shm_offset = 0; void* address = NULL; if (size) address = mapped_memory_->Alloc(size, &shm_id, &shm_offset); Buffer* buffer = new Buffer(id, size, shm_id, shm_offset, address); std::pair<BufferMap::iterator, bool> result = buffers_.insert(std::make_pair(id, buffer)); DCHECK(result.second); return buffer; } BufferTracker::Buffer* BufferTracker::GetBuffer(GLuint client_id) { BufferMap::iterator it = buffers_.find(client_id); return it != buffers_.end() ? it->second : NULL; } void BufferTracker::RemoveBuffer(GLuint client_id) { BufferMap::iterator it = buffers_.find(client_id); if (it != buffers_.end()) { Buffer* buffer = it->second; buffers_.erase(it); if (buffer->address_) mapped_memory_->Free(buffer->address_); delete buffer; } } void BufferTracker::FreePendingToken(Buffer* buffer, int32 token) { if (buffer->address_) mapped_memory_->FreePendingToken(buffer->address_, token); buffer->size_ = 0; buffer->shm_id_ = 0; buffer->shm_offset_ = 0; buffer->address_ = NULL; } } // namespace gles2 } // namespace gpu