1 --- fread.c.bsdnew 2009-11-11 13:33:09.000000000 -0800
2 +++ fread.c 2009-11-11 14:14:22.000000000 -0800
3 @@ -63,7 +63,7 @@ __fread(void * __restrict buf, size_t si
12 @@ -76,19 +76,66 @@ __fread(void * __restrict buf, size_t si
16 + /* first deal with anything left in buffer, plus any ungetc buffers */
17 while (resid > (r = fp->_r)) {
18 (void)memcpy((void *)p, (void *)fp->_p, (size_t)r);
20 /* fp->_r = 0 ... done in __srefill */
23 - if (__srefill(fp)) {
24 + if ((ret = __srefill0(fp)) > 0)
27 /* no more input: return partial result */
28 return ((total - resid) / size);
31 - (void)memcpy((void *)p, (void *)fp->_p, resid);
35 + * 5980080: don't use optimization if __SMBF not set (meaning setvbuf
36 + * was called, and the buffer belongs to the user).
37 + * 6180417: but for unbuffered (__SMBF is not set), so specifically
40 + if ((fp->_flags & (__SMBF | __SNBF)) && resid > fp->_bf._size) {
46 + fp->_bf._size = resid;
47 + while (fp->_bf._size > 0) {
48 + if ((ret = __srefill1(fp)) != 0) {
49 + /* no more input: return partial result */
50 + resid = fp->_bf._size;
52 + fp->_p = fp->_bf._base;
53 + /* fp->_r = 0; already set in __srefill1 */
54 + return ((total - resid) / size);
56 + fp->_bf._base += fp->_r;
57 + fp->_bf._size -= fp->_r;
60 + n = fp->_bf._size * ((resid - 1) / fp->_bf._size);
62 + (void)memcpy((void *)fp->_bf._base, (void *)(p + n), (size_t)r);
63 + fp->_p = fp->_bf._base + r;
66 + while (resid > (r = fp->_r)) {
67 + (void)memcpy((void *)p, (void *)fp->_p, (size_t)r);
69 + /* fp->_r = 0 ... done in __srefill */
72 + if (__srefill1(fp)) {
73 + /* no more input: return partial result */
74 + return ((total - resid) / size);
77 + (void)memcpy((void *)p, (void *)fp->_p, resid);