diff options
author | Ondřej Bílka <neleai@seznam.cz> | 2013-12-04 02:02:25 +0100 |
---|---|---|
committer | Ondřej Bílka <neleai@seznam.cz> | 2013-12-04 02:41:12 +0100 |
commit | d674f0ef3898c0d1fd5cec76c1c736d9cd9bc7d1 (patch) | |
tree | b6a4f57e8e469c61fb3b81e7903961d50a4203f3 /debug/memmove_chk.c | |
parent | 6905a19f7a8443950f105b6716f6b4b1f98c4dbd (diff) | |
download | glibc-d674f0ef3898c0d1fd5cec76c1c736d9cd9bc7d1.tar.gz glibc-d674f0ef3898c0d1fd5cec76c1c736d9cd9bc7d1.tar.xz glibc-d674f0ef3898c0d1fd5cec76c1c736d9cd9bc7d1.zip |
Refactor several debug routines.
To simplify additions of debug routines we replace a custom function implementation by a simple call.
Diffstat (limited to 'debug/memmove_chk.c')
-rw-r--r-- | debug/memmove_chk.c | 63 |
1 files changed, 1 insertions, 62 deletions
diff --git a/debug/memmove_chk.c b/debug/memmove_chk.c index 3ea34c6d04..6337e76ec2 100644 --- a/debug/memmove_chk.c +++ b/debug/memmove_chk.c @@ -36,66 +36,5 @@ MEMMOVE_CHK (dest, src, len, destlen) if (__builtin_expect (destlen < len, 0)) __chk_fail (); - unsigned long int dstp = (long int) dest; - unsigned long int srcp = (long int) src; - - /* This test makes the forward copying code be used whenever possible. - Reduces the working set. */ - if (dstp - srcp >= len) /* *Unsigned* compare! */ - { - /* Copy from the beginning to the end. */ - - /* If there not too few bytes to copy, use word copy. */ - if (len >= OP_T_THRES) - { - /* Copy just a few bytes to make DSTP aligned. */ - len -= (-dstp) % OPSIZ; - BYTE_COPY_FWD (dstp, srcp, (-dstp) % OPSIZ); - - /* Copy whole pages from SRCP to DSTP by virtual address - manipulation, as much as possible. */ - - PAGE_COPY_FWD_MAYBE (dstp, srcp, len, len); - - /* Copy from SRCP to DSTP taking advantage of the known - alignment of DSTP. Number of bytes remaining is put - in the third argument, i.e. in LEN. This number may - vary from machine to machine. */ - - WORD_COPY_FWD (dstp, srcp, len, len); - - /* Fall out and copy the tail. */ - } - - /* There are just a few bytes to copy. Use byte memory operations. */ - BYTE_COPY_FWD (dstp, srcp, len); - } - else - { - /* Copy from the end to the beginning. */ - srcp += len; - dstp += len; - - /* If there not too few bytes to copy, use word copy. */ - if (len >= OP_T_THRES) - { - /* Copy just a few bytes to make DSTP aligned. */ - len -= dstp % OPSIZ; - BYTE_COPY_BWD (dstp, srcp, dstp % OPSIZ); - - /* Copy from SRCP to DSTP taking advantage of the known - alignment of DSTP. Number of bytes remaining is put - in the third argument, i.e. in LEN. This number may - vary from machine to machine. */ - - WORD_COPY_BWD (dstp, srcp, len, len); - - /* Fall out and copy the tail. */ - } - - /* There are just a few bytes to copy. Use byte memory operations. */ - BYTE_COPY_BWD (dstp, srcp, len); - } - - return dest; + return memmove (dest, src, len); } |