add AIX sub-second resolution timestamp support
authorBjörn Jacke <bj@sernet.de>
Wed, 28 Jan 2009 23:35:26 +0000 (00:35 +0100)
committerJeremy Allison <jra@samba.org>
Thu, 29 Jan 2009 17:51:36 +0000 (09:51 -0800)
source3/lib/time.c

index 7dd0da8fa8ec43f90b9611b7ba42a0a82cc71ddb..14664716395f33bb34b7faab160dc0260de9eeb5 100644 (file)
@@ -404,6 +404,11 @@ struct timespec get_atimespec(const SMB_STRUCT_STAT *pst)
        ret.tv_sec = pst->st_atime;
        ret.tv_nsec = pst->st_atimensec;
        return ret;
+#elif defined(HAVE_STAT_ST_ATIME_N)
+       struct timespec ret;
+       ret.tv_sec = pst->st_atime;
+       ret.tv_nsec = pst->st_atime_n;
+       return ret;
 #elif defined(HAVE_STAT_ST_ATIMESPEC)
        return pst->st_atimespec;
 #else
@@ -423,6 +428,9 @@ void set_atimespec(SMB_STRUCT_STAT *pst, struct timespec ts)
 #elif defined(HAVE_STAT_ST_ATIMENSEC)
        pst->st_atime = ts.tv_sec;
        pst->st_atimensec = ts.tv_nsec
+#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_ATIMESPEC)
        pst->st_atimespec = ts;
 #else
@@ -448,6 +456,11 @@ struct timespec get_mtimespec(const SMB_STRUCT_STAT *pst)
        ret.tv_sec = pst->st_mtime;
        ret.tv_nsec = pst->st_mtimensec;
        return ret;
+#elif defined(HAVE_STAT_ST_MTIME_N)
+       struct timespec ret;
+       ret.tv_sec = pst->st_mtime;
+       ret.tv_nsec = pst->st_mtime_n;
+       return ret;
 #elif defined(HAVE_STAT_ST_MTIMESPEC)
        return pst->st_mtimespec;
 #else
@@ -467,6 +480,9 @@ void set_mtimespec(SMB_STRUCT_STAT *pst, struct timespec ts)
 #elif defined(HAVE_STAT_ST_MTIMENSEC)
        pst->st_mtime = ts.tv_sec;
        pst->st_mtimensec = ts.tv_nsec
+#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_ATIMESPEC)
        pst->st_atimespec = ts;
 #else
@@ -492,6 +508,11 @@ struct timespec get_ctimespec(const SMB_STRUCT_STAT *pst)
        ret.tv_sec = pst->st_ctime;
        ret.tv_nsec = pst->st_ctimensec;
        return ret;
+#elif defined(HAVE_STAT_ST_CTIME_N)
+       struct timespec ret;
+       ret.tv_sec = pst->st_ctime;
+       ret.tv_nsec = pst->st_ctime_n;
+       return ret;
 #elif defined(HAVE_STAT_ST_CTIMESPEC)
        return pst->st_ctimespec;
 #else
@@ -511,6 +532,9 @@ void set_ctimespec(SMB_STRUCT_STAT *pst, struct timespec ts)
 #elif defined(HAVE_STAT_ST_CTIMENSEC)
        pst->st_ctime = ts.tv_sec;
        pst->st_ctimensec = ts.tv_nsec
+#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_CTIMESPEC)
        pst->st_ctimespec = ts;
 #else