[PATCH] I2O: second code cleanup of sparse warnings and unneeded syncronization
Changes: - Added header "core.h" for i2o_core.ko internal definitions - More sparse fixes - Changed display of TID's in sysfs attributes from XXX to 0xXXX - Use the right functions for accessing I/O and normal memory - Removed error handling of SCSI device errors and let the SCSI layer take care of it - Added new device / removed device handling to SCSI-OSM - Make status access volatile - Cleaned up activation of I2O controller - Removed unnecessary wmb() and rmb() calls - Use own struct i2o_io for I/O memory instead of struct i2o_dma Signed-off-by: Markus Lidel <Markus.Lidel@shadowconnect.com> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
This commit is contained in:

committed by
Linus Torvalds

parent
b2aaee33fb
commit
9e87545f06
@@ -16,9 +16,7 @@
|
||||
#include <linux/module.h>
|
||||
#include <linux/i2o.h>
|
||||
#include <linux/delay.h>
|
||||
|
||||
/* Exec OSM functions */
|
||||
extern struct bus_type i2o_bus_type;
|
||||
#include "core.h"
|
||||
|
||||
/**
|
||||
* i2o_device_issue_claim - claim or release a device
|
||||
@@ -293,12 +291,12 @@ int i2o_device_parse_lct(struct i2o_controller *c)
|
||||
}
|
||||
|
||||
if (lct->table_size * 4 > c->dlct.len) {
|
||||
memcpy_fromio(c->lct, c->dlct.virt, c->dlct.len);
|
||||
memcpy(c->lct, c->dlct.virt, c->dlct.len);
|
||||
up(&c->lct_lock);
|
||||
return -EAGAIN;
|
||||
}
|
||||
|
||||
memcpy_fromio(c->lct, c->dlct.virt, lct->table_size * 4);
|
||||
memcpy(c->lct, c->dlct.virt, lct->table_size * 4);
|
||||
|
||||
lct = c->lct;
|
||||
|
||||
@@ -353,7 +351,7 @@ static ssize_t i2o_device_class_show_class_id(struct class_device *cd,
|
||||
{
|
||||
struct i2o_device *dev = to_i2o_device(cd->dev);
|
||||
|
||||
sprintf(buf, "%03x\n", dev->lct_data.class_id);
|
||||
sprintf(buf, "0x%03x\n", dev->lct_data.class_id);
|
||||
return strlen(buf) + 1;
|
||||
};
|
||||
|
||||
@@ -368,7 +366,7 @@ static ssize_t i2o_device_class_show_tid(struct class_device *cd, char *buf)
|
||||
{
|
||||
struct i2o_device *dev = to_i2o_device(cd->dev);
|
||||
|
||||
sprintf(buf, "%03x\n", dev->lct_data.tid);
|
||||
sprintf(buf, "0x%03x\n", dev->lct_data.tid);
|
||||
return strlen(buf) + 1;
|
||||
};
|
||||
|
||||
@@ -490,7 +488,7 @@ static int i2o_parm_issue(struct i2o_device *i2o_dev, int cmd, void *oplist,
|
||||
if (rc == -ETIMEDOUT)
|
||||
return rc;
|
||||
|
||||
memcpy_fromio(reslist, res.virt, res.len);
|
||||
memcpy(reslist, res.virt, res.len);
|
||||
i2o_dma_free(dev, &res);
|
||||
|
||||
/* Query failed */
|
||||
@@ -532,17 +530,23 @@ int i2o_parm_field_get(struct i2o_device *i2o_dev, int group, int field,
|
||||
void *buf, int buflen)
|
||||
{
|
||||
u16 opblk[] = { 1, 0, I2O_PARAMS_FIELD_GET, group, 1, field };
|
||||
u8 resblk[8 + buflen]; /* 8 bytes for header */
|
||||
u8 *resblk; /* 8 bytes for header */
|
||||
int size;
|
||||
|
||||
if (field == -1) /* whole group */
|
||||
opblk[4] = -1;
|
||||
|
||||
resblk = kmalloc(buflen + 8, GFP_KERNEL | GFP_ATOMIC);
|
||||
if (!resblk)
|
||||
return -ENOMEM;
|
||||
|
||||
size = i2o_parm_issue(i2o_dev, I2O_CMD_UTIL_PARAMS_GET, opblk,
|
||||
sizeof(opblk), resblk, buflen + 8);
|
||||
|
||||
memcpy(buf, resblk + 8, buflen); /* cut off header */
|
||||
|
||||
kfree(resblk);
|
||||
|
||||
if (size > buflen)
|
||||
return buflen;
|
||||
|
||||
|
Reference in New Issue
Block a user