summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorSascha Hauer <s.hauer@pengutronix.de>2022-04-21 11:16:09 +0200
committerSascha Hauer <s.hauer@pengutronix.de>2022-04-21 11:16:09 +0200
commit4811863eae2d1e710862e10d7171edbe8041056f (patch)
tree8899ceeff211b381ec7f08e2dc6c8a3d44f4a1e7 /lib
parent7a942b81e4d10b4f729c19b09b5d330bfeb6ba0e (diff)
parentaaac1c35ed14c81a8ffc93874f8b004deae9e172 (diff)
downloadbarebox-4811863eae2d1e710862e10d7171edbe8041056f.tar.gz
Merge branch 'for-next/misc'
Diffstat (limited to 'lib')
-rw-r--r--lib/libfile.c25
1 files changed, 25 insertions, 0 deletions
diff --git a/lib/libfile.c b/lib/libfile.c
index 6b373f05ca..1f533133c5 100644
--- a/lib/libfile.c
+++ b/lib/libfile.c
@@ -76,6 +76,31 @@ int write_full(int fd, const void *buf, size_t size)
EXPORT_SYMBOL(write_full);
/*
+ * pread_full - read to filedescriptor at offset
+ *
+ * Like pread, but this function only returns less bytes than
+ * requested when the end of file is reached.
+ */
+int pread_full(int fd, void *buf, size_t size, loff_t offset)
+{
+ size_t insize = size;
+ int now;
+
+ while (size) {
+ now = pread(fd, buf, size, offset);
+ if (now == 0)
+ break;
+ if (now < 0)
+ return now;
+ size -= now;
+ buf += now;
+ }
+
+ return insize - size;
+}
+EXPORT_SYMBOL(pread_full);
+
+/*
* read_full - read from filedescriptor
*
* Like read, but this function only returns less bytes than