NewLib:
- Added basic support for dirent.h; - Added memory.h for compatibility; - Added ftruncate() function; - Fixed date and time structures in ksys_file_info_t. git-svn-id: svn://kolibrios.org@9954 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
d91cb7946f
commit
6e3276cb4b
@ -133,6 +133,7 @@ CORE_SRCS:= \
|
|||||||
sys/unlink.c \
|
sys/unlink.c \
|
||||||
sys/write.c \
|
sys/write.c \
|
||||||
sys/io_alloc.S \
|
sys/io_alloc.S \
|
||||||
|
sys/ftruncate.c \
|
||||||
time/asctime.c \
|
time/asctime.c \
|
||||||
time/asctime_r.c \
|
time/asctime_r.c \
|
||||||
time/clock.c \
|
time/clock.c \
|
||||||
@ -508,6 +509,13 @@ MATH_SRCS = e_acos.c e_acosh.c e_asin.c e_atan2.c e_atanh.c e_cosh.c e_exp.c e_
|
|||||||
f_log10.S f_log10f.S f_logf.S f_tan.S f_tanf.S
|
f_log10.S f_log10f.S f_logf.S f_tan.S f_tanf.S
|
||||||
|
|
||||||
|
|
||||||
|
POSIX_SRCS = opendir.c \
|
||||||
|
closedir.c \
|
||||||
|
readdir.c \
|
||||||
|
seekdir.c \
|
||||||
|
telldir.c \
|
||||||
|
rewinddir.c
|
||||||
|
|
||||||
STATIC_OBJS = $(patsubst %.S, %.o, $(patsubst %.c, %.o, $(STATIC_SRCS)))
|
STATIC_OBJS = $(patsubst %.S, %.o, $(patsubst %.c, %.o, $(STATIC_SRCS)))
|
||||||
|
|
||||||
LIBCRT_OBJS = $(patsubst %.S, %.o, $(patsubst %.c, %.o, $(LIBCRT_SRCS)))
|
LIBCRT_OBJS = $(patsubst %.S, %.o, $(patsubst %.c, %.o, $(LIBCRT_SRCS)))
|
||||||
@ -531,6 +539,7 @@ STDLIB_OBJS = $(patsubst %.S, stdlib/%.o, $(patsubst %.asm, stdlib/%.o,\
|
|||||||
MATH_OBJS = $(patsubst %.S, math/%.o, $(patsubst %.asm, math/%.o,\
|
MATH_OBJS = $(patsubst %.S, math/%.o, $(patsubst %.asm, math/%.o,\
|
||||||
$(patsubst %.c, math/%.o, $(MATH_SRCS))))
|
$(patsubst %.c, math/%.o, $(MATH_SRCS))))
|
||||||
|
|
||||||
|
POSIX_OBJS = $(patsubst %.c, posix/%.o, $(POSIX_SRCS))
|
||||||
|
|
||||||
PRINTF_OBJS= stdio/vfprintf.o \
|
PRINTF_OBJS= stdio/vfprintf.o \
|
||||||
stdio/vfiprintf.o \
|
stdio/vfiprintf.o \
|
||||||
@ -563,7 +572,8 @@ LIB_SRCS+= \
|
|||||||
$(CORE_SRCS) \
|
$(CORE_SRCS) \
|
||||||
$(STDIO_SRCS) \
|
$(STDIO_SRCS) \
|
||||||
$(STRING_SRCS) \
|
$(STRING_SRCS) \
|
||||||
$(STDLIB_SRCS)
|
$(STDLIB_SRCS) \
|
||||||
|
$(POSIX_SRCS)
|
||||||
|
|
||||||
LIB_OBJS+= \
|
LIB_OBJS+= \
|
||||||
$(CORE_OBJS) \
|
$(CORE_OBJS) \
|
||||||
@ -572,7 +582,7 @@ LIB_OBJS+= \
|
|||||||
$(STDIO_OBJS) \
|
$(STDIO_OBJS) \
|
||||||
$(PRINTF_OBJS) \
|
$(PRINTF_OBJS) \
|
||||||
$(MATH_OBJS) \
|
$(MATH_OBJS) \
|
||||||
$(DIRENT_OBJS)
|
$(POSIX_OBJS)
|
||||||
|
|
||||||
LIB_OBJS+= time/wcsftime.o
|
LIB_OBJS+= time/wcsftime.o
|
||||||
|
|
||||||
|
@ -116,6 +116,7 @@ CORE_SRCS = {
|
|||||||
"sys/unlink.c",
|
"sys/unlink.c",
|
||||||
"sys/write.c",
|
"sys/write.c",
|
||||||
"sys/io_alloc.S",
|
"sys/io_alloc.S",
|
||||||
|
"sys/ftruncate.c",
|
||||||
"time/asctime.c",
|
"time/asctime.c",
|
||||||
"time/asctime_r.c",
|
"time/asctime_r.c",
|
||||||
"time/clock.c",
|
"time/clock.c",
|
||||||
@ -453,6 +454,14 @@ STDIO_SRCS = {
|
|||||||
"wscanf.c",
|
"wscanf.c",
|
||||||
"wsetup.c"
|
"wsetup.c"
|
||||||
}
|
}
|
||||||
|
POSIX_SRCS = {
|
||||||
|
"opendir.c",
|
||||||
|
"closedir.c",
|
||||||
|
"readdir.c",
|
||||||
|
"seekdir.c",
|
||||||
|
"telldir.c",
|
||||||
|
"rewinddir.c"
|
||||||
|
}
|
||||||
|
|
||||||
MATH_SRCS = {
|
MATH_SRCS = {
|
||||||
"e_acos.c", "e_acosh.c", "e_asin.c", "e_atan2.c", "e_atanh.c", "e_cosh.c", "e_exp.c", "e_fmod.c",
|
"e_acos.c", "e_acosh.c", "e_asin.c", "e_atan2.c", "e_atanh.c", "e_cosh.c", "e_exp.c", "e_fmod.c",
|
||||||
@ -505,6 +514,7 @@ LIB_SRCS += CORE_SRCS
|
|||||||
LIB_SRCS += prepend("stdio/", STDIO_SRCS)
|
LIB_SRCS += prepend("stdio/", STDIO_SRCS)
|
||||||
LIB_SRCS += prepend("string/", STRING_SRCS)
|
LIB_SRCS += prepend("string/", STRING_SRCS)
|
||||||
LIB_SRCS += prepend("stdlib/", STDLIB_SRCS)
|
LIB_SRCS += prepend("stdlib/", STDLIB_SRCS)
|
||||||
|
LIB_SRCS += prepend("posix/", POSIX_SRCS)
|
||||||
LIB_SRCS += prepend("math/", MATH_SRCS)
|
LIB_SRCS += prepend("math/", MATH_SRCS)
|
||||||
|
|
||||||
ALL_OBJS = {}
|
ALL_OBJS = {}
|
||||||
|
41
contrib/sdk/sources/newlib/libc/include/dirent.h
Normal file
41
contrib/sdk/sources/newlib/libc/include/dirent.h
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) KolibriOS team 2024. All rights reserved.
|
||||||
|
* Distributed under terms of the GNU General Public License
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _DIRENT_H_
|
||||||
|
#define _DIRENT_H_
|
||||||
|
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/cdefs.h>
|
||||||
|
#include <sys/ksys.h>
|
||||||
|
|
||||||
|
_BEGIN_STD_C
|
||||||
|
|
||||||
|
#define DT_UNKNOWN 0
|
||||||
|
#define DT_DIR 4
|
||||||
|
#define DT_REG 8
|
||||||
|
|
||||||
|
struct dirent {
|
||||||
|
ino_t d_ino;
|
||||||
|
unsigned d_type;
|
||||||
|
char d_name[KSYS_FNAME_UTF8_SIZE];
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
char* path;
|
||||||
|
uint32_t pos;
|
||||||
|
struct dirent last_entry;
|
||||||
|
} DIR;
|
||||||
|
|
||||||
|
DIR* _DEFUN(opendir, (name), const char *name);
|
||||||
|
int _DEFUN(closedir, (dirp), register DIR *dirp);
|
||||||
|
void _DEFUN(seekdir, (dirp, loc), DIR *dirp _AND long loc);
|
||||||
|
void _DEFUN(rewinddir, (dirp), DIR *dirp);
|
||||||
|
long _DEFUN(telldir, (dirp), DIR *dirp);
|
||||||
|
|
||||||
|
struct dirent *_DEFUN(readdir, (dirp), register DIR *dirp);
|
||||||
|
|
||||||
|
_END_STD_C
|
||||||
|
|
||||||
|
#endif /* _DIRENT_H_ */
|
11
contrib/sdk/sources/newlib/libc/include/memory.h
Normal file
11
contrib/sdk/sources/newlib/libc/include/memory.h
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) KolibriOS team 2024. All rights reserved.
|
||||||
|
* Distributed under terms of the GNU General Public License
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _MEMORY_H_
|
||||||
|
#define _MEMORY_H_
|
||||||
|
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
#endif // _MEMORY_H_
|
@ -48,7 +48,7 @@ typedef union {
|
|||||||
uint8_t sec;
|
uint8_t sec;
|
||||||
uint8_t _zero;
|
uint8_t _zero;
|
||||||
};
|
};
|
||||||
} ksys_time_t;
|
} ksys_time_bcd_t;
|
||||||
|
|
||||||
typedef union {
|
typedef union {
|
||||||
uint32_t val;
|
uint32_t val;
|
||||||
@ -58,7 +58,7 @@ typedef union {
|
|||||||
uint8_t day;
|
uint8_t day;
|
||||||
uint8_t _zero;
|
uint8_t _zero;
|
||||||
};
|
};
|
||||||
} ksys_date_t;
|
} ksys_date_bcd_t;
|
||||||
|
|
||||||
typedef union {
|
typedef union {
|
||||||
uint32_t val;
|
uint32_t val;
|
||||||
@ -93,6 +93,7 @@ typedef struct {
|
|||||||
};
|
};
|
||||||
union {
|
union {
|
||||||
uint32_t flags;
|
uint32_t flags;
|
||||||
|
uint32_t enc_name;
|
||||||
char* args;
|
char* args;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
@ -113,19 +114,47 @@ typedef struct {
|
|||||||
uint32_t rw_bytes;
|
uint32_t rw_bytes;
|
||||||
} ksys_file_status_t;
|
} ksys_file_status_t;
|
||||||
|
|
||||||
|
#define KSYS_FNAME_UTF8_SIZE 520
|
||||||
|
#define KSYS_FNAME_CP866_SIZE 264
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
uint8_t sec;
|
||||||
|
uint8_t min;
|
||||||
|
uint8_t hour;
|
||||||
|
uint8_t _zero;
|
||||||
|
} ksys_ftime_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
uint8_t day;
|
||||||
|
uint8_t month;
|
||||||
|
uint16_t year;
|
||||||
|
} ksys_fdate_t;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
uint32_t attr;
|
uint32_t attr;
|
||||||
uint32_t name_enc;
|
uint32_t name_enc;
|
||||||
ksys_time_t ctime;
|
ksys_ftime_t ctime;
|
||||||
ksys_date_t cdate;
|
ksys_fdate_t cdate;
|
||||||
ksys_time_t atime;
|
ksys_ftime_t atime;
|
||||||
ksys_date_t adate;
|
ksys_fdate_t adate;
|
||||||
ksys_time_t mtime;
|
ksys_ftime_t mtime;
|
||||||
ksys_date_t mdate;
|
ksys_fdate_t mdate;
|
||||||
uint64_t size;
|
uint64_t size;
|
||||||
char name[0];
|
char name[0];
|
||||||
} ksys_file_info_t;
|
} ksys_file_info_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
uint32_t version;
|
||||||
|
uint32_t blocks;
|
||||||
|
uint32_t files;
|
||||||
|
uint8_t __reserved[20];
|
||||||
|
} ksys_dir_entry_header_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
ksys_dir_entry_header_t header;
|
||||||
|
ksys_file_info_t info;
|
||||||
|
} ksys_dir_entry_t;
|
||||||
|
|
||||||
#define KSYS_THREAD_INFO_SIZE 1024
|
#define KSYS_THREAD_INFO_SIZE 1024
|
||||||
|
|
||||||
typedef union {
|
typedef union {
|
||||||
@ -424,15 +453,15 @@ KOSAPI ksys_oskey_t _ksys_get_key(void)
|
|||||||
|
|
||||||
/*==================== Function 3 - get system time. ===================*/
|
/*==================== Function 3 - get system time. ===================*/
|
||||||
|
|
||||||
KOSAPI ksys_time_t _ksys_get_time(void)
|
KOSAPI ksys_time_bcd_t _ksys_get_time(void)
|
||||||
{
|
{
|
||||||
ksys_time_t c_time;
|
ksys_time_bcd_t bcd_time;
|
||||||
asm_inline(
|
asm_inline(
|
||||||
"int $0x40"
|
"int $0x40"
|
||||||
: "=a"(c_time)
|
: "=a"(bcd_time)
|
||||||
: "a"(3)
|
: "a"(3)
|
||||||
: "memory");
|
: "memory");
|
||||||
return c_time;
|
return bcd_time;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*=================== Function 4 - draw text string. ===================*/
|
/*=================== Function 4 - draw text string. ===================*/
|
||||||
@ -866,14 +895,14 @@ KOSAPI uint64_t _ksys_get_ns_count(void)
|
|||||||
|
|
||||||
/*=================== Function 29 - get system date. ===================*/
|
/*=================== Function 29 - get system date. ===================*/
|
||||||
|
|
||||||
KOSAPI ksys_date_t _ksys_get_date(void)
|
KOSAPI ksys_date_bcd_t _ksys_get_date(void)
|
||||||
{
|
{
|
||||||
ksys_date_t val;
|
ksys_date_bcd_t bcd_date;
|
||||||
asm_inline(
|
asm_inline(
|
||||||
"int $0x40"
|
"int $0x40"
|
||||||
: "=a"(val)
|
: "=a"(bcd_date)
|
||||||
: "a"(29));
|
: "a"(29));
|
||||||
return val;
|
return bcd_date;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*===========+ Function 30 - work with the current folder.==============*/
|
/*===========+ Function 30 - work with the current folder.==============*/
|
||||||
@ -1528,6 +1557,20 @@ KOSAPI ksys_file_status_t _ksys_file_read(const char* name, uint64_t offset, uin
|
|||||||
return _ksys_file(&f);
|
return _ksys_file(&f);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
KOSAPI ksys_file_status_t _ksys_file_read_dir(const char* name, uint32_t offset,
|
||||||
|
uint32_t enc, uint32_t blocks, void* buff)
|
||||||
|
{
|
||||||
|
ksys_file_t f;
|
||||||
|
f.func_num = KSYS_FILE_READ_DIR;
|
||||||
|
f.offset = offset;
|
||||||
|
f.enc_name = enc;
|
||||||
|
f.data_size = blocks;
|
||||||
|
f.data = buff;
|
||||||
|
f.zero = 0;
|
||||||
|
f.path_ptr = (char*)name;
|
||||||
|
return _ksys_file(&f);
|
||||||
|
}
|
||||||
|
|
||||||
/*===================== Function 70, subfunction 2 =====================*/
|
/*===================== Function 70, subfunction 2 =====================*/
|
||||||
/*============ Create/rewrite file with long names support. ============*/
|
/*============ Create/rewrite file with long names support. ============*/
|
||||||
|
|
||||||
@ -1574,6 +1617,15 @@ KOSAPI int _ksys_file_set_size(const char* name, uint64_t size)
|
|||||||
|
|
||||||
/*========== Function 70, subfunction 5 - get information on file/folder. =====*/
|
/*========== Function 70, subfunction 5 - get information on file/folder. =====*/
|
||||||
|
|
||||||
|
enum KSYS_FILE_ATTR {
|
||||||
|
KSYS_FILE_ATTR_RO = 0x1,
|
||||||
|
KSYS_FILE_ATTR_HIDDEN = 0x2,
|
||||||
|
KSYS_FILE_ATTR_SYS = 0x4,
|
||||||
|
KSYS_FILE_ATTR_VOL_LABEL = 0x8,
|
||||||
|
KSYS_FILE_ATTR_DIR = 0x10,
|
||||||
|
KSYS_FILE_ATTR_ARCHIVE = 0x20
|
||||||
|
};
|
||||||
|
|
||||||
KOSAPI int _ksys_file_info(const char* name, ksys_file_info_t* info)
|
KOSAPI int _ksys_file_info(const char* name, ksys_file_info_t* info)
|
||||||
{
|
{
|
||||||
ksys_file_t f;
|
ksys_file_t f;
|
||||||
@ -1624,6 +1676,8 @@ KOSAPI int _ksys_file_delete(const char* path)
|
|||||||
return _ksys_file(&f).status;
|
return _ksys_file(&f).status;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define _ksys_rmdir(x) _ksys_file_delete(x)
|
||||||
|
|
||||||
/*============= Function 70, subfunction 9 - create folder. =============*/
|
/*============= Function 70, subfunction 9 - create folder. =============*/
|
||||||
|
|
||||||
KOSAPI int _ksys_mkdir(const char* path)
|
KOSAPI int _ksys_mkdir(const char* path)
|
||||||
|
@ -10,10 +10,11 @@ extern "C" {
|
|||||||
#define __need_ptrdiff_t
|
#define __need_ptrdiff_t
|
||||||
#include <sys/cdefs.h>
|
#include <sys/cdefs.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
|
#include <sys/ksys.h>
|
||||||
#include <sys/_types.h>
|
#include <sys/_types.h>
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
|
|
||||||
extern char **environ;
|
//extern char **environ;
|
||||||
|
|
||||||
void _EXFUN(_exit, (int __status ) _ATTRIBUTE ((__noreturn__)));
|
void _EXFUN(_exit, (int __status ) _ATTRIBUTE ((__noreturn__)));
|
||||||
|
|
||||||
@ -165,7 +166,7 @@ _READ_WRITE_RETURN_TYPE _EXFUN(read, (int __fd, void *__buf, size_t __nbyte ));
|
|||||||
int _EXFUN(rresvport, (int *__alport));
|
int _EXFUN(rresvport, (int *__alport));
|
||||||
int _EXFUN(revoke, (char *__path));
|
int _EXFUN(revoke, (char *__path));
|
||||||
#endif
|
#endif
|
||||||
int _EXFUN(rmdir, (const char *__path ));
|
#define rmdir(__path) _ksys_rmdir(__path)
|
||||||
#if __BSD_VISIBLE
|
#if __BSD_VISIBLE
|
||||||
int _EXFUN(ruserok, (const char *rhost, int superuser, const char *ruser, const char *luser));
|
int _EXFUN(ruserok, (const char *rhost, int superuser, const char *ruser, const char *luser));
|
||||||
#endif
|
#endif
|
||||||
@ -244,11 +245,12 @@ int _EXFUN(_execve, (const char *__path, char * const __argv[], char * const
|
|||||||
|
|
||||||
#if defined(__CYGWIN__) || defined(__rtems__) || defined(__aarch64__) || defined (__arm__) || defined(__sh__) || defined(__SPU__)
|
#if defined(__CYGWIN__) || defined(__rtems__) || defined(__aarch64__) || defined (__arm__) || defined(__sh__) || defined(__SPU__)
|
||||||
#if !defined(__INSIDE_CYGWIN__)
|
#if !defined(__INSIDE_CYGWIN__)
|
||||||
int _EXFUN(ftruncate, (int __fd, off_t __length));
|
|
||||||
int _EXFUN(truncate, (const char *, off_t __length));
|
int _EXFUN(truncate, (const char *, off_t __length));
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
int _EXFUN(ftruncate, (int __fd, off_t __length));
|
||||||
|
|
||||||
#if defined(__CYGWIN__) || defined(__rtems__)
|
#if defined(__CYGWIN__) || defined(__rtems__)
|
||||||
int _EXFUN(getdtablesize, (void));
|
int _EXFUN(getdtablesize, (void));
|
||||||
int _EXFUN(setdtablesize, (int));
|
int _EXFUN(setdtablesize, (int));
|
||||||
|
24
contrib/sdk/sources/newlib/libc/sys/ftruncate.c
Normal file
24
contrib/sdk/sources/newlib/libc/sys/ftruncate.c
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
|
||||||
|
#include <errno.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/ksys.h>
|
||||||
|
#include "glue.h"
|
||||||
|
#include "io.h"
|
||||||
|
|
||||||
|
int
|
||||||
|
_DEFUN (ftruncate, (fd, len),
|
||||||
|
int fd _AND
|
||||||
|
off_t len)
|
||||||
|
{
|
||||||
|
__io_handle *ioh;
|
||||||
|
if ((fd < 0) || (fd >=64))
|
||||||
|
{
|
||||||
|
errno = EBADF;
|
||||||
|
return (-1);
|
||||||
|
}
|
||||||
|
ioh = &__io_tab[fd];
|
||||||
|
if (_ksys_file_set_size(ioh->name, len))
|
||||||
|
return (-1);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
@ -27,7 +27,6 @@ _DEFUN (stat, (path, buf),
|
|||||||
const char *path _AND
|
const char *path _AND
|
||||||
struct stat *buf)
|
struct stat *buf)
|
||||||
{
|
{
|
||||||
|
|
||||||
ksys_file_info_t info;
|
ksys_file_info_t info;
|
||||||
struct tm time;
|
struct tm time;
|
||||||
|
|
||||||
@ -41,11 +40,11 @@ _DEFUN (stat, (path, buf),
|
|||||||
|
|
||||||
buf->st_size = info.size;
|
buf->st_size = info.size;
|
||||||
|
|
||||||
if (info.attr & 0x10)
|
if (info.attr & (KSYS_FILE_ATTR_DIR | KSYS_FILE_ATTR_VOL_LABEL))
|
||||||
buf->st_mode = S_IFDIR;
|
buf->st_mode = S_IFDIR;
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (info.attr & 0x07)
|
if (info.attr & (KSYS_FILE_ATTR_SYS | KSYS_FILE_ATTR_HIDDEN | KSYS_FILE_ATTR_RO))
|
||||||
buf->st_mode = S_IFREG|S_IRUSR|S_IXUSR;
|
buf->st_mode = S_IFREG|S_IRUSR|S_IXUSR;
|
||||||
else
|
else
|
||||||
buf->st_mode = S_IFREG|S_IRUSR|S_IWUSR|S_IXUSR;
|
buf->st_mode = S_IFREG|S_IRUSR|S_IWUSR|S_IXUSR;
|
||||||
|
Loading…
Reference in New Issue
Block a user