zone.9 (242270) | zone.9 (243998) |
---|---|
1.\"- 2.\" Copyright (c) 2001 Dag-Erling Co��dan Sm��rgrav 3.\" All rights reserved. 4.\" 5.\" Redistribution and use in source and binary forms, with or without 6.\" modification, are permitted provided that the following conditions 7.\" are met: 8.\" 1. Redistributions of source code must retain the above copyright --- 9 unchanged lines hidden (view full) --- 18.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24.\" SUCH DAMAGE. 25.\" | 1.\"- 2.\" Copyright (c) 2001 Dag-Erling Co��dan Sm��rgrav 3.\" All rights reserved. 4.\" 5.\" Redistribution and use in source and binary forms, with or without 6.\" modification, are permitted provided that the following conditions 7.\" are met: 8.\" 1. Redistributions of source code must retain the above copyright --- 9 unchanged lines hidden (view full) --- 18.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24.\" SUCH DAMAGE. 25.\" |
26.\" $FreeBSD: head/share/man/man9/zone.9 242270 2012-10-28 21:01:32Z trasz $ | 26.\" $FreeBSD: head/share/man/man9/zone.9 243998 2012-12-07 22:27:13Z pjd $ |
27.\" | 27.\" |
28.Dd October 28, 2012 | 28.Dd December 7, 2012 |
29.Dt ZONE 9 30.Os 31.Sh NAME 32.Nm uma_zcreate , 33.Nm uma_zalloc , 34.Nm uma_zalloc_arg , 35.Nm uma_zfree , 36.Nm uma_zfree_arg , 37.Nm uma_zdestroy , 38.Nm uma_zone_set_max, 39.Nm uma_zone_get_max, | 29.Dt ZONE 9 30.Os 31.Sh NAME 32.Nm uma_zcreate , 33.Nm uma_zalloc , 34.Nm uma_zalloc_arg , 35.Nm uma_zfree , 36.Nm uma_zfree_arg , 37.Nm uma_zdestroy , 38.Nm uma_zone_set_max, 39.Nm uma_zone_get_max, |
40.Nm uma_zone_get_cur | 40.Nm uma_zone_get_cur, 41.Nm uma_zone_set_warning |
41.Nd zone allocator 42.Sh SYNOPSIS 43.In sys/param.h 44.In sys/queue.h 45.In vm/uma.h 46.Ft uma_zone_t 47.Fo uma_zcreate 48.Fa "char *name" "int size" --- 11 unchanged lines hidden (view full) --- 60.Ft void 61.Fn uma_zdestroy "uma_zone_t zone" 62.Ft int 63.Fn uma_zone_set_max "uma_zone_t zone" "int nitems" 64.Ft int 65.Fn uma_zone_get_max "uma_zone_t zone" 66.Ft int 67.Fn uma_zone_get_cur "uma_zone_t zone" | 42.Nd zone allocator 43.Sh SYNOPSIS 44.In sys/param.h 45.In sys/queue.h 46.In vm/uma.h 47.Ft uma_zone_t 48.Fo uma_zcreate 49.Fa "char *name" "int size" --- 11 unchanged lines hidden (view full) --- 61.Ft void 62.Fn uma_zdestroy "uma_zone_t zone" 63.Ft int 64.Fn uma_zone_set_max "uma_zone_t zone" "int nitems" 65.Ft int 66.Fn uma_zone_get_max "uma_zone_t zone" 67.Ft int 68.Fn uma_zone_get_cur "uma_zone_t zone" |
69.Ft void 70.Fn uma_zone_set_warning "uma_zone_t zone" "const char *warning" |
|
68.Sh DESCRIPTION 69The zone allocator provides an efficient interface for managing 70dynamically-sized collections of items of similar size. 71The zone allocator can work with preallocated zones as well as with 72runtime-allocated ones, and is therefore available much earlier in the 73boot process than other memory management routines. 74.Pp 75A zone is an extensible collection of items of identical size. --- 132 unchanged lines hidden (view full) --- 208.Pp 209The 210.Fn uma_zone_get_cur 211function returns the approximate current occupancy of the zone. 212The returned value is approximate because appropriate synchronisation to 213determine an exact value is not performed by the implementation. 214This ensures low overhead at the expense of potentially stale data being used 215in the calculation. | 71.Sh DESCRIPTION 72The zone allocator provides an efficient interface for managing 73dynamically-sized collections of items of similar size. 74The zone allocator can work with preallocated zones as well as with 75runtime-allocated ones, and is therefore available much earlier in the 76boot process than other memory management routines. 77.Pp 78A zone is an extensible collection of items of identical size. --- 132 unchanged lines hidden (view full) --- 211.Pp 212The 213.Fn uma_zone_get_cur 214function returns the approximate current occupancy of the zone. 215The returned value is approximate because appropriate synchronisation to 216determine an exact value is not performed by the implementation. 217This ensures low overhead at the expense of potentially stale data being used 218in the calculation. |
219.Pp 220The 221.Fn uma_zone_set_warning 222function sets a warning that will be printed on the system console when the 223given zone becomes full and fails to allocate an item. 224The warning will be printed not often than every five minutes. 225Warnings can be turned off globally by setting the 226.Va vm.zone_warnings 227sysctl tunable to 228.Va 0 . |
|
216.Sh RETURN VALUES 217The 218.Fn uma_zalloc 219function returns a pointer to an item, or 220.Dv NULL 221if the zone ran out of unused items 222and 223.Dv M_NOWAIT --- 21 unchanged lines hidden --- | 229.Sh RETURN VALUES 230The 231.Fn uma_zalloc 232function returns a pointer to an item, or 233.Dv NULL 234if the zone ran out of unused items 235and 236.Dv M_NOWAIT --- 21 unchanged lines hidden --- |