[PATCH] [Target_Core_Mod]: Updates for v2.6.28-rc2

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



>From 92eaaa2d3fe569ec0654b44658504c8c75fa9a43 Mon Sep 17 00:00:00 2001
From: Nicholas Bellinger <nab@xxxxxxxxxxxxxxx>
Date: Wed, 29 Oct 2008 22:30:00 -0700
Subject: [PATCH] [Target_Core_Mod]: Updates for v2.6.28-rc2

There are two updates to Target_Core_Mod code for v2.6.27 -> v2.6.28-rc2

*) blkdev_get() loses "unsigned flags" parameter
*) blkdev_put() gains "fmode_t mode" parameter

For the first two, updated linux_blockdevice_claim*() and linux_blockdevice_release()
in drivers/lio-core/target_core_device.c, Also updated READ-ONLY cases for
Target_Core_Mod/IBLOCK and Target_Core_Mod/FILEIO.

*) struct genhd->capacity goes away

Target_Core_Mod/IBLOCK had been using this to emulate READ_CAPACITY.  Changed
iblock_emulate_read_cap() and iblock_emulate_read_cap16() to correctly use
include/linux/genhd.h:get_capacity() macro

Signed-off-by: Nicholas A. Bellinger <nab@xxxxxxxxxxxxxxx>
---
 drivers/lio-core/target_core_device.c |   12 ++++++------
 drivers/lio-core/target_core_file.c   |    2 +-
 drivers/lio-core/target_core_iblock.c |    8 ++++----
 3 files changed, 11 insertions(+), 11 deletions(-)

