]> git.ipfire.org Git - thirdparty/xfsprogs-dev.git/commitdiff
xfsprogs: revert OS X dummy function changes
authorDave Chinner <david@fromorbit.com>
Tue, 25 Aug 2015 00:10:51 +0000 (10:10 +1000)
committerDave Chinner <david@fromorbit.com>
Tue, 25 Aug 2015 00:10:51 +0000 (10:10 +1000)
Commit ff6f019d ("xfsprogs: missing and dummy calls for OS X
support") was committed prematurely. Revert it for now so that
better solutions can be committed cleanly.

Signed-off-by: Dave Chinner <david@fromorbit.com>
fsr/xfs_fsr.c
include/darwin.h

index 8be76ec3ee9480d3f331aa72ed4a2330fefdc508..b6737614c115784e390ca6ef14fef8b8acd4bb67 100644 (file)
 #define _PATH_FSRLAST          "/var/tmp/.fsrlast_xfs"
 #define _PATH_PROC_MOUNTS      "/proc/mounts"
 
-#ifdef USE_DUMMY_XATTR
-       /* OS X has fsetxattr with different number of arguments.
-        * Because it won't work anyway (no fstab/mtab and so on),
-        * hijack the call to a dummy function so it can at least
-        * compile.
-        */
-#  define fsetxattr(a,b,c,d,e) dummy_fsetxattr(a,b,c,d,e)
-#endif
 
 char *progname;
 
index 710d62f1871e0f21d8eb232083f9c1dfe4bb38dd..b90489813d7d197fd7172bd16f64e5e0106db3f7 100644 (file)
@@ -73,37 +73,45 @@ static __inline__ void platform_getoptreset(void)
 
 static __inline__ int platform_uuid_compare(uuid_t *uu1, uuid_t *uu2)
 {
-       return uuid_compare((const unsigned char *) uu1, (const unsigned char*) uu2);
+       return uuid_compare(uu1, uu2, NULL);
 }
 
 static __inline__ void platform_uuid_unparse(uuid_t *uu, char *buffer)
 {
-       uuid_unparse(*uu, buffer);
+       uint32_t status;
+       char *s;
+       uuid_to_string(uu, &s, &status);
+       if (status == uuid_s_ok)
+               strcpy(buffer, s);
+       else buffer[0] = '\0';
+       free(s);
 }
 
 static __inline__ int platform_uuid_parse(char *buffer, uuid_t *uu)
 {
-       return uuid_parse(buffer, *uu);
+       uint32_t status;
+       uuid_from_string(buffer, uu, &status);
+       return (status == uuid_s_ok);
 }
 
 static __inline__ int platform_uuid_is_null(uuid_t *uu)
 {
-       return uuid_is_null(*uu);
+       return uuid_is_nil(uu, NULL);
 }
 
 static __inline__ void platform_uuid_generate(uuid_t *uu)
 {
-       uuid_generate(*uu);
+       uuid_create(uu, NULL);
 }
 
 static __inline__ void platform_uuid_clear(uuid_t *uu)
 {
-       uuid_clear(*uu);
+       uuid_create_nil(uu, NULL);
 }
 
 static __inline__ void platform_uuid_copy(uuid_t *dst, uuid_t *src)
 {
-       uuid_copy(*dst, *src);
+       memcpy(dst, src, sizeof(uuid_t));
 }
 
 typedef unsigned char          __u8;
@@ -148,13 +156,11 @@ typedef int64_t           xfs_daddr_t;
 #define O_SYNC          0
 #endif
 
+#define ENOATTR                989     /* Attribute not found */
 #define EFSCORRUPTED   990     /* Filesystem is corrupted */
 #define EFSBADCRC      991     /* Bad CRC detected */
 #define constpp                char * const *
 
-#define XATTR_SIZE_MAX 65536    /* size of an extended attribute value (64k) */
-#define XATTR_LIST_MAX 65536    /* size of extended attribute namelist (64k) */
-
 #define HAVE_FID       1
 
 static __inline__ int
@@ -163,131 +169,4 @@ platform_discard_blocks(int fd, uint64_t start, uint64_t len)
        return 0;
 }
 
