diff options
author | Nick Terrell <terrelln@fb.com> | 2022-10-22 02:00:35 +0300 |
---|---|---|
committer | Nick Terrell <terrelln@fb.com> | 2022-10-22 02:00:35 +0300 |
commit | 14e77332e74603efab8347c89d3cda447c3b97c9 (patch) | |
tree | b7b8a48f4f75590266a763c52e072dda32b228ae /tools/lib/perf/lib.c | |
parent | 88a309465b3f05a100c3b81966982c0f9f5d23a6 (diff) | |
parent | 1d61754caa8c69f566504e63c8b3f3a2df0954c8 (diff) | |
download | linux-14e77332e74603efab8347c89d3cda447c3b97c9.tar.xz |
Merge branch 'main' into zstd-next
Diffstat (limited to 'tools/lib/perf/lib.c')
-rw-r--r-- | tools/lib/perf/lib.c | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/tools/lib/perf/lib.c b/tools/lib/perf/lib.c index 18658931fc71..696fb0ea67c6 100644 --- a/tools/lib/perf/lib.c +++ b/tools/lib/perf/lib.c @@ -38,6 +38,26 @@ ssize_t readn(int fd, void *buf, size_t n) return ion(true, fd, buf, n); } +ssize_t preadn(int fd, void *buf, size_t n, off_t offs) +{ + size_t left = n; + + while (left) { + ssize_t ret = pread(fd, buf, left, offs); + + if (ret < 0 && errno == EINTR) + continue; + if (ret <= 0) + return ret; + + left -= ret; + buf += ret; + offs += ret; + } + + return n; +} + /* * Write exactly 'n' bytes or return an error. */ |