1 /* SPDX-License-Identifier: GPL-2.0 */
2 #ifndef __ALPHA_STRING_H__
3 #define __ALPHA_STRING_H__
4
5 #ifdef __KERNEL__
6
7 /*
8 * GCC of any recent vintage doesn't do stupid things with bcopy.
9 * EGCS 1.1 knows all about expanding memcpy inline, others don't.
10 *
11 * Similarly for a memset with data = 0.
12 */
13
14 #define __HAVE_ARCH_MEMCPY
15 extern void * memcpy(void *, const void *, size_t);
16 #define __HAVE_ARCH_MEMMOVE
17 extern void * memmove(void *, const void *, size_t);
18
19 /* For backward compatibility with modules. Unused otherwise. */
20 extern void * __memcpy(void *, const void *, size_t);
21
22 #define memcpy __builtin_memcpy
23
24 #define __HAVE_ARCH_MEMSET
25 extern void * __constant_c_memset(void *, unsigned long, size_t);
26 extern void * ___memset(void *, int, size_t);
27 extern void * __memset(void *, int, size_t);
28 extern void * memset(void *, int, size_t);
29
30 /* For gcc 3.x, we cannot have the inline function named "memset" because
31 the __builtin_memset will attempt to resolve to the inline as well,
32 leading to a "sorry" about unimplemented recursive inlining. */
__memset(void * s,int c,size_t n)33 extern inline void *__memset(void *s, int c, size_t n)
34 {
35 if (__builtin_constant_p(c)) {
36 if (__builtin_constant_p(n)) {
37 return __builtin_memset(s, c, n);
38 } else {
39 unsigned long c8 = (c & 0xff) * 0x0101010101010101UL;
40 return __constant_c_memset(s, c8, n);
41 }
42 }
43 return ___memset(s, c, n);
44 }
45
46 #define memset __memset
47
48 #define __HAVE_ARCH_STRCPY
49 extern char * strcpy(char *,const char *);
50 #define __HAVE_ARCH_STRNCPY
51 extern char * strncpy(char *, const char *, size_t);
52 #define __HAVE_ARCH_STRCAT
53 extern char * strcat(char *, const char *);
54 #define __HAVE_ARCH_STRNCAT
55 extern char * strncat(char *, const char *, size_t);
56 #define __HAVE_ARCH_STRCHR
57 extern char * strchr(const char *,int);
58 #define __HAVE_ARCH_STRRCHR
59 extern char * strrchr(const char *,int);
60 #define __HAVE_ARCH_STRLEN
61 extern size_t strlen(const char *);
62 #define __HAVE_ARCH_MEMCHR
63 extern void * memchr(const void *, int, size_t);
64
65 /* The following routine is like memset except that it writes 16-bit
66 aligned values. The DEST and COUNT parameters must be even for
67 correct operation. */
68
69 #define __HAVE_ARCH_MEMSET16
70 extern void * __memset16(void *dest, unsigned short, size_t count);
memset16(uint16_t * p,uint16_t v,size_t n)71 static inline void *memset16(uint16_t *p, uint16_t v, size_t n)
72 {
73 if (__builtin_constant_p(v))
74 return __constant_c_memset(p, 0x0001000100010001UL * v, n * 2);
75 return __memset16(p, v, n * 2);
76 }
77
78 #endif /* __KERNEL__ */
79
80 #endif /* __ALPHA_STRING_H__ */
81