memset.c 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. /* Copyright (C) 1991,1993,1995,1997,1998,2003,2004
  2. Free Software Foundation, Inc.
  3. This file is part of the GNU C Library.
  4. Contributed by Torbjorn Granlund (tege@sics.se).
  5. The GNU C Library is free software; you can redistribute it and/or
  6. modify it under the terms of the GNU Lesser General Public
  7. License as published by the Free Software Foundation; either
  8. version 2.1 of the License, or (at your option) any later version.
  9. The GNU C Library is distributed in the hope that it will be useful,
  10. but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  12. Lesser General Public License for more details.
  13. You should have received a copy of the GNU Lesser General Public
  14. License along with the GNU C Library; if not, write to the Free
  15. Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
  16. 02111-1307 USA. */
  17. #include "api.h"
  18. #define op_t unsigned long int
  19. #define OPSIZ (sizeof(op_t))
  20. typedef unsigned char byte;
  21. void* memset(void* dstpp, int c, size_t len) {
  22. long int dstp = (long int)dstpp;
  23. if (len >= 8) {
  24. int xlen;
  25. op_t cccc;
  26. cccc = (unsigned char)c;
  27. cccc |= cccc << 8;
  28. cccc |= cccc << 16;
  29. if (OPSIZ > 4) {
  30. /* Do the shift in two steps to avoid warning if long has 32 bits. */
  31. cccc |= (cccc << 16) << 16;
  32. }
  33. /* There are at least some bytes to set.
  34. No need to test for LEN == 0 in this alignment loop. */
  35. while (dstp % OPSIZ != 0) {
  36. ((byte*)dstp)[0] = c;
  37. dstp += 1;
  38. len -= 1;
  39. }
  40. /* Write 8 `op_t' per iteration until less than 8 `op_t' remain. */
  41. xlen = len / (OPSIZ * 8);
  42. while (xlen > 0) {
  43. ((op_t*)dstp)[0] = cccc;
  44. ((op_t*)dstp)[1] = cccc;
  45. ((op_t*)dstp)[2] = cccc;
  46. ((op_t*)dstp)[3] = cccc;
  47. ((op_t*)dstp)[4] = cccc;
  48. ((op_t*)dstp)[5] = cccc;
  49. ((op_t*)dstp)[6] = cccc;
  50. ((op_t*)dstp)[7] = cccc;
  51. dstp += 8 * OPSIZ;
  52. xlen -= 1;
  53. }
  54. len %= OPSIZ * 8;
  55. /* Write 1 `op_t' per iteration until less than OPSIZ bytes remain. */
  56. xlen = len / OPSIZ;
  57. while (xlen > 0) {
  58. ((op_t*)dstp)[0] = cccc;
  59. dstp += OPSIZ;
  60. xlen -= 1;
  61. }
  62. len %= OPSIZ;
  63. }
  64. /* Write the last few bytes. */
  65. while (len > 0) {
  66. ((byte*)dstp)[0] = c;
  67. dstp += 1;
  68. len -= 1;
  69. }
  70. return dstpp;
  71. }