2 .\" Copyright (c) 2012 The NetBSD Foundation, Inc.
3 .\" All rights reserved.
5 .\" This code is derived from software contributed to The NetBSD Foundation
8 .\" Redistribution and use in source and binary forms, with or without
9 .\" modification, are permitted provided that the following conditions
11 .\" 1. Redistributions of source code must retain the above copyright
12 .\" notice, this list of conditions and the following disclaimer.
13 .\" 2. Redistributions in binary form must reproduce the above copyright
14 .\" notice, this list of conditions and the following disclaimer in the
15 .\" documentation and/or other materials provided with the distribution.
17 .\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
18 .\" ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
19 .\" TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
20 .\" PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
21 .\" BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22 .\" CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23 .\" SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24 .\" INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
25 .\" CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26 .\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27 .\" POSSIBILITY OF SUCH DAMAGE.
36 .Nd copy a value to all bytes of a memory buffer
40 .Fd "#define __STDC_WANT_LIB_EXT1__ 1
43 .Fn memset_s "void *s" "rsize_t smax" "int c" "rsize_t n"
47 function copies the value
49 (converted to an unsigned char)
50 into each of the first
52 bytes of the memory buffer whose starting address is given by
55 It is a runtime-constraints violation if
68 If there is a runtime-constraints violation, and if
70 is not a null pointer,
75 then, before reporting the runtime-constraints violation,
79 bytes to the destination.
89 This property is required by the following sentences in
92 .Bd -filled -offset indent
97 function shall be evaluated strictly according to the rules of
98 the abstract machine as described in (5.1.2.3).
99 That is, any call to the
101 function shall assume that the memory indicated by
105 may be accessible in the future and thus must contain
106 the values indicated by
112 function returns zero for success, or a non-zero error code
113 if there was a runtime-constraints violation.
116 returns the following error codes.
117 It does not store the error code in the global
124 argument was a null pointer.
146 .Fn set_constraint_handler_s
147 interface is not supported.