2 .\" Copyright (c) 2002, Sun Microsystems, Inc. All Rights Reserved
3 .\" Copyright (c) 2015, Joyent, Inc.
4 .\" 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.
5 .\" 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.
6 .\" 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]
7 .TH BSTRING 3C "Dec 31, 2014"
9 bstring, bcopy, bcmp, bzero, explicit_bzero \- memory operations
15 \fBvoid\fR \fBbcopy\fR(\fBconst void *\fR\fIs1\fR, \fBvoid *\fR\fIs2\fR, \fBsize_t\fR \fIn\fR);
20 \fBint\fR \fBbcmp\fR(\fBconst void *\fR\fIs1\fR, \fBconst void *\fR\fIs2\fR, \fBsize_t\fR \fIn\fR);
25 \fBvoid\fR \fBbzero\fR(\fBvoid *\fR\fIs\fR, \fBsize_t\fR \fIn\fR);
30 \fBvoid\fR \fBexplicit_bzero\fR(\fBvoid *\fR\fIs\fR, \fBsize_t\fR \fIn\fR);
35 The \fBbcopy()\fR, \fBbcmp()\fR, and \fBbzero()\fR functions operate as
36 efficiently as possible on memory areas (arrays of bytes bounded by a count,
37 not terminated by a null character). They do not check for the overflow of
38 any receiving memory area. These functions are similar to the \fBmemcpy()\fR,
39 \fBmemcmp()\fR, and \fBmemset()\fR functions described on the \fBmemory\fR(3C)
43 The \fBbcopy()\fR function copies \fIn\fR bytes from memory area \fIs1\fR to
44 \fIs2\fR. Copying between objects that overlap will take place correctly.
47 The \fBbcmp()\fR function compares the first \fIn\fR bytes of its arguments,
48 returning 0 if they are identical and 1 otherwise. The \fBbcmp()\fR function
49 always returns 0 when \fIn\fR is 0.
52 The \fBbzero()\fR function sets the first \fIn\fR bytes in memory area \fIs\fR
56 The \fBexplicit_bzero()\fR function behaves the same as \fBbzero()\fR, except it
57 should not be removed by the compiler's optimization passes.
60 The \fBbcopy()\fR and \fBexplicit_bzero()\fR functions take parameters backwards
61 from \fBmemcmp()\fR. See \fBmemory\fR(3C).
64 See \fBattributes\fR(5) for descriptions of the following attributes:
72 ATTRIBUTE TYPE ATTRIBUTE VALUE
74 Interface Stability See NOTES
81 \fBmemory\fR(3C), \fBattributes\fR(5), \fBstandards\fR(5)
84 \fBbcopy\fR(), \fBbcmp\fR(), and \fBbzero\fR() are \fBSTANDARD\fR.
85 \fBexplicit_bzero\fR() is \fBCOMMITTED\fR.