chiark / gitweb /
fixup for cddf148028f52
authorHarald Hoyer <harald@redhat.com>
Wed, 17 Apr 2013 16:58:06 +0000 (18:58 +0200)
committerHarald Hoyer <harald@redhat.com>
Wed, 17 Apr 2013 17:00:50 +0000 (19:00 +0200)
Instead of making a type up, just use __SWORD_TYPE, after reading
statfs(2).

Too bad, this does not fix s390x because __SWORD_TYPE is (long int) and
the kernel uses (int) to fill in the field!!!!!!

src/journal/sd-journal.c
src/readahead/readahead-collect.c
src/shared/util.c

index 6d0f363faf267eff02e53a48d7ccc79c4799a074..88777cbcb967a481219c6ee43c12f9ff044c478d 100644 (file)
@@ -1248,11 +1248,11 @@ static void check_network(sd_journal *j, int fd) {
                 return;
 
         j->on_network =
-                (unsigned long) sfs.f_type == CIFS_MAGIC_NUMBER ||
-                (unsigned long) sfs.f_type == CODA_SUPER_MAGIC ||
-                (unsigned long) sfs.f_type == NCP_SUPER_MAGIC ||
-                (unsigned long) sfs.f_type == NFS_SUPER_MAGIC ||
-                (unsigned long) sfs.f_type == SMB_SUPER_MAGIC;
+                (unsigned __SWORD_TYPE) sfs.f_type == CIFS_MAGIC_NUMBER ||
+                (unsigned __SWORD_TYPE) sfs.f_type == CODA_SUPER_MAGIC ||
+                (unsigned __SWORD_TYPE) sfs.f_type == NCP_SUPER_MAGIC ||
+                (unsigned __SWORD_TYPE) sfs.f_type == NFS_SUPER_MAGIC ||
+                (unsigned __SWORD_TYPE) sfs.f_type == SMB_SUPER_MAGIC;
 }
 
 static int add_file(sd_journal *j, const char *prefix, const char *filename) {
index 735bd8e3e0b055d49182a3999dbeea75aa427d43..fbfa8e786fdd16f4bd967ce807dbc87f2ad96ace 100644 (file)
@@ -505,7 +505,7 @@ done:
         on_ssd = fs_on_ssd(root) > 0;
         log_debug("On SSD: %s", yes_no(on_ssd));
 
-        on_btrfs = statfs(root, &sfs) >= 0 && (unsigned long) sfs.f_type == BTRFS_SUPER_MAGIC;
+        on_btrfs = statfs(root, &sfs) >= 0 && (unsigned __SWORD_TYPE) sfs.f_type == BTRFS_SUPER_MAGIC;
         log_debug("On btrfs: %s", yes_no(on_btrfs));
 
         if (asprintf(&pack_fn_new, "%s/.readahead.new", root) < 0) {
index f59c19df29018242d9dd587df45af7ff0fc23afa..386973b3fcc75ce70620d65dcfb2dec951dd297e 100644 (file)
@@ -2779,8 +2779,8 @@ int rm_rf_children_dangerous(int fd, bool only_dirs, bool honour_sticky, struct
 
 static int is_temporary_fs(struct statfs *s) {
         assert(s);
-        return (unsigned long) s->f_type == TMPFS_MAGIC ||
-                (unsigned long) s->f_type == RAMFS_MAGIC;
+        return (unsigned __SWORD_TYPE) s->f_type == TMPFS_MAGIC ||
+                (unsigned __SWORD_TYPE) s->f_type == RAMFS_MAGIC;
 }
 
 int rm_rf_children(int fd, bool only_dirs, bool honour_sticky, struct stat *root_dev) {