mirror of
https://github.com/samba-team/samba.git
synced 2025-01-12 09:18:10 +03:00
add Tru64 sub-second resolution timestamp support
This commit is contained in:
parent
ede1732195
commit
d177015a6d
@ -409,6 +409,11 @@ struct timespec get_atimespec(const SMB_STRUCT_STAT *pst)
|
||||
ret.tv_sec = pst->st_atime;
|
||||
ret.tv_nsec = pst->st_atime_n;
|
||||
return ret;
|
||||
#elif defined(HAVE_STAT_ST_UATIME)
|
||||
struct timespec ret;
|
||||
ret.tv_sec = pst->st_atime;
|
||||
ret.tv_nsec = pst->st_uatime * 1000;
|
||||
return ret;
|
||||
#elif defined(HAVE_STAT_ST_ATIMESPEC)
|
||||
return pst->st_atimespec;
|
||||
#else
|
||||
@ -431,6 +436,9 @@ void set_atimespec(SMB_STRUCT_STAT *pst, struct timespec ts)
|
||||
#elif defined(HAVE_STAT_ST_ATIME_N)
|
||||
pst->st_atime = ts.tv_sec;
|
||||
pst->st_atime_n = ts.tv_nsec;
|
||||
#elif defined(HAVE_STAT_ST_UATIME)
|
||||
pst->st_atime = ts.tv_sec;
|
||||
pst->st_uatime = ts.tv_nsec / 1000;
|
||||
#elif defined(HAVE_STAT_ST_ATIMESPEC)
|
||||
pst->st_atimespec = ts;
|
||||
#else
|
||||
@ -461,6 +469,11 @@ struct timespec get_mtimespec(const SMB_STRUCT_STAT *pst)
|
||||
ret.tv_sec = pst->st_mtime;
|
||||
ret.tv_nsec = pst->st_mtime_n;
|
||||
return ret;
|
||||
#elif defined(HAVE_STAT_ST_UMTIME)
|
||||
struct timespec ret;
|
||||
ret.tv_sec = pst->st_mtime;
|
||||
ret.tv_nsec = pst->st_umtime * 1000;
|
||||
return ret;
|
||||
#elif defined(HAVE_STAT_ST_MTIMESPEC)
|
||||
return pst->st_mtimespec;
|
||||
#else
|
||||
@ -483,6 +496,9 @@ void set_mtimespec(SMB_STRUCT_STAT *pst, struct timespec ts)
|
||||
#elif defined(HAVE_STAT_ST_MTIME_N)
|
||||
pst->st_mtime = ts.tv_sec;
|
||||
pst->st_mtime_n = ts.tv_nsec;
|
||||
#elif defined(HAVE_STAT_ST_UMTIME)
|
||||
pst->st_mtime = ts.tv_sec;
|
||||
pst->st_umtime = ts.tv_nsec / 1000;
|
||||
#elif defined(HAVE_STAT_ST_MTIMESPEC)
|
||||
pst->st_mtimespec = ts;
|
||||
#else
|
||||
@ -513,6 +529,11 @@ struct timespec get_ctimespec(const SMB_STRUCT_STAT *pst)
|
||||
ret.tv_sec = pst->st_ctime;
|
||||
ret.tv_nsec = pst->st_ctime_n;
|
||||
return ret;
|
||||
#elif defined(HAVE_STAT_ST_UCTIME)
|
||||
struct timespec ret;
|
||||
ret.tv_sec = pst->st_ctime;
|
||||
ret.tv_nsec = pst->st_uctime * 1000;
|
||||
return ret;
|
||||
#elif defined(HAVE_STAT_ST_CTIMESPEC)
|
||||
return pst->st_ctimespec;
|
||||
#else
|
||||
@ -535,6 +556,9 @@ void set_ctimespec(SMB_STRUCT_STAT *pst, struct timespec ts)
|
||||
#elif defined(HAVE_STAT_ST_CTIME_N)
|
||||
pst->st_ctime = ts.tv_sec;
|
||||
pst->st_ctime_n = ts.tv_nsec;
|
||||
#elif defined(HAVE_STAT_ST_UCTIME)
|
||||
pst->st_ctime = ts.tv_sec;
|
||||
pst->st_uctime = ts.tv_nsec / 1000;
|
||||
#elif defined(HAVE_STAT_ST_CTIMESPEC)
|
||||
pst->st_ctimespec = ts;
|
||||
#else
|
||||
|
Loading…
Reference in New Issue
Block a user