xref: /freebsd/lib/libc/string/bcopy.3 (revision 6a182dddd96b4ae8fb9664e39c7ef2c40e6979ff)
158f0484fSRodney W. Grimes.\" Copyright (c) 1990, 1991, 1993
258f0484fSRodney W. Grimes.\"	The Regents of the University of California.  All rights reserved.
358f0484fSRodney W. Grimes.\"
458f0484fSRodney W. Grimes.\" This code is derived from software contributed to Berkeley by
558f0484fSRodney W. Grimes.\" Chris Torek.
658f0484fSRodney W. Grimes.\"
758f0484fSRodney W. Grimes.\" Redistribution and use in source and binary forms, with or without
858f0484fSRodney W. Grimes.\" modification, are permitted provided that the following conditions
958f0484fSRodney W. Grimes.\" are met:
1058f0484fSRodney W. Grimes.\" 1. Redistributions of source code must retain the above copyright
1158f0484fSRodney W. Grimes.\"    notice, this list of conditions and the following disclaimer.
1258f0484fSRodney W. Grimes.\" 2. Redistributions in binary form must reproduce the above copyright
1358f0484fSRodney W. Grimes.\"    notice, this list of conditions and the following disclaimer in the
1458f0484fSRodney W. Grimes.\"    documentation and/or other materials provided with the distribution.
153fb3b97cSEd Maste.\" 3. Neither the name of the University nor the names of its contributors
1658f0484fSRodney W. Grimes.\"    may be used to endorse or promote products derived from this software
1758f0484fSRodney W. Grimes.\"    without specific prior written permission.
1858f0484fSRodney W. Grimes.\"
1958f0484fSRodney W. Grimes.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
2058f0484fSRodney W. Grimes.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
2158f0484fSRodney W. Grimes.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
2258f0484fSRodney W. Grimes.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
2358f0484fSRodney W. Grimes.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
2458f0484fSRodney W. Grimes.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
2558f0484fSRodney W. Grimes.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
2658f0484fSRodney W. Grimes.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
2758f0484fSRodney W. Grimes.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
2858f0484fSRodney W. Grimes.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
2958f0484fSRodney W. Grimes.\" SUCH DAMAGE.
3058f0484fSRodney W. Grimes.\"
3158f0484fSRodney W. Grimes.\"     @(#)bcopy.3	8.1 (Berkeley) 6/4/93
327f3dea24SPeter Wemm.\" $FreeBSD$
3358f0484fSRodney W. Grimes.\"
34*6a182dddSMarcelo Araujo.Dd August 14, 2015
3558f0484fSRodney W. Grimes.Dt BCOPY 3
36a307d598SRuslan Ermilov.Os
3758f0484fSRodney W. Grimes.Sh NAME
3858f0484fSRodney W. Grimes.Nm bcopy
3958f0484fSRodney W. Grimes.Nd copy byte string
4025bb73e0SAlexey Zelkin.Sh LIBRARY
4125bb73e0SAlexey Zelkin.Lb libc
4258f0484fSRodney W. Grimes.Sh SYNOPSIS
43bc0ad8e7SRobert Drehmel.In strings.h
4458f0484fSRodney W. Grimes.Ft void
4558f0484fSRodney W. Grimes.Fn bcopy "const void *src" "void *dst" "size_t len"
4658f0484fSRodney W. Grimes.Sh DESCRIPTION
4758f0484fSRodney W. GrimesThe
4858f0484fSRodney W. Grimes.Fn bcopy
4958f0484fSRodney W. Grimesfunction
5058f0484fSRodney W. Grimescopies
5158f0484fSRodney W. Grimes.Fa len
5258f0484fSRodney W. Grimesbytes from string
5358f0484fSRodney W. Grimes.Fa src
5458f0484fSRodney W. Grimesto string
5558f0484fSRodney W. Grimes.Fa dst .
5658f0484fSRodney W. GrimesThe two strings may overlap.
5758f0484fSRodney W. GrimesIf
5858f0484fSRodney W. Grimes.Fa len
5958f0484fSRodney W. Grimesis zero, no bytes are copied.
6058f0484fSRodney W. Grimes.Sh SEE ALSO
6158f0484fSRodney W. Grimes.Xr memccpy 3 ,
6258f0484fSRodney W. Grimes.Xr memcpy 3 ,
6358f0484fSRodney W. Grimes.Xr memmove 3 ,
6458f0484fSRodney W. Grimes.Xr strcpy 3 ,
6558f0484fSRodney W. Grimes.Xr strncpy 3
6658f0484fSRodney W. Grimes.Sh HISTORY
6758f0484fSRodney W. GrimesA
6858f0484fSRodney W. Grimes.Fn bcopy
6958f0484fSRodney W. Grimesfunction appeared in
7058f0484fSRodney W. Grimes.Bx 4.2 .
71bc0ad8e7SRobert DrehmelIts prototype existed previously in
72fe08efe6SRuslan Ermilov.In string.h
73bc0ad8e7SRobert Drehmelbefore it was moved to
74fe08efe6SRuslan Ermilov.In strings.h
75bc0ad8e7SRobert Drehmelfor
76bc0ad8e7SRobert Drehmel.St -p1003.1-2001
77bc0ad8e7SRobert Drehmelcompliance.
78*6a182dddSMarcelo Araujo.Pp
79*6a182dddSMarcelo AraujoThe
80*6a182dddSMarcelo Araujo.St -p1003.1-2008
81*6a182dddSMarcelo Araujoremoves the specification of
82*6a182dddSMarcelo Araujo.Fn bcopy
83*6a182dddSMarcelo Araujoand it is marked as LEGACY in
84*6a182dddSMarcelo Araujo.St -p1003.1-2004 .
85*6a182dddSMarcelo AraujoNew programs should use
86*6a182dddSMarcelo Araujo.Xr memmove 3 .
87*6a182dddSMarcelo AraujoIf the input and output buffer do not overlap, then
88*6a182dddSMarcelo Araujo.Xr memcpy 3
89*6a182dddSMarcelo Araujois more efficient.
90*6a182dddSMarcelo AraujoNote that
91*6a182dddSMarcelo Araujo.Fn bcopy
92*6a182dddSMarcelo Araujotakes
93*6a182dddSMarcelo Araujo.Ar src
94*6a182dddSMarcelo Araujoand
95*6a182dddSMarcelo Araujo.Ar dst
96*6a182dddSMarcelo Araujoin the opposite order from
97*6a182dddSMarcelo Araujo.Fn memmove
98*6a182dddSMarcelo Araujoand
99*6a182dddSMarcelo Araujo.Fn memcpy .
100