Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit d7ed9c05 authored by Linus Torvalds's avatar Linus Torvalds
Browse files
* '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
Loading
Loading
Loading
Loading
+4 −5
Original line number Original line Diff line number Diff line
@@ -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,
	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,
	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,
		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
+6 −1
Original line number Original line Diff line number Diff line
@@ -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)