source: mainline/boot/generic/src/memstr.c@ de1712e

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since de1712e was de1712e, checked in by Martin Decky <martin@…>, 8 years ago

boot: rename typedefs.h to stddef.h

  • Property mode set to 100644
File size: 3.2 KB
Line 
1/*
2 * Copyright (c) 2010 Jiri Svoboda
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 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29#include <memstr.h>
30#include <stddef.h>
31
32/** Move memory block without overlapping.
33 *
34 * Copy cnt bytes from src address to dst address. The source
35 * and destination memory areas cannot overlap.
36 *
37 * @param dst Destination address to copy to.
38 * @param src Source address to copy from.
39 * @param cnt Number of bytes to copy.
40 *
41 * @return Destination address.
42 *
43 */
44void *memcpy(void *dst, const void *src, size_t cnt)
45{
46 uint8_t *dp = (uint8_t *) dst;
47 const uint8_t *sp = (uint8_t *) src;
48
49 while (cnt-- != 0)
50 *dp++ = *sp++;
51
52 return dst;
53}
54
55/** Fill block of memory.
56 *
57 * Fill cnt bytes at dst address with the value val.
58 *
59 * @param dst Destination address to fill.
60 * @param val Value to fill.
61 * @param cnt Number of bytes to fill.
62 *
63 * @return Destination address.
64 *
65 */
66void *memset(void *dst, int val, size_t cnt)
67{
68 uint8_t *dp = (uint8_t *) dst;
69
70 while (cnt-- != 0)
71 *dp++ = val;
72
73 return dst;
74}
75
76/** Move memory block with possible overlapping.
77 *
78 * Copy cnt bytes from src address to dst address. The source
79 * and destination memory areas may overlap.
80 *
81 * @param dst Destination address to copy to.
82 * @param src Source address to copy from.
83 * @param cnt Number of bytes to copy.
84 *
85 * @return Destination address.
86 *
87 */
88void *memmove(void *dst, const void *src, size_t cnt)
89{
90 /* Nothing to do? */
91 if (src == dst)
92 return dst;
93
94 /* Non-overlapping? */
95 if ((dst >= src + cnt) || (src >= dst + cnt))
96 return memcpy(dst, src, cnt);
97
98 uint8_t *dp;
99 const uint8_t *sp;
100
101 /* Which direction? */
102 if (src > dst) {
103 /* Forwards. */
104 dp = dst;
105 sp = src;
106
107 while (cnt-- != 0)
108 *dp++ = *sp++;
109 } else {
110 /* Backwards. */
111 dp = dst + (cnt - 1);
112 sp = src + (cnt - 1);
113
114 while (cnt-- != 0)
115 *dp-- = *sp--;
116 }
117
118 return dst;
119}
120
121/** @}
122 */
Note: See TracBrowser for help on using the repository browser.