2 .\" Copyright (c) 2003, Sun Microsystems, Inc. All Rights Reserved
3 .\" The contents of this file are subject to the terms of the Common Development and Distribution License (the "License"). You may not use this file except in compliance with the License.
4 .\" You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE or http://www.opensolaris.org/os/licensing. See the License for the specific language governing permissions and limitations under the License.
5 .\" When distributing Covered Code, include this CDDL HEADER in each file and include the License file at usr/src/OPENSOLARIS.LICENSE. If applicable, add the following below this CDDL HEADER, with the fields enclosed by brackets "[]" replaced with your own identifying information: Portions Copyright [yyyy] [name of copyright owner]
6 .TH PPGSZ 1 "Jan 23, 2003"
8 ppgsz \- set preferred page size for stack, heap, and/or other anonymous
13 \fB/usr/bin/ppgsz\fR [\fB-F\fR] \fB-o\fR \fIoption\fR[,\fIoption\fR] \fIcmd\fR | \fB-p\fR \fIpid\fR...
19 The \fBppgsz\fR utility sets the preferred page size for stack, heap, and/or
20 other anonymous segments for the target process(es), that is, the launched
21 \fIcmd\fR or the process(es) in the pid list. \fBppgsz\fR stops the target
22 process(es) while changing the page size. See \fBmemcntl\fR(2).
26 The following options are supported:
33 Force. Sets the preferred page size options(s) for target process(es) even if
34 controlled by other process(es). Caution should be exercised when using the
35 \fB-F\fR flag. See \fBproc\fR(1).
41 \fB\fB-o\fR \fIoption\fR[,\fIoption\fR]\fR
44 The \fIoption\fRs are:
48 \fB\fBheap\fR=\fIsize\fR\fR
51 This option specifies the preferred page size for the heap of the target
52 process(es). \fBheap\fR is defined to be the bss (uninitialized data) and the
53 brk area that immediately follows the bss (see \fBbrk\fR(2)). The preferred
54 heap page size is set for the existing heap and for any additional heap memory
55 allocated in the future. See NOTES.
61 \fB\fBstack\fR=\fIsize\fR\fR
64 This option specifies the preferred page size for the stack of the target
65 process(es). The preferred stack page size is set for the existing stack and
66 newly allocated parts of the stack as it expands.
72 \fB\fBanon\fR=\fIsize\fR\fR
75 This option specifies the preferred page size for all existing
76 \fBMAP_PRIVATE\fR anonymous segments of the target process(es), other than
77 \fBheap\fR and \fBstack\fR, which are large enough to fit at least one aligned
78 page of the specified size. For the segments that are large enough, the
79 preferred page size is set starting at the first size-aligned address in the
80 segment. The \fBanon\fR preferred pagesize is not applied to \fBMAP_PRIVATE\fR
81 anonymous segments created in the future. See \fBMAP_ANON\fR in \fBmmap\fR(2).
83 Anonymous memory refers to \fBMAP_PRIVATE\fR pages that are not directly
84 associated with a file in some filesystem. The \fBppgsz\fR command uses
85 \fBmemcntl\fR(2) to set the preferred page size for anonymous segments. See
86 \fBMC_HAT_ADVISE\fR in \fBmemcntl\fR(2).
89 At least one of the above options must be specified.
91 \fIsize\fR must be a supported page size (see \fBpagesize\fR(1)) or \fB0\fR, in
92 which case the system will select an appropriate page size. See
95 \fIsize\fR defaults to bytes and can be specified in octal (\fB0\fR), decimal,
96 or hexadecimal (\fB0x\fR). The numeric value can be qualified with \fBK\fR,
97 \fBM\fR, \fBG\fR, or \fBT\fR to specify Kilobytes, Megabytes, Gigabytes, or
98 Terabytes, respectively. \fB4194304\fR, \fB0x400000\fR, \fB4096K\fR,
99 \fB0x1000K\fR, and \fB4M\fR are different ways to specify 4 Megabytes.
105 \fB\fB-p\fR \fIpid\fR\fR
108 Sets the preferred page size option(s) for the target process(es) in the
109 process-id (\fIpid\fR) list following the \fB-p\fR option. The pid list can
110 also consist of names in the \fB/proc\fR directory. Only the process owner or
111 the super-user is permitted to set page size.
113 \fIcmd\fR is interpreted if \fB-p\fR is not specified. \fBppgsz\fR launches
114 \fIcmd\fR and applies page size option(s) to the new process.
116 The heap and stack preferred page sizes are inherited. Child process(es)
117 created (see \fBfork\fR(2)) from the launched process or the target process(es)
118 in the pid list after \fBppgsz\fR completes will inherit the preferred heap and
119 stack page sizes. The preferred page sizes of all segments are set back to the
120 default system page size on \fBexec\fR(2) (see \fBgetpagesize\fR(3C)). The
121 preferred page size for all other anonymous segments is not inherited by
122 children of the launched or target process(es).
127 \fBExample 1 \fRSetting the preferred heap and stack page size
130 The following example sets the preferred heap page size to \fB4M\fR and the
131 preferred stack page size to \fB512K\fR for all \fBora\fR\(emowned processes
132 running commands that begin with \fBora\fR:
137 example% \fBppgsz -o heap=4M,stack=512K -p `pgrep -u ora '^ora'`\fR
143 \fBExample 2 \fRSetting the preferred anonymous page size
146 The following example sets the preferred page size of existing qualifying
147 anonymous segments to \fB512k\fR for process ID \fB953\fR:
152 example% \fBppgsz -o anon=512k -p 953\fR
160 If \fIcmd\fR is specified and successfully invoked (see \fBexec\fR(2)), the
161 exit status of \fBppgsz\fR will be the exit status of \fIcmd\fR. Otherwise,
162 \fBppgsz\fR will exit with one of the following values:
169 Successfully set preferred page size(s) for processes in the pid list.
178 An error occurred in \fBppgsz\fR. Errors include: invalid argument, invalid
179 page size(s) specified, and failure to set preferred page size(s) for one or
180 more processes in the pid list or \fIcmd\fR.
189 \fIcmd\fR was found but could not be invoked.
198 \fIcmd\fR could not be found.
214 \fB\fB/usr/lib/ld/map.bssalign\fR \fR
217 A template link-editor \fBmapfile\fR for aligning bss (see NOTES).
223 See \fBattributes\fR(5) for descriptions of the following attributes:
231 ATTRIBUTE TYPE ATTRIBUTE VALUE
233 Interface Stability Evolving
239 \fBld\fR(1), \fBmpss.so.1\fR(1), \fBpagesize\fR(1), \fBpgrep\fR(1),
240 \fBpmap\fR(1), \fBproc\fR(1), \fBbrk\fR(2), \fBexec\fR(2), \fBfork\fR(2),
241 \fBmemcntl\fR(2), \fBmmap\fR(2), \fBsbrk\fR(2), \fBgetpagesize\fR(3C),
242 \fBproc\fR(4), \fBattributes\fR(5)
245 \fILinker and Libraries Guide\fR
249 Due to resource constraints, the setting of the preferred page size does not
250 necessarily guarantee that the target process(es) will get the preferred page
251 size. Use \fBpmap\fR(1) to view the \fBactual\fR heap and stack page sizes of
252 the target process(es) (see \fBpmap\fR \fB-s\fR option).
255 Large pages are required to be mapped at addresses that are multiples of the
256 size of the large page. Given that the heap is typically not large page
257 aligned, the starting portions of the heap (below the first large page aligned
258 address) are mapped with the system memory page size. See
259 \fBgetpagesize\fR(3C).
262 To provide a heap that will be mapped with a large page size, an application
263 can be built using a link-editor (\fBld\fR(1)) \fBmapfile\fR containing the
264 \fBbss\fR segment declaration directive. Refer to the section Mapfile Option in
265 the \fILinker and Libraries Guide\fR for more details of this directive and the
266 template \fBmapfile\fR provided in \fB/usr/lib/ld/map.bssalign\fR. Users are
267 cautioned that an alignment specification may be machine-specific and may lose
268 its benefit on different hardware platforms. A more flexible means of
269 requesting the most optimal underlying page size may evolve in future releases.
272 \fBmpss.so.1\fR(1), a preloadable shared object, can also be used to set the
273 preferred stack and/or heap page sizes.