major stdio overhaul, using readv/writev, plus other changes
authorRich Felker <dalias@aerifal.cx>
Mon, 28 Mar 2011 05:14:44 +0000 (01:14 -0400)
committerRich Felker <dalias@aerifal.cx>
Mon, 28 Mar 2011 05:14:44 +0000 (01:14 -0400)
commite3cd6c5c265cd481db6e0c5b529855d99f0bda30
tree85d2c586e4ea8e261ed68cc4b1901a1711774441
parentea343364a719add2cd8adf8a50c15bb5f9400dd8
major stdio overhaul, using readv/writev, plus other changes

the biggest change in this commit is that stdio now uses readv to fill
the caller's buffer and the FILE buffer with a single syscall, and
likewise writev to flush the FILE buffer and write out the caller's
buffer in a single syscall.

making this change required fundamental architectural changes to
stdio, so i also made a number of other improvements in the process:

- the implementation no longer assumes that further io will fail
  following errors, and no longer blocks io when the error flag is set
  (though the latter could easily be changed back if desired)

- unbuffered mode is no longer implemented as a one-byte buffer. as a
  consequence, scanf unreading has to use ungetc, to the unget buffer
  has been enlarged to hold at least 2 wide characters.

- the FILE structure has been rearranged to maintain the locations of
  the fields that might be used in glibc getc/putc type macros, while
  shrinking the structure to save some space.

- error cases for fflush, fseek, etc. should be more correct.

- library-internal macros are used for getc_unlocked and putc_unlocked
  now, eliminating some ugly code duplication. __uflow and __overflow
  are no longer used anywhere but these macros. switch to read or
  write mode is also separated so the code can be better shared, e.g.
  with ungetc.

- lots of other small things.
37 files changed:
src/exit/exit.c
src/internal/stdio_impl.h
src/stdio/__overflow.c
src/stdio/__stdio_read.c
src/stdio/__stdio_seek.c
src/stdio/__stdio_write.c
src/stdio/__stdout_write.c [new file with mode: 0644]
src/stdio/__toread.c [new file with mode: 0644]
src/stdio/__towrite.c [new file with mode: 0644]
src/stdio/__uflow.c
src/stdio/__underflow.c [deleted file]
src/stdio/fflush.c
src/stdio/fgetc.c
src/stdio/fgets.c
src/stdio/fgetwc.c
src/stdio/fputc.c
src/stdio/fputwc.c
src/stdio/fread.c
src/stdio/fseek.c
src/stdio/fwrite.c
src/stdio/getc.c [deleted file]
src/stdio/getc_unlocked.c
src/stdio/getchar_unlocked.c
src/stdio/getdelim.c
src/stdio/putc.c [deleted file]
src/stdio/putc_unlocked.c
src/stdio/putchar_unlocked.c
src/stdio/setvbuf.c
src/stdio/stderr.c
src/stdio/stdout.c
src/stdio/ungetc.c
src/stdio/ungetwc.c
src/stdio/vdprintf.c
src/stdio/vfprintf.c
src/stdio/vfscanf.c
src/stdio/vsnprintf.c
src/stdio/vswprintf.c