Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1758079AbYJQUDh (ORCPT ); Fri, 17 Oct 2008 16:03:37 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1756124AbYJQUD0 (ORCPT ); Fri, 17 Oct 2008 16:03:26 -0400 Received: from smtp127.sbc.mail.sp1.yahoo.com ([69.147.65.186]:39504 "HELO smtp127.sbc.mail.sp1.yahoo.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with SMTP id S1756038AbYJQUDY (ORCPT ); Fri, 17 Oct 2008 16:03:24 -0400 X-YMail-OSG: lJxStnwVM1kB8kFXgfbVzCm.yMD1vgQlyekGnXI3D884fs1Ay2aXRi0_zJTwEfcKlMRbyG4XKdjbYcdWLqtxDBzQbjHBbXiR5v0KfS59D_9bRuy.mFJPIsm4MDzgZLlvHQxOEvyDOWrV4IvJRtIMnFOXbV_lmXKEbIHwuyU- X-Yahoo-Newman-Property: ymail-3 Subject: Re: [PATCH] [ConfigFS]: Allow symbolic links from a SysFS struct kobject source. From: "Nicholas A. Bellinger" To: Joel Becker Cc: Greg KH , LKML , Linux-fsdevel , linux-scsi , "Linux-iSCSI.org Target Dev" , SCST-Devel , Alan Stern , Andrew Morton , Christoph Hellwig In-Reply-To: <20081017194857.GD5633@mail.oracle.com> References: <1224226555.5556.279.camel@haakon2.linux-iscsi.org> <20081017074453.GA4850@kroah.com> <1224231739.5556.303.camel@haakon2.linux-iscsi.org> <20081017194857.GD5633@mail.oracle.com> Content-Type: text/plain Date: Fri, 17 Oct 2008 13:03:21 -0700 Message-Id: <1224273801.5556.354.camel@haakon2.linux-iscsi.org> Mime-Version: 1.0 X-Mailer: Evolution 2.22.3.1 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2052 Lines: 58 On Fri, 2008-10-17 at 12:48 -0700, Joel Becker wrote: > On Fri, Oct 17, 2008 at 01:22:18AM -0700, Nicholas A. Bellinger wrote: > > On Fri, 2008-10-17 at 00:44 -0700, Greg KH wrote: > > > What is the problem you are attempting to solve here? > > > > > > > So, the generic target_core_mod engine that lives > > under /sys/kernel/config/target/core needs a method to locate struct > > block_device and struct scsi_device for access via bio_submit() and > > scsi_execute_() respectively. > > > > Originally, target_core_mod used key echoed through configfs attributes > > like so: > > > > export TARGET=/sys/kernel/config/target/core/ > > > > # Create $STORAGE_OBJECT of type Linux/BLOCK in generic target_core_mod > > mkdir -p $TARGET/iblock_0/lvm_test0 > > # OLD METHOD to reference struct block_device > > echo iblock_major=254,iblock_minor=2 > $TARGET/iblock_0/lvm_test0/control > > echo 1 > $TARGET/iblock_0/lvm_test0/enable > > # NEW METHOD using sysfs ->configfs symlinks to reference struct block_device > > ln -s /sys/block/dm-2 $TARGET/iblock_0/lvm_test0/dm-2 > > Pass an open file descriptor. In bash(1): > > exec 3<>/dev/dm-7 > echo 3 >$TARGET/iblock_0/lvm_test0/control # I'd call it 'fd' > > In kernel, in the ->store() function of 'control': > > p = (char *)page; > fd = simple_strtol(p, &p, 0); > filp = fget(fd); > inode = igrab(filp->f_mapping->host); > dev = I_BDEV(filp->f_mapping->host); > blkdev_get(dev, FMODE_WRITE | FMODE_READ, 0); > > Error handling is left up to you (validate the strtol, fd range, ISBLK, > etc). This assumes you want the struct block_device and want to pin it > in memory. I assume you do. > Sounds good.. I will go about converting the target_core_mod subsystem plugins to use this method.. Thanks Joel! --nab > Joel > -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/