1da2e3ebdSchin /*********************************************************************** 2da2e3ebdSchin * * 3da2e3ebdSchin * This software is part of the ast package * 4*b30d1939SAndy Fiddaman * Copyright (c) 1985-2011 AT&T Intellectual Property * 5da2e3ebdSchin * and is licensed under the * 6*b30d1939SAndy Fiddaman * Eclipse Public License, Version 1.0 * 77c2fbfb3SApril Chin * by AT&T Intellectual Property * 8da2e3ebdSchin * * 9da2e3ebdSchin * A copy of the License is available at * 10*b30d1939SAndy Fiddaman * http://www.eclipse.org/org/documents/epl-v10.html * 11*b30d1939SAndy Fiddaman * (with md5 checksum b35adb5213ca9657e911e9befb180842) * 12da2e3ebdSchin * * 13da2e3ebdSchin * Information and Software Systems Research * 14da2e3ebdSchin * AT&T Research * 15da2e3ebdSchin * Florham Park NJ * 16da2e3ebdSchin * * 17da2e3ebdSchin * Glenn Fowler <gsf@research.att.com> * 18da2e3ebdSchin * David Korn <dgk@research.att.com> * 19da2e3ebdSchin * Phong Vo <kpv@research.att.com> * 20da2e3ebdSchin * * 21da2e3ebdSchin ***********************************************************************/ 22da2e3ebdSchin #if defined(_UWIN) && defined(_BLD_ast) 23da2e3ebdSchin _STUB_vmregion()24da2e3ebdSchinvoid _STUB_vmregion(){} 25da2e3ebdSchin 26da2e3ebdSchin #else 27da2e3ebdSchin 28da2e3ebdSchin #include "vmhdr.h" 29da2e3ebdSchin 30da2e3ebdSchin /* Return the containing region of an allocated piece of memory. 313e14f97fSRoger A. Faulkner ** Beware: this only works with Vmbest, Vmdebug and Vmprofile. 323e14f97fSRoger A. Faulkner ** 333e14f97fSRoger A. Faulkner ** 10/31/2009: Add handling of shared/persistent memory regions. 34da2e3ebdSchin ** 35da2e3ebdSchin ** Written by Kiem-Phong Vo, kpv@research.att.com, 01/16/94. 36da2e3ebdSchin */ 37da2e3ebdSchin #if __STD_C vmregion(Void_t * addr)383e14f97fSRoger A. FaulknerVmalloc_t* vmregion(Void_t* addr) 39da2e3ebdSchin #else 40da2e3ebdSchin Vmalloc_t* vmregion(addr) 413e14f97fSRoger A. Faulkner Void_t* addr; 42da2e3ebdSchin #endif 433e14f97fSRoger A. Faulkner { 443e14f97fSRoger A. Faulkner Vmalloc_t *vm; 453e14f97fSRoger A. Faulkner Vmdata_t *vd; 463e14f97fSRoger A. Faulkner 473e14f97fSRoger A. Faulkner if(!addr) 483e14f97fSRoger A. Faulkner return NIL(Vmalloc_t*); 493e14f97fSRoger A. Faulkner 503e14f97fSRoger A. Faulkner vd = SEG(BLOCK(addr))->vmdt; 51*b30d1939SAndy Fiddaman 52*b30d1939SAndy Fiddaman _vmlock(NIL(Vmalloc_t*), 1); 533e14f97fSRoger A. Faulkner for(vm = Vmheap; vm; vm = vm->next) 543e14f97fSRoger A. Faulkner if(vm->data == vd) 553e14f97fSRoger A. Faulkner break; 56*b30d1939SAndy Fiddaman _vmlock(NIL(Vmalloc_t*), 0); 573e14f97fSRoger A. Faulkner 583e14f97fSRoger A. Faulkner return vm; 59da2e3ebdSchin } 60da2e3ebdSchin 61da2e3ebdSchin #endif 62