2015-01-31 11:13:50 +08:00
|
|
|
/*
|
2021-03-08 18:19:04 +08:00
|
|
|
* Copyright (c) 2006-2021, RT-Thread Development Team
|
2015-01-31 11:13:50 +08:00
|
|
|
*
|
2018-10-14 19:28:18 +08:00
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
2015-01-31 11:13:50 +08:00
|
|
|
*
|
|
|
|
* Change Logs:
|
|
|
|
* Date Author Notes
|
|
|
|
* 2015-01-28 Bernard first version
|
|
|
|
*/
|
|
|
|
#include <rtthread.h>
|
2021-11-13 05:47:32 +08:00
|
|
|
#include <LowLevelIOInterface.h>
|
2021-10-26 12:51:32 +08:00
|
|
|
#include <unistd.h>
|
2015-01-31 11:13:50 +08:00
|
|
|
|
2021-11-13 23:16:31 +08:00
|
|
|
/*
|
|
|
|
* The "__lseek" function makes the next file operation (__read or
|
|
|
|
* __write) act on a new location. The parameter "whence" specifies
|
|
|
|
* how the "offset" parameter should be interpreted according to the
|
|
|
|
* following table:
|
|
|
|
*
|
|
|
|
* 0 (=SEEK_SET) - Goto location "offset".
|
|
|
|
* 1 (=SEEK_CUR) - Go "offset" bytes from the current location.
|
|
|
|
* 2 (=SEEK_END) - Go to "offset" bytes from the end.
|
|
|
|
*
|
|
|
|
* This function should return the current file position, or -1 on
|
|
|
|
* failure.
|
|
|
|
*/
|
|
|
|
|
2015-01-31 11:13:50 +08:00
|
|
|
#pragma module_name = "?__lseek"
|
2021-11-13 23:16:31 +08:00
|
|
|
|
2015-01-31 11:13:50 +08:00
|
|
|
long __lseek(int handle, long offset, int whence)
|
|
|
|
{
|
|
|
|
if (handle == _LLIO_STDOUT ||
|
|
|
|
handle == _LLIO_STDERR ||
|
|
|
|
handle == _LLIO_STDIN)
|
|
|
|
return _LLIO_ERROR;
|
2021-11-16 00:22:49 +08:00
|
|
|
#ifdef DFS_USING_POSIX
|
2017-10-15 22:41:59 +08:00
|
|
|
return lseek(handle, offset, whence);
|
2015-01-31 21:59:58 +08:00
|
|
|
#else
|
|
|
|
return _LLIO_ERROR;
|
2021-11-16 00:22:49 +08:00
|
|
|
#endif /* DFS_USING_POSIX */
|
2015-01-31 11:13:50 +08:00
|
|
|
}
|