LibC: fix fread implementation
fread() should read until either size*nitems bytes are read or eof is reached.
This commit is contained in:
parent
41757b5f6c
commit
5972c73950
|
@ -255,15 +255,26 @@ size_t fread(void* buffer, size_t size, size_t nitems, FILE* file)
|
||||||
{
|
{
|
||||||
if (file->eof || nitems * size == 0)
|
if (file->eof || nitems * size == 0)
|
||||||
return 0;
|
return 0;
|
||||||
long ret = syscall(SYS_READ, file->fd, buffer, size * nitems);
|
|
||||||
if (ret < 0)
|
size_t target = size * nitems;
|
||||||
|
size_t nread = 0;
|
||||||
|
|
||||||
|
while (nread < target)
|
||||||
{
|
{
|
||||||
file->error = true;
|
size_t ret = syscall(SYS_READ, file->fd, (uint8_t*)buffer + nread, target - nread);
|
||||||
return 0;
|
|
||||||
|
if (ret < 0)
|
||||||
|
file->error = true;
|
||||||
|
else if (ret == 0)
|
||||||
|
file->eof = true;
|
||||||
|
|
||||||
|
if (ret <= 0)
|
||||||
|
return nread;
|
||||||
|
|
||||||
|
nread += ret;
|
||||||
}
|
}
|
||||||
if (ret == 0)
|
|
||||||
file->eof = true;
|
return nread / size;
|
||||||
return ret / size;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO
|
// TODO
|
||||||
|
|
Loading…
Reference in New Issue