string_32.h 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. /*
  2. * string.h: External definitions for optimized assembly string
  3. * routines for the Linux Kernel.
  4. *
  5. * Copyright (C) 1995,1996 David S. Miller (davem@caip.rutgers.edu)
  6. * Copyright (C) 1996,1997 Jakub Jelinek (jj@sunsite.mff.cuni.cz)
  7. */
  8. #ifndef __SPARC_STRING_H__
  9. #define __SPARC_STRING_H__
  10. #include <asm/page.h>
  11. /* Really, userland/ksyms should not see any of this stuff. */
  12. #ifdef __KERNEL__
  13. extern void __memmove(void *,const void *,__kernel_size_t);
  14. #ifndef EXPORT_SYMTAB_STROPS
  15. /* First the mem*() things. */
  16. #define __HAVE_ARCH_MEMMOVE
  17. #undef memmove
  18. #define memmove(_to, _from, _n) \
  19. ({ \
  20. void *_t = (_to); \
  21. __memmove(_t, (_from), (_n)); \
  22. _t; \
  23. })
  24. #define __HAVE_ARCH_MEMCPY
  25. #define memcpy(t, f, n) __builtin_memcpy(t, f, n)
  26. #define __HAVE_ARCH_MEMSET
  27. #define memset(s, c, count) __builtin_memset(s, c, count)
  28. #define __HAVE_ARCH_MEMSCAN
  29. #undef memscan
  30. #define memscan(__arg0, __char, __arg2) \
  31. ({ \
  32. extern void *__memscan_zero(void *, size_t); \
  33. extern void *__memscan_generic(void *, int, size_t); \
  34. void *__retval, *__addr = (__arg0); \
  35. size_t __size = (__arg2); \
  36. \
  37. if(__builtin_constant_p(__char) && !(__char)) \
  38. __retval = __memscan_zero(__addr, __size); \
  39. else \
  40. __retval = __memscan_generic(__addr, (__char), __size); \
  41. \
  42. __retval; \
  43. })
  44. #define __HAVE_ARCH_MEMCMP
  45. extern int memcmp(const void *,const void *,__kernel_size_t);
  46. /* Now the str*() stuff... */
  47. #define __HAVE_ARCH_STRLEN
  48. extern __kernel_size_t strlen(const char *);
  49. #define __HAVE_ARCH_STRNCMP
  50. extern int __strncmp(const char *, const char *, __kernel_size_t);
  51. static inline int __constant_strncmp(const char *src, const char *dest, __kernel_size_t count)
  52. {
  53. register int retval;
  54. switch(count) {
  55. case 0: return 0;
  56. case 1: return (src[0] - dest[0]);
  57. case 2: retval = (src[0] - dest[0]);
  58. if(!retval && src[0])
  59. retval = (src[1] - dest[1]);
  60. return retval;
  61. case 3: retval = (src[0] - dest[0]);
  62. if(!retval && src[0]) {
  63. retval = (src[1] - dest[1]);
  64. if(!retval && src[1])
  65. retval = (src[2] - dest[2]);
  66. }
  67. return retval;
  68. case 4: retval = (src[0] - dest[0]);
  69. if(!retval && src[0]) {
  70. retval = (src[1] - dest[1]);
  71. if(!retval && src[1]) {
  72. retval = (src[2] - dest[2]);
  73. if (!retval && src[2])
  74. retval = (src[3] - dest[3]);
  75. }
  76. }
  77. return retval;
  78. case 5: retval = (src[0] - dest[0]);
  79. if(!retval && src[0]) {
  80. retval = (src[1] - dest[1]);
  81. if(!retval && src[1]) {
  82. retval = (src[2] - dest[2]);
  83. if (!retval && src[2]) {
  84. retval = (src[3] - dest[3]);
  85. if (!retval && src[3])
  86. retval = (src[4] - dest[4]);
  87. }
  88. }
  89. }
  90. return retval;
  91. default:
  92. retval = (src[0] - dest[0]);
  93. if(!retval && src[0]) {
  94. retval = (src[1] - dest[1]);
  95. if(!retval && src[1]) {
  96. retval = (src[2] - dest[2]);
  97. if(!retval && src[2])
  98. retval = __strncmp(src+3,dest+3,count-3);
  99. }
  100. }
  101. return retval;
  102. }
  103. }
  104. #undef strncmp
  105. #define strncmp(__arg0, __arg1, __arg2) \
  106. (__builtin_constant_p(__arg2) ? \
  107. __constant_strncmp(__arg0, __arg1, __arg2) : \
  108. __strncmp(__arg0, __arg1, __arg2))
  109. #endif /* !EXPORT_SYMTAB_STROPS */
  110. #endif /* __KERNEL__ */
  111. #endif /* !(__SPARC_STRING_H__) */