X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Finternal%2Fstdio_impl.h;h=d659522fde90a42e96eaa3f36d837f796f953465;hb=23614b0fcb4cd4d7b2e4148d3b1887b642169765;hp=65dcfbda053968b768f22a79a539e9711157fb1a;hpb=617182734ca0beffa347747019d78b972e2038f9;p=musl diff --git a/src/internal/stdio_impl.h b/src/internal/stdio_impl.h index 65dcfbda..d659522f 100644 --- a/src/internal/stdio_impl.h +++ b/src/internal/stdio_impl.h @@ -2,28 +2,12 @@ #define _STDIO_IMPL_H #include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include #include "syscall.h" #include "libc.h" #define UNGET 8 +#define FFINALLOCK(f) ((f)->lock>=0 ? __lockfile((f)) : 0) #define FLOCK(f) int __need_unlock = ((f)->lock>=0 ? __lockfile((f)) : 0) #define FUNLOCK(f) if (__need_unlock) __unlockfile((f)); else @@ -33,8 +17,9 @@ #define F_EOF 16 #define F_ERR 32 #define F_SVB 64 +#define F_APP 128 -struct __FILE_s { +struct _IO_FILE { unsigned flags; unsigned char *rpos, *rend; int (*close)(FILE *); @@ -61,6 +46,7 @@ struct __FILE_s { void *mustbezero_2; unsigned char *shend; off_t shlim, shcnt; + FILE *prev_locked, *next_locked; }; size_t __stdio_read(FILE *, unsigned char *, size_t); @@ -74,10 +60,10 @@ size_t __string_read(FILE *, unsigned char *, size_t); int __toread(FILE *); int __towrite(FILE *); -int __overflow(FILE *, int); -int __oflow(FILE *); -int __uflow(FILE *); -int __underflow(FILE *); +#if defined(__PIC__) && (100*__GNUC__+__GNUC_MINOR__ >= 303) +__attribute__((visibility("protected"))) +#endif +int __overflow(FILE *, int), __uflow(FILE *); int __fseeko(FILE *, off_t, int); int __fseeko_unlocked(FILE *, off_t, int); @@ -87,6 +73,7 @@ size_t __fwritex(const unsigned char *, size_t, FILE *); int __putc_unlocked(int, FILE *); FILE *__fdopen(int, const char *); +int __fmodeflags(const char *); #define OFLLOCK() LOCK(libc.ofl_lock) #define OFLUNLOCK() UNLOCK(libc.ofl_lock)