1 //-----------------------------------------------------------------------------
2 // Jonathan Westhues, Sept 2005
4 // This code is licensed to you under the terms of the GNU GPL, version 2 or,
5 // at your option, any later version. See the LICENSE.txt file for the text of
7 //-----------------------------------------------------------------------------
8 // Common string.h functions
9 //-----------------------------------------------------------------------------
14 void *memcpy(void *dest
, const void *src
, int len
)
17 const uint8_t *s
= src
;
26 void *memset(void *dest
, int c
, int len
)
36 int memcmp(const void *av
, const void *bv
, int len
)
38 const uint8_t *a
= av
;
39 const uint8_t *b
= bv
;
51 void memxor(uint8_t * dest
, uint8_t * src
, size_t len
) {
52 for( ; len
> 0; len
--,dest
++,src
++)
56 int strlen(const char *str
)
66 char* strncat(char *dest
, const char *src
, unsigned int n
)
68 unsigned int dest_len
= strlen(dest
);
71 for (i
= 0 ; i
< n
&& src
[i
] != '\0' ; i
++)
72 dest
[dest_len
+ i
] = src
[i
];
73 dest
[dest_len
+ i
] = '\0';
78 char* strcat(char *dest
, const char *src
)
80 unsigned int dest_len
= strlen(dest
);
83 for (i
= 0 ; src
[i
] != '\0' ; i
++)
84 dest
[dest_len
+ i
] = src
[i
];
85 dest
[dest_len
+ i
] = '\0';
89 ////////////////////////////////////////// code to do 'itoa'
91 /* reverse: reverse string s in place */
92 void strreverse(char s
[])
96 for (i
= 0, j
= strlen(s
)-1; i
<j
; i
++, j
--) {
103 /* itoa: convert n to characters in s */
104 void itoa(int n
, char s
[])
108 if ((sign
= n
) < 0) /* record sign */
109 n
= -n
; /* make n positive */
111 do { /* generate digits in reverse order */
112 s
[i
++] = n
% 10 + '0'; /* get next digit */
113 } while ((n
/= 10) > 0); /* delete it */
120 //////////////////////////////////////// END 'itoa' CODE