On Fri, 2008-09-12 at 21:49 -0700, Joel Becker wrote: > On Fri, Sep 12, 2008 at 03:27:57PM -0700, Nicholas A. Bellinger wrote: > > On Fri, 2008-09-12 at 13:15 -0700, Joel Becker wrote: > > > No, you don't do this. Like I said, configfs clients let > > > userspace create and destroy items. Not kernelspace. Do not call > > > sys_mkdir()/sys_rmdir() from your modules. > > > > Well, the startup 'fabric registration' is only case where I figured > > vfs_mkdir($CONFIGFS/target/$FABRIC) being called in order to have the > > fabric struct config_item appear at modprobe $FABRIC_MOD *BEFORE* the > > user did anything would be beneficial at all. If vfs_mkdir() was not > > called from transport_fabric_register_configfs(), it only means user > > would have call mkdir $CONFIGFS/target/$FABRIC and/or mkdir -p > > $CONFIGFS/target/$FABRIC/endpoint to kick off one common make_group() > > for $FABRIC (that lives in target_core_configfs.c) and then make_group() > > that likes inside of $FABRIC_MOD who's parent is $CONFIGFS/target. In > > LIO-Target's case, this would be creating a new iSCSI Qualified Name > > with mkdir $CONFIGFS/target/iscsi/iqn.superturobdiskarry > > I'm still totally unclear as to why $FABRIC has to live under > target/. Well, I figured that since $FABRIC would be depending upon LUN mappings to target/core/$STORAGE_OBJECT struct config_items , it would make sense sense for $FABRIC to appear under a common target mode engine.. Having $CONFIGFS/target/core for storage objects and $CONFIG/$FABRIC/endpoint/lun_0 and setting up symlinks between the two entities is what I think you have in mind. This setup you mention may have other advantages/disadvantages when it goes to a generic target mode, but I have been focused on getting the initial setup (see below..) up and running, sooo.. :-) Obviously if things can be done easier I am all for it. Also I think for debugging and [PROC,IOCTL] -> ConfigFS conversion purposes, being able to call my do_configfs_[mkdir,rmdir] wrappers when existing legacy target functionality get called to add/remove the ConfigFS entries may have some value as well.. At least to make it easier for kernel level $FABRIC_MOD maintainers to see how generic kernel target mode configfs works... Just wanted to mention that.. > I'm not clear if there can be more than one $FABRIC at a time. Absoulutely. Current each $FABRIC_MOD that registers itself with the common target engine calls the target_fabric_configfs_register() that creates its own struct config_group with fabric dependent configfs ops/abstractions. This could very well be hidden behind the actual non configfs related target engine infrastructure when $FABRIC_MOD does actual fabric registration. Also having common code for $FABRIC_MOD to use to allow those LUN mappings across multiple independent $FABRIC_MODs from target/core/$STORAGE_OBJECT is the main idea, but point taken that $FABRIC does not necessary need to be hanging directly off $CONFIGS/target to function.. Also why I think having $FABRIC under $CONFIGFS/target/ makes sense, I would like to be able to do rm -rf $CONFIGFS/target to shutdown all LUN mappings on all fabrics on all storage objects instead of rm -rf $CONFIGFS/iscsi ; rm -rf $CONFIGFS/sas ; rm -rf $CONFIGFS/pscsi ; rm -rf $CONFIGFS/target.. :-) > etc. That's what I'm trying to understand so I can help you out. > :-) So, as of this morning I have basic iqn.foo/tpgt_1 ConfigFS functionality for LIO-Target.. Here is what it looks like.. <snip> # Create some target:/sys/kernel/config/target/iscsi# mkdir -p iqn.iscsi-hd.renderbox/tpgt_1 target:/sys/kernel/config/target/iscsi# mkdir -p iqn.lio-production/tpgt_1 target:/sys/kernel/config/target/iscsi# mkdir -p iqn.upstreamtargetmodestorage/tpgt_1 target:/sys/kernel/config/target/iscsi# mkdir -p iqn.superturbodiskarray/tpgt_1 target:/sys/kernel/config/target/iscsi# mkdir -p `iscsi-name`/tpgt_1 target:/sys/kernel/config/target/iscsi# mkdir -p `iscsi-name`/tpgt_1 target:/sys/kernel/config/target/iscsi# mkdir -p `iscsi-name`/tpgt_1 target:/sys/kernel/config/target/iscsi# mkdir -p `iscsi-name`/tpgt_1 target:/sys/kernel/config/target/iscsi# tree . |-- iqn.2003-01.org.linux-iscsi.target.i686:sn.11c045e90b | `-- tpgt_1 |-- iqn.2003-01.org.linux-iscsi.target.i686:sn.acc810f5a2fc | `-- tpgt_1 |-- iqn.2003-01.org.linux-iscsi.target.i686:sn.b341232f3595 | `-- tpgt_1 |-- iqn.2003-01.org.linux-iscsi.target.i686:sn.b5ada4ff123a | `-- tpgt_1 |-- iqn.iscsi-hd.renderbox | `-- tpgt_1 |-- iqn.lio-production | `-- tpgt_1 |-- iqn.superturbodiskarray | `-- tpgt_1 |-- iqn.upstreamtargetmodestorage | `-- tpgt_1 `-- lio_version 16 directories, 1 file # Notice the module count.. target:/sys/kernel/config/target/iscsi# lsmod Module Size Used by iscsi_target_mod 369004 17 target_core_configfs 11416 18 iscsi_target_mod configfs 24216 3 iscsi_target_mod,target_core_configfs # Delete the IQNs and TPGTs created with /sbin/iscsi-name prefix.. target:/sys/kernel/config/target/iscsi# rm -rf iqn.2003-01.org.linux-iscsi.target.i686\:sn.* target:/sys/kernel/config/target/iscsi# tree . |-- iqn.iscsi-hd.renderbox | `-- tpgt_1 |-- iqn.lio-production | `-- tpgt_1 |-- iqn.superturbodiskarray | `-- tpgt_1 |-- iqn.upstreamtargetmodestorage | `-- tpgt_1 `-- lio_version 8 directories, 1 file # And the module counts.. target:/sys/kernel/config/target/iscsi# lsmod Module Size Used by iscsi_target_mod 369004 9 target_core_configfs 11416 10 iscsi_target_mod configfs 24216 3 iscsi_target_mod,target_core_configfs --nab :-) > Joel > -- 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