-
-/*
- * Dummy POSIX timer replacement
- */
-#define CLOCK_REALTIME 1
-typedef uint64_t timer_t;
-typedef double   timer_c;
-typedef clock_id_t clockid_t;
-struct itimerspec
-  {
-    struct timespec it_interval;
-    struct timespec it_value;
-  };
-
-static inline int timer_create (clockid_t __clock_id,
-                         struct sigevent *__restrict __evp,
-                         timer_t *__restrict __timerid)
-{
-       return 0;
-}
-
-static inline int timer_settime (timer_t __timerid, int __flags,
-                          const struct itimerspec *__restrict __value,
-                          struct itimerspec *__restrict __ovalue)
-{
-       return 0;
-}
-
-static inline int timer_delete (timer_t __timerid)
-{
-       return 0;
-}
-
-static inline int timer_gettime (timer_t __timerid, struct itimerspec *__value)
-{
-       return 0;
-}
-
-static inline int nftw64(const char *path, int (*fn)(const char *, const struct stat *ptr, int flag, struct FTW *), int depth,
-         int flags)
-{
-       return nftw(path, fn, depth, flags);
-}
-
-#define MREMAP_FIXED 1
-#define MREMAP_MAYMOVE 2
-static inline void *mremap(void *old_address, size_t old_size,
-                    size_t new_size, int flags, ... /* void *new_address */)
-{
-       return NULL;
-}
-
-/* FSR */
-
-#define                _PATH_MOUNTED   "/etc/mtab"
-#define                USE_DUMMY_XATTR
-
-typedef int __fsblkcnt_t;
-typedef int __fsfilcnt_t;
-typedef long long int __fsblkcnt64_t;
-typedef long long int __fsfilcnt64_t;
-
-struct statvfs64
-{
-       unsigned long int f_bsize;
-       unsigned long int f_frsize;
-       __fsblkcnt64_t f_blocks;
-       __fsblkcnt64_t f_bfree;
-       __fsblkcnt64_t f_bavail;
-       __fsfilcnt64_t f_files;
-       __fsfilcnt64_t f_ffree;
-       __fsfilcnt64_t f_favail;
-       unsigned long int f_fsid;
-       int __f_unused;
-       unsigned long int f_flag;
-       unsigned long int f_namemax;
-       int __f_spare[6];
-};
-
-struct mntent
-{
-       char *mnt_fsname;               /* Device or server for filesystem.  */
-       char *mnt_dir;          /* Directory mounted on.  */
-       char *mnt_type;         /* Type of filesystem: ufs, nfs, etc.  */
-       char *mnt_opts;         /* Comma-separated options for fs.  */
-       int mnt_freq;           /* Dump frequency (in days).  */
-       int mnt_passno;         /* Pass number for `fsck'.  */
-};
-
-static inline FILE *setmntent(const char *filename, const char *type)
-{
-       return NULL;
-}
-
-static inline int endmntent(FILE *fp)
-{
-       return 0;
-}
-
-static inline struct mntent *getmntent(FILE *fp)
-{
-       return NULL;
-}
-
-static inline int addmntent(FILE *fp, const struct mntent *mnt)
-{
-       return 0;
-}
-
-static inline char *hasmntopt(const struct mntent *mnt, const char *opt)
-{
-       return NULL;
-}
-
-static inline int statvfs64 (const char *__restrict __file, 
-                                                        struct statvfs64 *__restrict __buf)
-{
-       return 0;
-}
-
-static inline int dummy_fsetxattr (int filedes, const char *name,
-                       const void *value, size_t size, int flags)
-{
-       return 0;
-}
-
-
 #endif /* __XFS_DARWIN_H__ */