[U-Boot] [PATCH 1/5 v2] sandbox: add lseek helper
Simon Glass
sjg at chromium.org
Thu Feb 2 00:37:27 CET 2012
Hi Mike,
On Tue, Jan 31, 2012 at 11:53 AM, Mike Frysinger <vapier at gentoo.org> wrote:
> Follow up patches want to be able to seek fd's.
>
> Signed-off-by: Mike Frysinger <vapier at gentoo.org>
> ---
> arch/sandbox/cpu/os.c | 13 +++++++++++++
> include/os.h | 15 +++++++++++++++
> 2 files changed, 28 insertions(+), 0 deletions(-)
>
> diff --git a/arch/sandbox/cpu/os.c b/arch/sandbox/cpu/os.c
> index 093e7dc..13331d2 100644
> --- a/arch/sandbox/cpu/os.c
> +++ b/arch/sandbox/cpu/os.c
> @@ -45,6 +45,19 @@ ssize_t os_write(int fd, const void *buf, size_t count)
> return write(fd, buf, count);
> }
>
> +off_t os_lseek(int fd, off_t offset, int whence)
> +{
> + if (whence == OS_SEEK_SET)
> + whence = SEEK_SET;
> + else if (whence == OS_SEEK_CUR)
> + whence = SEEK_CUR;
> + else if (whence == OS_SEEK_END)
> + whence = SEEK_END;
I suppose this is safest.
> + else
> + printf("%s: invalid whence value %i\n", __func__, whence);
> + return lseek(fd, offset, whence);
> +}
> +
> int os_open(const char *pathname, int flags)
> {
> return open(pathname, flags);
> diff --git a/include/os.h b/include/os.h
> index c17a8a5..11017b7 100644
> --- a/include/os.h
> +++ b/include/os.h
> @@ -49,6 +49,21 @@ ssize_t os_read(int fd, void *buf, size_t count);
> ssize_t os_write(int fd, const void *buf, size_t count);
>
> /**
> + * Access to the OS lseek() system call
> + *
> + * \param fd File descriptor as returned by os_open()
> + * \param offset File offset (based on whence)
> + * \param whence Position offset is relative to (see below)
> + * \return new file offset
> + */
> +off_t os_lseek(int fd, off_t offset, int whence);
> +
> +/* Defines for "whence" in os_lseek() */
> +#define OS_SEEK_SET 0
> +#define OS_SEEK_CUR 0
> +#define OS_SEEK_END 0
0, 1, 2?
> +
> +/**
> * Access to the OS open() system call
> *
> * \param pathname Pathname of file to open
> --
> 1.7.8.4
>
> _______________________________________________
> U-Boot mailing list
> U-Boot at lists.denx.de
> http://lists.denx.de/mailman/listinfo/u-boot
Regards,
Simon
More information about the U-Boot
mailing list