diff --git a/drivers/lio-core/target_core_device.c b/drivers/lio-core/target_core_device.c
index 6891b54..11dc965 100644
--- a/drivers/lio-core/target_core_device.c
+++ b/drivers/lio-core/target_core_device.c
@@ -68,7 +68,7 @@ extern se_global_t *se_global;
 
 extern struct block_device *linux_blockdevice_claim_bd (struct block_device *bd, void *claim_ptr)
 {
-	if (blkdev_get(bd, FMODE_WRITE|FMODE_READ, O_RDWR) < 0)
+	if (blkdev_get(bd, FMODE_WRITE|FMODE_READ) < 0)
 		return(NULL);	
 	/*
 	 * If no claim pointer was passed from claimee, use struct block_device.
@@ -77,7 +77,7 @@ extern struct block_device *linux_blockdevice_claim_bd (struct block_device *bd,
 		claim_ptr = (void *)bd;
 
 	if (bd_claim(bd, claim_ptr) < 0) {
-		blkdev_put(bd);
+		blkdev_put(bd, FMODE_WRITE|FMODE_READ);
 		return(NULL);
 	}
 	
@@ -96,7 +96,7 @@ extern struct block_device *__linux_blockdevice_claim (int major, int minor, voi
 		return(NULL);
 	}
 
-	if (blkdev_get(bd, FMODE_WRITE, O_RDWR) < 0) {
+	if (blkdev_get(bd, FMODE_WRITE|FMODE_READ) < 0) {
 		*ret = -1;
 		return(NULL);
 	}
@@ -129,7 +129,7 @@ extern struct block_device *linux_blockdevice_claim (int major, int minor, void
 	if (!(bd = bdget(dev)))
 		return(NULL);
 
-	if (blkdev_get(bd, FMODE_WRITE, O_RDWR) < 0)
+	if (blkdev_get(bd, FMODE_WRITE|FMODE_READ) < 0)
 		return(NULL);
 	/*
 	 * If no claim pointer was passed from claimee, use struct block_device.
@@ -138,7 +138,7 @@ extern struct block_device *linux_blockdevice_claim (int major, int minor, void
 		claim_ptr = (void *)bd;
 
 	if (bd_claim(bd, claim_ptr) < 0) {
-		blkdev_put(bd);
+		blkdev_put(bd, FMODE_WRITE|FMODE_READ);
 		return(NULL);
 	}
 	
@@ -159,7 +159,7 @@ extern int linux_blockdevice_release (int major, int minor, struct block_device
 		bd = bd_p;
 
 	bd_release(bd);
-	blkdev_put(bd);
+	blkdev_put(bd, FMODE_WRITE|FMODE_READ);
 
 	return(0);
 }
diff --git a/drivers/lio-core/target_core_file.c b/drivers/lio-core/target_core_file.c
index 35c7665..1ea126f 100644
--- a/drivers/lio-core/target_core_file.c
+++ b/drivers/lio-core/target_core_file.c
@@ -159,7 +159,7 @@ extern int fd_release_phydevice (se_device_t *dev)
 	if (dev->dev_flags & DF_READ_ONLY) {
 		PYXPRINT("FILEIO: Calling blkdev_put() for Major:Minor - %d:%d\n",
 			fd_dev->fd_major, fd_dev->fd_minor);
-		blkdev_put((struct block_device *)fd_dev->fd_bd);
+		blkdev_put((struct block_device *)fd_dev->fd_bd, FMODE_READ);
 	} else {	
 		PYXPRINT("FILEIO: Releasing Major:Minor - %d:%d\n", fd_dev->fd_major,
 			fd_dev->fd_minor);
diff --git a/drivers/lio-core/target_core_iblock.c b/drivers/lio-core/target_core_iblock.c
index f5beb70..8f5a442 100644
--- a/drivers/lio-core/target_core_iblock.c
+++ b/drivers/lio-core/target_core_iblock.c
@@ -159,7 +159,7 @@ extern int iblock_release_phydevice (se_device_t *dev)
 	if (dev->dev_flags & DF_READ_ONLY) {
 		PYXPRINT("IBLOCK: Calling blkdev_put() for Major:Minor - %d:%d\n",
 			ib_dev->ibd_major, ib_dev->ibd_minor);
-		blkdev_put((struct block_device *)ib_dev->ibd_bd);
+		blkdev_put((struct block_device *)ib_dev->ibd_bd, FMODE_READ);
 	} else {
 		PYXPRINT("IBLOCK: Releasing Major:Minor - %d:%d\n",
 			ib_dev->ibd_major, ib_dev->ibd_minor);
@@ -415,9 +415,9 @@ static int iblock_emulate_read_cap (se_task_t *task)
 {
 	iblock_dev_t *ibd = (iblock_dev_t *) task->iscsi_dev->dev_ptr;
 	struct block_device *bd = ibd->ibd_bd;
-	u32 blocks = (bd->bd_disk->capacity - 1);
+	u32 blocks = (get_capacity(bd->bd_disk) - 1);
 
-	if ((bd->bd_disk->capacity - 1) >= 0x00000000ffffffff)
+	if ((get_capacity(bd->bd_disk) - 1) >= 0x00000000ffffffff)
 		blocks = 0xffffffff;
 
 	return(transport_generic_emulate_readcapacity(task->iscsi_cmd, blocks, IBLOCK_BLOCKSIZE));
@@ -427,7 +427,7 @@ static int iblock_emulate_read_cap16 (se_task_t *task)
 {
 	iblock_dev_t *ibd = (iblock_dev_t *) task->iscsi_dev->dev_ptr;
 	struct block_device *bd = ibd->ibd_bd;
-	unsigned long long blocks_long = (bd->bd_disk->capacity - 1);
+	unsigned long long blocks_long = (get_capacity(bd->bd_disk) - 1);
 
 	return(transport_generic_emulate_readcapacity_16(task->iscsi_cmd, blocks_long, IBLOCK_BLOCKSIZE));;
 }
-- 
1.5.4.1



--
To unsubscribe from this list: send the line "unsubscribe linux-scsi" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [SCSI Target Devel]     [Linux SCSI Target Infrastructure]     [Kernel Newbies]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Linux IIO]     [Samba]     [Device Mapper]
  Powered by Linux