Commit d7ed9c05 authored by Linus Torvalds's avatar Linus Torvalds

Merge branch 'for_linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jack/linux-udf-2.6

* 'for_linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jack/linux-udf-2.6:
  udf: remove redundant tests on unsigned
  udf: Use device size when drive reported bogus number of written blocks
parents 4d8d4d25 3391faa4
...@@ -238,7 +238,7 @@ static int udf_bitmap_prealloc_blocks(struct super_block *sb, ...@@ -238,7 +238,7 @@ static int udf_bitmap_prealloc_blocks(struct super_block *sb,
mutex_lock(&sbi->s_alloc_mutex); mutex_lock(&sbi->s_alloc_mutex);
part_len = sbi->s_partmaps[partition].s_partition_len; part_len = sbi->s_partmaps[partition].s_partition_len;
if (first_block < 0 || first_block >= part_len) if (first_block >= part_len)
goto out; goto out;
if (first_block + block_count > part_len) if (first_block + block_count > part_len)
...@@ -297,7 +297,7 @@ static int udf_bitmap_new_block(struct super_block *sb, ...@@ -297,7 +297,7 @@ static int udf_bitmap_new_block(struct super_block *sb,
mutex_lock(&sbi->s_alloc_mutex); mutex_lock(&sbi->s_alloc_mutex);
repeat: repeat:
if (goal < 0 || goal >= sbi->s_partmaps[partition].s_partition_len) if (goal >= sbi->s_partmaps[partition].s_partition_len)
goal = 0; goal = 0;
nr_groups = bitmap->s_nr_groups; nr_groups = bitmap->s_nr_groups;
...@@ -666,8 +666,7 @@ static int udf_table_prealloc_blocks(struct super_block *sb, ...@@ -666,8 +666,7 @@ static int udf_table_prealloc_blocks(struct super_block *sb,
int8_t etype = -1; int8_t etype = -1;
struct udf_inode_info *iinfo; struct udf_inode_info *iinfo;
if (first_block < 0 || if (first_block >= sbi->s_partmaps[partition].s_partition_len)
first_block >= sbi->s_partmaps[partition].s_partition_len)
return 0; return 0;
iinfo = UDF_I(table); iinfo = UDF_I(table);
...@@ -743,7 +742,7 @@ static int udf_table_new_block(struct super_block *sb, ...@@ -743,7 +742,7 @@ static int udf_table_new_block(struct super_block *sb,
return newblock; return newblock;
mutex_lock(&sbi->s_alloc_mutex); mutex_lock(&sbi->s_alloc_mutex);
if (goal < 0 || goal >= sbi->s_partmaps[partition].s_partition_len) if (goal >= sbi->s_partmaps[partition].s_partition_len)
goal = 0; goal = 0;
/* We search for the closest matching block to goal. If we find /* We search for the closest matching block to goal. If we find
......
...@@ -56,7 +56,12 @@ unsigned long udf_get_last_block(struct super_block *sb) ...@@ -56,7 +56,12 @@ unsigned long udf_get_last_block(struct super_block *sb)
struct block_device *bdev = sb->s_bdev; struct block_device *bdev = sb->s_bdev;
unsigned long lblock = 0; unsigned long lblock = 0;
if (ioctl_by_bdev(bdev, CDROM_LAST_WRITTEN, (unsigned long) &lblock)) /*
* ioctl failed or returned obviously bogus value?
* Try using the device size...
*/
if (ioctl_by_bdev(bdev, CDROM_LAST_WRITTEN, (unsigned long) &lblock) ||
lblock == 0)
lblock = bdev->bd_inode->i_size >> sb->s_blocksize_bits; lblock = bdev->bd_inode->i_size >> sb->s_blocksize_bits;
if (lblock) if (lblock)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment