blob: f4ebd3399321d2e664ee3faa74ef6ada81a82ee8 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
#include "stdlib.h"
void *memcpy(void *vd, const void *vs, int count) {
uint8_t *dest = vd, *src = vs;
uint32_t f = count % 4, n = count / 4, i;
const uint32_t* s = (uint32_t*)src;
uint32_t* d = (uint32_t*)dest;
for (i = 0; i < n; i++) {
d[i] = s[i];
}
if (f != 0) {
for (i = count - f; i < count; i++) {
dest[i] = src[i];
}
}
return vd;
}
uint8_t *memset(uint8_t *dest, uint8_t val, int count) {
int i;
for (i = 0; i < count; i++) {
dest[i] = val;
}
return dest;
}
uint16_t *memsetw(uint16_t *dest, uint16_t val, int count) {
int i;
for (i = 0; i < count; i++) {
dest[i] = val;
}
return dest;
}
int strlen(const char *str) {
int i = 0;
while (str[i++]);
return i;
}
|