diff options
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | libio/fileops.c | 19 |
2 files changed, 9 insertions, 15 deletions
diff --git a/ChangeLog b/ChangeLog index 165a178076..ec220266a4 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +2012-03-29 David S. Miller <davem@davemloft.net> + + * libio/fileops.c (_IO_new_file_xsputn): Don't try to optimize + small copies by hand. + 2012-03-28 Siddhesh Poyarekar <siddhesh@redhat.com> [BZ #13761] diff --git a/libio/fileops.c b/libio/fileops.c index 95e09b4400..a2e8dacd77 100644 --- a/libio/fileops.c +++ b/libio/fileops.c @@ -1341,24 +1341,13 @@ _IO_new_file_xsputn (f, data, n) { if (count > to_do) count = to_do; - if (count > 20) - { #ifdef _LIBC - f->_IO_write_ptr = __mempcpy (f->_IO_write_ptr, s, count); + f->_IO_write_ptr = __mempcpy (f->_IO_write_ptr, s, count); #else - memcpy (f->_IO_write_ptr, s, count); - f->_IO_write_ptr += count; + memcpy (f->_IO_write_ptr, s, count); + f->_IO_write_ptr += count; #endif - s += count; - } - else - { - register char *p = f->_IO_write_ptr; - register int i = (int) count; - while (--i >= 0) - *p++ = *s++; - f->_IO_write_ptr = p; - } + s += count; to_do -= count; } if (to_do + must_flush > 0) |