X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Faio%2Flio_listio.c;h=7b6a03d3c1f7d1edf3197c53d19146dd0563dc2b;hb=db505b794c697631f65e6b91ff106496debb86ac;hp=53f9f502ab4e994da2fa61c3c8a1a46045fe9d05;hpb=c6d441e3a246370d9c459396ec22b096db93850e;p=musl diff --git a/src/aio/lio_listio.c b/src/aio/lio_listio.c index 53f9f502..7b6a03d3 100644 --- a/src/aio/lio_listio.c +++ b/src/aio/lio_listio.c @@ -1,6 +1,5 @@ #include #include -#include #include #include #include "pthread_impl.h" @@ -13,7 +12,7 @@ struct lio_state { static int lio_wait(struct lio_state *st) { - int i, err, got_err; + int i, err, got_err = 0; int cnt = st->cnt; struct aiocb **cbs = st->cbs; @@ -44,7 +43,7 @@ static void notify_signal(struct sigevent *sev) .si_signo = sev->sigev_signo, .si_value = sev->sigev_value, .si_code = SI_ASYNCIO, - .si_pid = __pthread_self()->pid, + .si_pid = getpid(), .si_uid = getuid() }; __syscall(SYS_rt_sigqueueinfo, si.si_pid, si.si_signo, &si); @@ -67,7 +66,7 @@ static void *wait_thread(void *p) return 0; } -int lio_listio(int mode, struct aiocb *restrict const cbs[restrict], int cnt, struct sigevent *restrict sev) +int lio_listio(int mode, struct aiocb *restrict const *restrict cbs, int cnt, struct sigevent *restrict sev) { int i, ret; struct lio_state *st=0; @@ -109,7 +108,7 @@ int lio_listio(int mode, struct aiocb *restrict const cbs[restrict], int cnt, st if (mode == LIO_WAIT) { ret = lio_wait(st); free(st); - return 0; + return ret; } if (st) { @@ -141,3 +140,4 @@ int lio_listio(int mode, struct aiocb *restrict const cbs[restrict], int cnt, st return 0; } +weak_alias(lio_listio, lio_listio64);