13d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby/* 23d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby * Copyright (C) 2014 The Android Open Source Project 33d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby * 43d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby * Licensed under the Apache License, Version 2.0 (the "License"); 53d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby * you may not use this file except in compliance with the License. 63d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby * You may obtain a copy of the License at 73d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby * 83d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby * http://www.apache.org/licenses/LICENSE-2.0 93d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby * 103d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby * Unless required by applicable law or agreed to in writing, software 113d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby * distributed under the License is distributed on an "AS IS" BASIS, 123d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 133d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby * See the License for the specific language governing permissions and 143d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby * limitations under the License. 153d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby */ 163d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby 173d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby#include "dmMemory.h" 183d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby#include "dmThreadHelper.h" 193d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby#include <stdio.h> 203d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby#include <sys/time.h> 213d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby#include <signal.h> 223d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby#include "dmAllocatedPointersPool.h" 233d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby 243d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby#ifdef DEBUG 253d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake HambyDMAllocatedPointersPool::~DMAllocatedPointersPool() 263d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby{ 273d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby#ifdef DEBUG 283d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby //PrintUnreleased(); 293d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby#endif 303d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby} 313d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby 323d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hambyvoid DMAllocatedPointersPool::PrintUnreleased() 333d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby{ 343d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby DMSingleLock oLock( m_csPointerPoolLock ); 353d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby 363d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby std::map<void*, int>::const_iterator vli = m_listOfAllocatedPointers.begin(); 373d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby int nBlockNum = 1; 383d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby 393d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby while (vli != m_listOfAllocatedPointers.end()) 403d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby { 413d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby const char *ptr = (const char*)(const void*)vli->first; 423d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby CPCHAR* ppStr = (CPCHAR*)ptr; 433d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby 443d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby ptr += 3*sizeof(const char*) + DMAllocatedPointersPool::c_nExtraBytes; 453d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby 463d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby printf( "%d. block (%d bytes) with addr %p was not deallocated; file %s, line %d\n", 473d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby nBlockNum++, (int)ppStr[2], ptr, ppStr[0], (int)ppStr[1] ); 483d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby vli++; 493d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby } 503d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby if ( nBlockNum > 1 ) 513d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby printf( "\n" ); 523d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby 533d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby //m_listOfAllocatedPointers.clear(); 543d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby} 553d91e7ce47853dc4e6ec7e1fc675c3d1585e3c51Jake Hamby#endif //DEBUG 56