xref: /titanic_51/usr/src/lib/libast/common/vmalloc/vmclose.c (revision 3e14f97f673e8a630f076077de35afdd43dc1587)
1da2e3ebdSchin /***********************************************************************
2da2e3ebdSchin *                                                                      *
3da2e3ebdSchin *               This software is part of the ast package               *
4*3e14f97fSRoger A. Faulkner *          Copyright (c) 1985-2010 AT&T Intellectual Property          *
5da2e3ebdSchin *                      and is licensed under the                       *
6da2e3ebdSchin *                  Common Public License, Version 1.0                  *
77c2fbfb3SApril Chin *                    by AT&T Intellectual Property                     *
8da2e3ebdSchin *                                                                      *
9da2e3ebdSchin *                A copy of the License is available at                 *
10da2e3ebdSchin *            http://www.opensource.org/licenses/cpl1.0.txt             *
11da2e3ebdSchin *         (with md5 checksum 059e8cd6165cb4c31e351f2b69388fd9)         *
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_vmclose()24da2e3ebdSchin void _STUB_vmclose(){}
25da2e3ebdSchin 
26da2e3ebdSchin #else
27da2e3ebdSchin 
28da2e3ebdSchin #include	"vmhdr.h"
29da2e3ebdSchin 
30da2e3ebdSchin /*	Close down a region.
31da2e3ebdSchin **
32da2e3ebdSchin **	Written by Kiem-Phong Vo, kpv@research.att.com, 01/16/94.
33da2e3ebdSchin */
34da2e3ebdSchin #if __STD_C
vmclose(Vmalloc_t * vm)35da2e3ebdSchin int vmclose(Vmalloc_t* vm)
36da2e3ebdSchin #else
37da2e3ebdSchin int vmclose(vm)
38da2e3ebdSchin Vmalloc_t*	vm;
39da2e3ebdSchin #endif
40da2e3ebdSchin {
41da2e3ebdSchin 	Seg_t		*seg, *vmseg, *next;
42da2e3ebdSchin 	Vmalloc_t	*v, *last;
43da2e3ebdSchin 	Vmdata_t*	vd = vm->data;
44da2e3ebdSchin 	int		ev = 0;
45da2e3ebdSchin 
46da2e3ebdSchin 	if(vm == Vmheap)
47da2e3ebdSchin 		return -1;
48da2e3ebdSchin 
49da2e3ebdSchin 	if(!(vd->mode&VM_TRUST) && ISLOCK(vd,0))
50da2e3ebdSchin 		return -1;
51da2e3ebdSchin 
52da2e3ebdSchin 	if(vm->disc->exceptf &&
53da2e3ebdSchin 	   (ev = (*vm->disc->exceptf)(vm,VM_CLOSE,NIL(Void_t*),vm->disc)) < 0 )
54da2e3ebdSchin 		return -1;
55da2e3ebdSchin 
56da2e3ebdSchin 	/* make this region inaccessible until it disappears */
57da2e3ebdSchin 	vd->mode &= ~VM_TRUST;
58da2e3ebdSchin 	SETLOCK(vd,0);
59da2e3ebdSchin 
60da2e3ebdSchin 	if((vd->mode&VM_MTPROFILE) && _Vmpfclose)
61da2e3ebdSchin 		(*_Vmpfclose)(vm);
62da2e3ebdSchin 
63da2e3ebdSchin 	/* remove from linked list of regions	*/
64da2e3ebdSchin 	for(last = Vmheap, v = last->next; v; last = v, v = v->next)
65da2e3ebdSchin 	{	if(v == vm)
66da2e3ebdSchin 		{	last->next = v->next;
67da2e3ebdSchin 			break;
68da2e3ebdSchin 		}
69da2e3ebdSchin 	}
70da2e3ebdSchin 
71da2e3ebdSchin 	if(ev == 0)
72da2e3ebdSchin 	{	vmseg = NIL(Seg_t*);
73da2e3ebdSchin 		for(seg = vd->seg; seg; seg = next)
74da2e3ebdSchin 		{	next = seg->next;
75da2e3ebdSchin 			if(seg->extent == seg->size)
76da2e3ebdSchin 				vmseg = seg;
77da2e3ebdSchin 			else	(*vm->disc->memoryf)(vm,seg->addr,seg->extent,0,vm->disc);
78da2e3ebdSchin 		}
79da2e3ebdSchin 		if(vmseg)
80da2e3ebdSchin 			(*vm->disc->memoryf)(vm,vmseg->addr,vmseg->extent,0,vm->disc);
81da2e3ebdSchin 	}
82da2e3ebdSchin 	else	CLRLOCK(vd,0);
83da2e3ebdSchin 
84da2e3ebdSchin 	vmfree(Vmheap,vm);
85da2e3ebdSchin 
86da2e3ebdSchin 	return 0;
87da2e3ebdSchin }
88da2e3ebdSchin 
89da2e3ebdSchin #endif
90