aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/scsi/scsi_sysfs.c
diff options
context:
space:
mode:
authorVikas Chaudhary <vikas.chaudhary@qlogic.com>2011-08-12 05:51:28 -0400
committerJames Bottomley <JBottomley@Parallels.com>2011-08-27 10:36:46 -0400
commit2944369144548432f3a5ffce7a2926bfb4ce4f0a (patch)
treec42de87060c88ed22224e828fbd81a83f33a03e7 /drivers/scsi/scsi_sysfs.c
parent6085491c34b37fa806f70ccd3fb2bf08416e9e98 (diff)
[SCSI] scsi: Added support for adapter and firmware reset
Added new sysfs attr 'host_reset' in scsi_sysfs.c to perform adapter or firmware reset as suggested by Mike Christie here: http://marc.info/?l=linux-scsi&m=127359347111167&w=2 user/application can write "adapter" or "firmware" on this attr and it will call newly added function hook in scsi_host_template to call LDD adapter or firmware reset implementation. Signed-off-by: Vikas Chaudhary <vikas.chaudhary@qlogic.com> Reviewed-by: Mike Christie <michaelc@cs.wisc.edu> Signed-off-by: James Bottomley <JBottomley@Parallels.com>
Diffstat (limited to 'drivers/scsi/scsi_sysfs.c')
-rw-r--r--drivers/scsi/scsi_sysfs.c38
1 files changed, 38 insertions, 0 deletions
diff --git a/drivers/scsi/scsi_sysfs.c b/drivers/scsi/scsi_sysfs.c
index e0bd3f790fca..04c2a278076e 100644
--- a/drivers/scsi/scsi_sysfs.c
+++ b/drivers/scsi/scsi_sysfs.c
@@ -246,6 +246,43 @@ show_shost_active_mode(struct device *dev,
246 246
247static DEVICE_ATTR(active_mode, S_IRUGO | S_IWUSR, show_shost_active_mode, NULL); 247static DEVICE_ATTR(active_mode, S_IRUGO | S_IWUSR, show_shost_active_mode, NULL);
248 248
249static int check_reset_type(char *str)
250{
251 if (strncmp(str, "adapter", 10) == 0)
252 return SCSI_ADAPTER_RESET;
253 else if (strncmp(str, "firmware", 10) == 0)
254 return SCSI_FIRMWARE_RESET;
255 else
256 return 0;
257}
258
259static ssize_t
260store_host_reset(struct device *dev, struct device_attribute *attr,
261 const char *buf, size_t count)
262{
263 struct Scsi_Host *shost = class_to_shost(dev);
264 struct scsi_host_template *sht = shost->hostt;
265 int ret = -EINVAL;
266 char str[10];
267 int type;
268
269 sscanf(buf, "%s", str);
270 type = check_reset_type(str);
271
272 if (!type)
273 goto exit_store_host_reset;
274
275 if (sht->host_reset)
276 ret = sht->host_reset(shost, type);
277
278exit_store_host_reset:
279 if (ret == 0)
280 ret = count;
281 return ret;
282}
283
284static DEVICE_ATTR(host_reset, S_IWUSR, NULL, store_host_reset);
285
249shost_rd_attr(unique_id, "%u\n"); 286shost_rd_attr(unique_id, "%u\n");
250shost_rd_attr(host_busy, "%hu\n"); 287shost_rd_attr(host_busy, "%hu\n");
251shost_rd_attr(cmd_per_lun, "%hd\n"); 288shost_rd_attr(cmd_per_lun, "%hd\n");
@@ -272,6 +309,7 @@ static struct attribute *scsi_sysfs_shost_attrs[] = {
272 &dev_attr_active_mode.attr, 309 &dev_attr_active_mode.attr,
273 &dev_attr_prot_capabilities.attr, 310 &dev_attr_prot_capabilities.attr,
274 &dev_attr_prot_guard_type.attr, 311 &dev_attr_prot_guard_type.attr,
312 &dev_attr_host_reset.attr,
275 NULL 313 NULL
276}; 314};
277 315