From: Roman Kagan <rkagan@mail.ru>
To: Greg KH <gregkh@suse.de>, linux-hotplug-devel@lists.sourceforge.net
Cc: linux-scsi@vger.kernel.org
Subject: [PATCH] drivers/scsi: add hotplug with MODNAME env var
Date: Fri, 04 Mar 2005 10:49:07 +0000 [thread overview]
Message-ID: <20050304104903.GA2311@katya> (raw)
Hi,
The patch below adds hotplug callout to scsi_bus_type, and makes it
generate MODNAME environment variable for use with modprobe. Also it
adds a few matching MODULE_ALIAS() macros to the appropriate modules.
Two caveats:
1) I'm not particularly certain about the "scsi-type-" prefix: it may
resemble cases where request_module() is used; the reason I used
dashes was that MODULE_ALIAS() macros were put manually into the
code, rather that automatically generated from a corresponding
*_dev_id table;
2) TYPE_* macros in include/scsi/scsi.h are in hex and can't be
conveniently __stringify()-ed, so I've hardcoded the values and
inserted comments next to them referring to those macros.
It handles only sd, sr, st, and osst cases. I'd like to leave it to
scsi folks to decide whether sg should be "scsi-type-*" or the explicit
list of types not handled by other modules.
Roman.
Signed-off-by: Roman Kagan <rkagan@mail.ru>
drivers/scsi/scsi_sysfs.c | 16 ++++++++++++++++
drivers/scsi/sd.c | 2 ++
drivers/scsi/sr.c | 3 +++
drivers/scsi/st.c | 2 ++
drivers/scsi/osst.c | 2 ++
5 files changed, 25 insertions(+)
diff -rup linux-2.6.11/drivers/scsi/scsi_sysfs.c linux-2.6.11.modname/drivers/scsi/scsi_sysfs.c
--- linux-2.6.11/drivers/scsi/scsi_sysfs.c 2005-03-02 10:37:49.000000000 +0300
+++ linux-2.6.11.modname/drivers/scsi/scsi_sysfs.c 2005-03-04 13:18:05.000000000 +0300
@@ -202,9 +202,25 @@ static int scsi_bus_match(struct device
return (sdp->inq_periph_qual = SCSI_INQ_PQ_CON)? 1: 0;
}
+static int scsi_hotplug(struct device *dev, char **envp,
+ int num_envp, char *buffer, int buffer_size)
+{
+ struct scsi_device *sdev = to_scsi_device(dev);
+ int i = 0;
+ int length = 0;
+
+ if (add_hotplug_env_var(envp, num_envp, &i, buffer, buffer_size, &length,
+ "MODNAME=scsi-type-%d", sdev->type))
+ return -ENOMEM;
+
+ envp[i] = NULL;
+ return 0;
+}
+
struct bus_type scsi_bus_type = {
.name = "scsi",
.match = scsi_bus_match,
+ .hotplug = scsi_hotplug,
};
int scsi_sysfs_register(void)
diff -rup linux-2.6.11/drivers/scsi/sd.c linux-2.6.11.modname/drivers/scsi/sd.c
--- linux-2.6.11/drivers/scsi/sd.c 2005-03-02 10:38:17.000000000 +0300
+++ linux-2.6.11.modname/drivers/scsi/sd.c 2005-03-04 13:16:22.000000000 +0300
@@ -1653,6 +1653,8 @@ static void __exit exit_sd(void)
MODULE_LICENSE("GPL");
MODULE_AUTHOR("Eric Youngdale");
MODULE_DESCRIPTION("SCSI disk (sd) driver");
+MODULE_ALIAS("scsi-type-0"); /* TYPE_DISK */
+MODULE_ALIAS("scsi-type-7"); /* TYPE_MOD */
module_init(init_sd);
module_exit(exit_sd);
diff -rup linux-2.6.11/drivers/scsi/sr.c linux-2.6.11.modname/drivers/scsi/sr.c
--- linux-2.6.11/drivers/scsi/sr.c 2005-03-02 10:38:37.000000000 +0300
+++ linux-2.6.11.modname/drivers/scsi/sr.c 2005-03-04 13:16:22.000000000 +0300
@@ -956,6 +956,9 @@ static void __exit exit_sr(void)
unregister_blkdev(SCSI_CDROM_MAJOR, "sr");
}
+MODULE_ALIAS("scsi-type-4"); /* TYPE_WORM */
+MODULE_ALIAS("scsi-type-5"); /* TYPE_ROM */
+
module_init(init_sr);
module_exit(exit_sr);
MODULE_LICENSE("GPL");
diff -rup linux-2.6.11/drivers/scsi/st.c linux-2.6.11.modname/drivers/scsi/st.c
--- linux-2.6.11/drivers/scsi/st.c 2005-03-02 10:38:12.000000000 +0300
+++ linux-2.6.11.modname/drivers/scsi/st.c 2005-03-04 13:16:22.000000000 +0300
@@ -4090,6 +4090,8 @@ static void __exit exit_st(void)
printk(KERN_INFO "st: Unloaded.\n");
}
+MODULE_ALIAS("scsi-type-1"); /* TYPE_TAPE */
+
module_init(init_st);
module_exit(exit_st);
diff -rup linux-2.6.11/drivers/scsi/osst.c linux-2.6.11.modname/drivers/scsi/osst.c
--- linux-2.6.11/drivers/scsi/osst.c 2005-03-02 10:38:08.000000000 +0300
+++ linux-2.6.11.modname/drivers/scsi/osst.c 2005-03-04 13:20:45.000000000 +0300
@@ -5888,5 +5888,7 @@ static void __exit exit_osst (void)
printk(KERN_INFO "osst :I: Unloaded.\n");
}
+MODULE_ALIAS("scsi-type-1"); /* TYPE_TAPE */
+
module_init(init_osst);
module_exit(exit_osst);
-------------------------------------------------------
SF email is sponsored by - The IT Product Guide
Read honest & candid reviews on hundreds of IT Products from real users.
Discover which products truly live up to the hype. Start reading now.
http://ads.osdn.com/?ad_ide95&alloc_id\x14396&op=click
_______________________________________________
Linux-hotplug-devel mailing list http://linux-hotplug.sourceforge.net
Linux-hotplug-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/linux-hotplug-devel
reply other threads:[~2005-03-04 10:49 UTC|newest]
Thread overview: [no followups] expand[flat|nested] mbox.gz Atom feed
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20050304104903.GA2311@katya \
--to=rkagan@mail.ru \
--cc=gregkh@suse.de \
--cc=linux-hotplug-devel@lists.sourceforge.net \
--cc=linux-scsi@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).