Hello community,
here is the log from the commit of package reiserfs for openSUSE:Factory
checked in at Tue Aug 9 11:00:00 CEST 2011.
--------
--- reiserfs/reiserfs.changes 2010-04-15 23:52:19.000000000 +0200
+++ /mounts/work_src_done/STABLE/reiserfs/reiserfs.changes 2011-08-08 22:09:07.000000000 +0200
@@ -1,0 +2,5 @@
+Mon Aug 8 22:07:46 CEST 2011 - jeffm@suse.de
+
+- Fix signedness issues for large file systems
+
+-------------------------------------------------------------------
calling whatdependson for head-i586
New:
----
reiserfs-signedness-fixes
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Other differences:
------------------
++++++ reiserfs.spec ++++++
--- /var/tmp/diff_new_pack.72Spgk/_old 2011-08-09 10:59:37.000000000 +0200
+++ /var/tmp/diff_new_pack.72Spgk/_new 2011-08-09 10:59:37.000000000 +0200
@@ -1,7 +1,7 @@
#
-# spec file for package reiserfs (Version 3.6.21)
+# spec file for package reiserfs
#
-# Copyright (c) 2010 SUSE LINUX Products GmbH, Nuernberg, Germany.
+# Copyright (c) 2011 SUSE LINUX Products GmbH, Nuernberg, Germany.
#
# All modifications and additions to the file contributed by third parties
# remain the property of their copyright owners, unless otherwise agreed
@@ -23,13 +23,15 @@
Conflicts: libreiserfs-progs
Supplements: filesystem(reiserfs)
Version: 3.6.21
-Release: 3
+Release: 12
Summary: Reiser File System utilities
License: GPLv2+
Group: System/Filesystems
AutoReqProv: on
Source: reiserfsprogs-%{version}.tar.bz2
Patch1: reiserfsprogs-fix-fsck-crash
+Patch2: reiserfs-signedness-fixes
+
BuildRoot: %{_tmppath}/%{name}-%{version}-build
%description
@@ -42,6 +44,7 @@
%prep
%setup -q -n reiserfsprogs-%{version}
%patch1 -p1
+%patch2 -p1
%build
autoreconf
++++++ reiserfs-signedness-fixes ++++++
From: Jeff Mahoney
Subject: [PATCH] reiserfs: Fix signedness issues for large file systems
References: bnc#701602
Signed-by: Jeff Mahoney
---
debugreiserfs/debugreiserfs.c | 22 +++++++++++-----------
debugreiserfs/pack.c | 18 +++++++++---------
debugreiserfs/scan.c | 2 +-
debugreiserfs/stat.c | 2 +-
fsck/check_tree.c | 6 +++---
fsck/pass0.c | 10 +++++-----
fsck/pass1.c | 4 ++--
include/reiserfs_fs.h | 2 ++
lib/io.c | 2 +-
reiserfscore/journal.c | 2 +-
reiserfscore/prints.c | 14 +++++++-------
reiserfscore/reiserfslib.c | 5 +++--
reiserfscore/stree.c | 2 +-
13 files changed, 47 insertions(+), 44 deletions(-)
--- a/debugreiserfs/debugreiserfs.c
+++ b/debugreiserfs/debugreiserfs.c
@@ -59,11 +59,11 @@ Options:\n\
#if 1
struct reiserfs_fsstat {
- int nr_internals;
- int nr_leaves;
- int nr_files;
- int nr_directories;
- int nr_unformatted;
+ unsigned int nr_internals;
+ unsigned int nr_leaves;
+ unsigned int nr_files;
+ unsigned int nr_directories;
+ unsigned int nr_unformatted;
} g_stat_info;
#endif
@@ -465,14 +465,14 @@ static void init_bitmap (reiserfs_filsys
case ALL_BLOCKS:
input_bitmap (fs) = reiserfs_create_bitmap (block_count);
reiserfs_bitmap_fill (input_bitmap (fs));
- reiserfs_warning (stderr, "Whole device (%d blocks) is to be scanned\n",
+ reiserfs_warning (stderr, "Whole device (%u blocks) is to be scanned\n",
reiserfs_bitmap_ones (input_bitmap (fs)));
break;
case USED_BLOCKS:
reiserfs_warning (stderr, "Loading on-disk bitmap .. ");
input_bitmap (fs) = reiserfs_create_bitmap (block_count);
reiserfs_bitmap_copy (input_bitmap (fs), fs->fs_bitmap2);
- reiserfs_warning (stderr, "%d bits set - done\n",
+ reiserfs_warning (stderr, "%lu bits set - done\n",
reiserfs_bitmap_ones (input_bitmap (fs)));
break;
case UNUSED_BLOCKS:
@@ -480,7 +480,7 @@ static void init_bitmap (reiserfs_filsys
input_bitmap (fs) = reiserfs_create_bitmap (block_count);
reiserfs_bitmap_copy (input_bitmap (fs), fs->fs_bitmap2);
reiserfs_bitmap_invert (input_bitmap (fs));
- reiserfs_warning (stderr, "%d bits set - done\n",
+ reiserfs_warning (stderr, "%lu bits set - done\n",
reiserfs_bitmap_ones (input_bitmap (fs)));
break;
case EXTERN_BITMAP:
@@ -494,7 +494,7 @@ static void init_bitmap (reiserfs_filsys
reiserfs_exit (1, "could not load fitmap from \"%s\"",
input_bitmap_file_name(fs));
}
- reiserfs_warning (stderr, "%d blocks marked in the given bitmap\n",
+ reiserfs_warning (stderr, "%u blocks marked in the given bitmap\n",
reiserfs_bitmap_ones (input_bitmap (fs)));
fclose (fp);
break;
@@ -554,8 +554,8 @@ static void do_dump_tree (reiserfs_filsy
}
/* print the statistic */
- printf ("\t%d internal + %d leaves + %d "
- "unformatted nodes = %d blocks\n",
+ printf ("\t%u internal + %u leaves + %u "
+ "unformatted nodes = %u blocks\n",
g_stat_info.nr_internals, g_stat_info.nr_leaves,
g_stat_info.nr_unformatted, g_stat_info.nr_internals +
g_stat_info.nr_leaves + g_stat_info.nr_unformatted);
--- a/debugreiserfs/pack.c
+++ b/debugreiserfs/pack.c
@@ -8,7 +8,7 @@
/* counters for each kind of blocks */
-int packed,
+unsigned int packed,
packed_leaves,
full_blocks,
having_ih_array, /* blocks with broken block head */
@@ -638,7 +638,7 @@ static void pack_frozen_data (reiserfs_f
}
reiserfs_warning (stderr, "ok\n");fflush (stderr);
reiserfs_warning (stderr,
- "Super block, bitmaps, journal - %d blocks - done, %d blocks left\n",
+ "Super block, bitmaps, journal - %u blocks - done, %u blocks left\n",
packed, reiserfs_bitmap_ones (what_to_pack));
}
@@ -693,13 +693,13 @@ void pack_partition (reiserfs_filsys_t *
magic16 = END_MAGIC;
fwrite_le16 (&magic16);
- fprintf (stderr, "\nPacked %d blocks:\n"
- "\tcompessed %d\n"
- "\tfull blocks %d\n"
- "\t\tleaves with broken block head %d\n"
- "\t\tcorrupted leaves %d\n"
- "\t\tinternals %d\n"
- "\t\tdescriptors %d\n",
+ fprintf (stderr, "\nPacked %u blocks:\n"
+ "\tcompessed %u\n"
+ "\tfull blocks %u\n"
+ "\t\tleaves with broken block head %u\n"
+ "\t\tcorrupted leaves %u\n"
+ "\t\tinternals %u\n"
+ "\t\tdescriptors %u\n",
packed,
packed_leaves, full_blocks, having_ih_array,
bad_leaves, internals, descs);
--- a/debugreiserfs/scan.c
+++ b/debugreiserfs/scan.c
@@ -1032,7 +1032,7 @@ void do_scan (reiserfs_filsys_t * fs)
/* step 2: */
done = 0;
total = reiserfs_bitmap_ones (input_bitmap (fs));
- printf ("%ld bits set in bitmap\n", total);
+ printf ("%lu bits set in bitmap\n", total);
for (i = 0; i < get_sb_block_count (fs->fs_ondisk_sb); i ++) {
int type;
--- a/debugreiserfs/stat.c
+++ b/debugreiserfs/stat.c
@@ -245,7 +245,7 @@ void do_stat (reiserfs_filsys_t * fs)
reiserfs_exit (1, "could not open %s to save bitmap: %m\n",
input_bitmap_file_name(fs));
}
- reiserfs_warning (stderr, "Updated bitmap contains %d blocks marked\n",
+ reiserfs_warning (stderr, "Updated bitmap contains %u blocks marked\n",
reiserfs_bitmap_ones (input_bitmap (fs)));
reiserfs_bitmap_save (fp, input_bitmap (fs));
--- a/fsck/check_tree.c
+++ b/fsck/check_tree.c
@@ -119,7 +119,7 @@ static int is_block_free (reiserfs_filsy
}
-/*static int hits = 0;*/
+/*static unsigned int hits = 0;*/
/* we have seen this block in the tree, mark corresponding bit in the
control bitmap */
@@ -156,7 +156,7 @@ static void init_control_bitmap (reiserf
for (i = 0; i <= fs->fs_super_bh->b_blocknr; i ++)
we_met_it (i);
- /*printf ("SKIPPED: %d blocks marked used (%d)\n", hits,
+ /*printf ("SKIPPED: %u blocks marked used (%d)\n", hits,
reiserfs_bitmap_zeros (control_bitmap));
hits = 0;*/
@@ -172,7 +172,7 @@ static void init_control_bitmap (reiserf
block ++;
}
- /*printf ("BITMAPS: %d blocks marked used (%d)\n", hits,
+ /*printf ("BITMAPS: %u blocks marked used (%d)\n", hits,
reiserfs_bitmap_zeros (control_bitmap));
hits = 0;*/
--- a/fsck/pass0.c
+++ b/fsck/pass0.c
@@ -1759,7 +1759,7 @@ static void init_source_bitmap (reiserfs
case ALL_BLOCKS:
fsck_source_bitmap (fs) = reiserfs_create_bitmap (block_count);
reiserfs_bitmap_fill (fsck_source_bitmap (fs));
- fsck_progress ("The whole partition (%d blocks) is to be scanned\n",
+ fsck_progress ("The whole partition (%u blocks) is to be scanned\n",
reiserfs_bitmap_ones (fsck_source_bitmap (fs)));
break;
@@ -1768,7 +1768,7 @@ static void init_source_bitmap (reiserfs
fsck_source_bitmap (fs) = reiserfs_create_bitmap (block_count);
reiserfs_bitmap_copy (fsck_source_bitmap (fs), fs->fs_bitmap2);
- fsck_progress ("ok, %d blocks marked used\n",
+ fsck_progress ("ok, %u blocks marked used\n",
reiserfs_bitmap_ones (fsck_source_bitmap (fs)));
break;
@@ -1787,7 +1787,7 @@ static void init_source_bitmap (reiserfs
fsck_data (fs)->rebuild.bitmap_file_name);
}
- fsck_progress ("%d blocks marked used in extern bitmap\n",
+ fsck_progress ("%u blocks marked used in extern bitmap\n",
reiserfs_bitmap_ones (fsck_source_bitmap (fs)));
fclose (fp);
break;
@@ -1863,8 +1863,8 @@ static void init_source_bitmap (reiserfs
fsck_source_bitmap (fs)->bm_set_bits = reiserfs_bitmap_ones (fsck_source_bitmap (fs));
- fsck_progress ("Skipping %d blocks (super block, journal, "
- "bitmaps) %d blocks will be read\n", tmp, fsck_source_bitmap (fs)->bm_set_bits);
+ fsck_progress ("Skipping %u blocks (super block, journal, "
+ "bitmaps) %u blocks will be read\n", tmp, fsck_source_bitmap (fs)->bm_set_bits);
}
--- a/fsck/pass1.c
+++ b/fsck/pass1.c
@@ -646,8 +646,8 @@ void load_pass_1_result (FILE * fp, reis
fetch_objectid_map (proper_id_map (fs), fs);
*/
- fsck_progress ("Pass 1 result loaded. %d blocks used, %d allocable, "
- "still to be inserted %d\n",
+ fsck_progress ("Pass 1 result loaded. %u blocks used, %u allocable, "
+ "still to be inserted %u\n",
reiserfs_bitmap_ones (fsck_new_bitmap (fs)),
reiserfs_bitmap_zeros (fsck_allocable_bitmap (fs)),
reiserfs_bitmap_zeros (fsck_uninsertables (fs)));
--- a/include/reiserfs_fs.h
+++ b/include/reiserfs_fs.h
@@ -32,6 +32,8 @@
#ifndef REISERFSPROGS_FS_H
#define REISERFSPRIGS_FS_H
+typedef unsigned int blocknr_t;
+
#ifndef NO_EXTERN_INLINE
# define extern_inline extern inline
#else
--- a/lib/io.c
+++ b/lib/io.c
@@ -628,7 +628,7 @@ void close_rollback_file () {
return;
fwrite (&rollback_blocks_number, sizeof (rollback_blocksize), 1, s_rollback_file);
if (log_file != 0)
- fprintf (log_file, "rollback: %d blocks backed up\n", rollback_blocks_number);
+ fprintf (log_file, "rollback: %u blocks backed up\n", rollback_blocks_number);
}
fclose (s_rollback_file);
--- a/reiserfscore/journal.c
+++ b/reiserfscore/journal.c
@@ -577,7 +577,7 @@ int reiserfs_create_journal(
{
/* host device does not contain enough blocks */
reiserfs_warning (stderr, "reiserfs_create_journal: cannot create "
- "a journal of %lu blocks with %lu offset on %d blocks\n",
+ "a journal of %lu blocks with %lu offset on %u blocks\n",
len, offset, get_sb_block_count(sb));
return 0;
}
--- a/reiserfscore/prints.c
+++ b/reiserfscore/prints.c
@@ -148,7 +148,7 @@ static int print_disk_child (FILE * stre
int len;
dc = *((const struct disk_child **)(args[0]));
- len = asprintf (&buffer, "[dc_number=%u, dc_size=%u]", get_dc_child_blocknr (dc),
+ len = asprintf (&buffer, "[dc_number=%lu, dc_size=%u]", get_dc_child_blocknr (dc),
get_dc_child_size (dc));
FPRINTF;
}
@@ -373,9 +373,9 @@ static void print_sequence (FILE * fp, _
return;
if (len == 1)
- reiserfs_warning (fp, " %d", le32_to_cpu (start));
+ reiserfs_warning (fp, " %u", le32_to_cpu (start));
else
- reiserfs_warning (fp, " %d(%d)", le32_to_cpu (start), len);
+ reiserfs_warning (fp, " %u(%d)", le32_to_cpu (start), len);
}
@@ -491,7 +491,7 @@ static int print_internal (FILE * fp, st
to = last < B_NR_ITEMS (bh) ? last : B_NR_ITEMS (bh);
}
- reiserfs_warning (fp, "INTERNAL NODE (%ld) contains %b\n", bh->b_blocknr, bh);
+ reiserfs_warning (fp, "INTERNAL NODE (%lu) contains %b\n", bh->b_blocknr, bh);
dc = B_N_CHILD (bh, from);
reiserfs_warning (fp, "PTR %d: %y ", from, dc);
@@ -527,7 +527,7 @@ static int print_leaf (FILE * fp, reiser
reiserfs_warning (fp,
"\n===================================================================\n");
- reiserfs_warning (fp, "LEAF NODE (%ld) contains %b (real items %d)\n",
+ reiserfs_warning (fp, "LEAF NODE (%lu) contains %b (real items %d)\n",
bh->b_blocknr, bh, real_nr);
if (!(print_mode & PRINT_TREE_DETAILS)) {
@@ -761,7 +761,7 @@ void print_block (FILE * fp, reiserfs_fi
if (print_super_block (fp, fs, file_name, bh, 0))
if (print_leaf (fp, fs, bh, mode, first, last))
if (print_internal (fp, bh, first, last))
- reiserfs_warning (fp, "Block %ld contains unformatted data\n", bh->b_blocknr);
+ reiserfs_warning (fp, "Block %lu contains unformatted data\n", bh->b_blocknr);
}
@@ -797,7 +797,7 @@ void print_tb (int mode, int item_pos, i
tbSh = 0;
tbFh = 0;
}
- printf ("* %u * %3lu(%2lu) * %3lu(%2lu) * %3lu(%2lu) * %5ld * %5ld * %5ld * %5ld * %5ld *\n",
+ printf ("* %u * %3lu(%2lu) * %3lu(%2lu) * %3lu(%2lu) * %5lu * %5lu * %5lu * %5lu * %5lu *\n",
h,
tbSh ? tbSh->b_blocknr : ~0ul,
tbSh ? tbSh->b_count : ~0ul,
--- a/reiserfscore/reiserfslib.c
+++ b/reiserfscore/reiserfslib.c
@@ -59,7 +59,8 @@ reiserfs_filsys_t * reiserfs_open (char
reiserfs_filsys_t * fs;
struct buffer_head * bh;
struct reiserfs_super_block * sb;
- int fd, i;
+ int fd;
+ unsigned int i;
/* convert root dir key and parent root dir key to little endian format */
make_const_keys ();
@@ -200,7 +201,7 @@ reiserfs_filsys_t * reiserfs_create (cha
block_size, block_count, 0))
{
reiserfs_warning (stderr, "reiserfs_create: can not create that small "
- "(%d blocks) filesystem\n", block_count);
+ "(%u blocks) filesystem\n", block_count);
return 0;
}
--- a/reiserfscore/stree.c
+++ b/reiserfscore/stree.c
@@ -313,7 +313,7 @@ int search_by_key (reiserfs_filsys_t * f
int n_stop_level) /* How far down the tree to search.*/
{
struct reiserfs_super_block * sb;
- int n_block_number,
+ unsigned int n_block_number,
expected_level,
n_block_size = fs->fs_blocksize;
struct buffer_head * p_s_bh;
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Remember to have fun...
--
To unsubscribe, e-mail: opensuse-commit+unsubscribe@opensuse.org
For additional commands, e-mail: opensuse-commit+help@opensuse.org