Commit 0aca7844 authored by Benjamin Romer's avatar Benjamin Romer Committed by Greg Kroah-Hartman

staging: unisys: remove ERRDEV macros

Remove the LOGERR, LOGERRDEV, LOGERRDEVX, LOGERRNAME, LOGORDUMPERR
macros from all the drivers.

In one case the removal of the ERRDRV() changed things such that a macro which
returned a value was needed, but the return value was no longer being used. In
this case the macro was replaced with the contents of the macro, but with the
truth calculation removed so that it would not generate a warning.
Signed-off-by: default avatarBenjamin Romer <benjamin.romer@unisys.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 61620a1b
...@@ -78,9 +78,6 @@ ...@@ -78,9 +78,6 @@
(void *)(p2) = SWAPPOINTERS_TEMP; \ (void *)(p2) = SWAPPOINTERS_TEMP; \
} while (0) } while (0)
#define TBDDRV(fmt, args...) LOGERR(fmt, ## args)
#define HUHDRV(fmt, args...) LOGERR(fmt, ## args)
#define ERRDRV(fmt, args...) LOGERR(fmt, ## args)
#define WARNDRV(fmt, args...) LOGWRN(fmt, ## args) #define WARNDRV(fmt, args...) LOGWRN(fmt, ## args)
#define SECUREDRV(fmt, args...) LOGWRN(fmt, ## args) #define SECUREDRV(fmt, args...) LOGWRN(fmt, ## args)
......
...@@ -184,10 +184,8 @@ wait_for_valid_guid(uuid_le __iomem *guid) ...@@ -184,10 +184,8 @@ wait_for_valid_guid(uuid_le __iomem *guid)
(void __iomem *)guid, sizeof(uuid_le)); (void __iomem *)guid, sizeof(uuid_le));
if (uuid_le_cmp(tmpguid, NULL_UUID_LE) != 0) if (uuid_le_cmp(tmpguid, NULL_UUID_LE) != 0)
break; break;
LOGERR("Waiting for non-0 GUID (why???)...\n");
UIS_THREAD_WAIT_SEC(5); UIS_THREAD_WAIT_SEC(5);
} }
LOGERR("OK... GUID is non-0 now\n");
} }
static inline unsigned int static inline unsigned int
......
...@@ -25,44 +25,6 @@ ...@@ -25,44 +25,6 @@
#include <linux/printk.h> #include <linux/printk.h>
/*
* # LOGERR
*
* \brief Log error message - logs a message at the LOG_ERR level,
* including source line number information
*
* \param devname the device name of the device reporting this message, or
* NULL if this message is NOT device-related.
* \param fmt printf()-style format string containing the message to log.
* \param args Optional arguments to be formatted and inserted into the format
* \param string.
* \return nothing
*
* Logs the specified error message at the LOG_ERR level. It will also
* include the file, line number, and function name of where the error
* originated in the log message.
*/
#define LOGERR(fmt, args...) pr_err(fmt, ## args)
#define LOGERRDEV(devname, fmt, args...) \
pr_err("%s " fmt, devname, ## args)
#define LOGERRDEVX(devno, fmt, args...) \
pr_err("dev%d " fmt, devno, ## args)
#define LOGERRNAME(vnic, fmt, args...) \
do { \
if (vnic != NULL) { \
pr_err("%s " fmt, vnic->name, ## args); \
} else { \
pr_err(fmt, ## args); \
} \
} while (0)
#define LOGORDUMPERR(seqfile, fmt, args...) do { \
if (seqfile) { \
seq_printf(seqfile, fmt, ## args); \
} else { \
LOGERR(fmt, ## args); \
} \
} while (0)
/* /*
* # LOGWRN * # LOGWRN
* *
......
...@@ -132,14 +132,10 @@ static __iomem void *init_vbus_channel(u64 ch_addr, u32 ch_bytes) ...@@ -132,14 +132,10 @@ static __iomem void *init_vbus_channel(u64 ch_addr, u32 ch_bytes)
{ {
void __iomem *ch = uislib_ioremap_cache(ch_addr, ch_bytes); void __iomem *ch = uislib_ioremap_cache(ch_addr, ch_bytes);
if (!ch) { if (!ch)
LOGERR("CONTROLVM_BUS_CREATE error: ioremap_cache of channelAddr:%Lx for channelBytes:%llu failed",
(unsigned long long)ch_addr,
(unsigned long long)ch_bytes);
return NULL; return NULL;
}
if (!SPAR_VBUS_CHANNEL_OK_CLIENT(ch)) { if (!SPAR_VBUS_CHANNEL_OK_CLIENT(ch)) {
ERRDRV("%s channel cannot be used", __func__);
uislib_iounmap(ch); uislib_iounmap(ch);
return NULL; return NULL;
} }
...@@ -154,8 +150,6 @@ create_bus(struct controlvm_message *msg, char *buf) ...@@ -154,8 +150,6 @@ create_bus(struct controlvm_message *msg, char *buf)
size_t size; size_t size;
if (max_bus_count == bus_list_count) { if (max_bus_count == bus_list_count) {
LOGERR("CONTROLVM_BUS_CREATE Failed: max buses:%d already created\n",
max_bus_count);
POSTCODE_LINUX_3(BUS_CREATE_FAILURE_PC, max_bus_count, POSTCODE_LINUX_3(BUS_CREATE_FAILURE_PC, max_bus_count,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
return CONTROLVM_RESP_ERROR_MAX_BUSES; return CONTROLVM_RESP_ERROR_MAX_BUSES;
...@@ -208,8 +202,6 @@ create_bus(struct controlvm_message *msg, char *buf) ...@@ -208,8 +202,6 @@ create_bus(struct controlvm_message *msg, char *buf)
/* found a bus already in the list with same bus_no - /* found a bus already in the list with same bus_no -
* reject add * reject add
*/ */
LOGERR("CONTROLVM_BUS_CREATE Failed: bus %d already exists.\n",
bus->bus_no);
POSTCODE_LINUX_3(BUS_CREATE_FAILURE_PC, bus->bus_no, POSTCODE_LINUX_3(BUS_CREATE_FAILURE_PC, bus->bus_no,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
kfree(bus); kfree(bus);
...@@ -233,14 +225,12 @@ create_bus(struct controlvm_message *msg, char *buf) ...@@ -233,14 +225,12 @@ create_bus(struct controlvm_message *msg, char *buf)
cmd.add_vbus.bus_uuid = msg->cmd.create_bus.bus_data_type_uuid; cmd.add_vbus.bus_uuid = msg->cmd.create_bus.bus_data_type_uuid;
cmd.add_vbus.instance_uuid = msg->cmd.create_bus.bus_inst_uuid; cmd.add_vbus.instance_uuid = msg->cmd.create_bus.bus_inst_uuid;
if (!virt_control_chan_func) { if (!virt_control_chan_func) {
LOGERR("CONTROLVM_BUS_CREATE Failed: virtpci callback not registered.");
POSTCODE_LINUX_3(BUS_CREATE_FAILURE_PC, bus->bus_no, POSTCODE_LINUX_3(BUS_CREATE_FAILURE_PC, bus->bus_no,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
kfree(bus); kfree(bus);
return CONTROLVM_RESP_ERROR_VIRTPCI_DRIVER_FAILURE; return CONTROLVM_RESP_ERROR_VIRTPCI_DRIVER_FAILURE;
} }
if (!virt_control_chan_func(&cmd)) { if (!virt_control_chan_func(&cmd)) {
LOGERR("CONTROLVM_BUS_CREATE Failed: virtpci GUEST_ADD_VBUS returned error.");
POSTCODE_LINUX_3(BUS_CREATE_FAILURE_PC, bus->bus_no, POSTCODE_LINUX_3(BUS_CREATE_FAILURE_PC, bus->bus_no,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
kfree(bus); kfree(bus);
...@@ -286,8 +276,6 @@ destroy_bus(struct controlvm_message *msg, char *buf) ...@@ -286,8 +276,6 @@ destroy_bus(struct controlvm_message *msg, char *buf)
} }
if (!bus) { if (!bus) {
LOGERR("CONTROLVM_BUS_DESTROY Failed: failed to find bus %d.\n",
bus_no);
read_unlock(&bus_list_lock); read_unlock(&bus_list_lock);
return CONTROLVM_RESP_ERROR_ALREADY_DONE; return CONTROLVM_RESP_ERROR_ALREADY_DONE;
} }
...@@ -295,8 +283,6 @@ destroy_bus(struct controlvm_message *msg, char *buf) ...@@ -295,8 +283,6 @@ destroy_bus(struct controlvm_message *msg, char *buf)
/* verify that this bus has no devices. */ /* verify that this bus has no devices. */
for (i = 0; i < bus->device_count; i++) { for (i = 0; i < bus->device_count; i++) {
if (bus->device[i] != NULL) { if (bus->device[i] != NULL) {
LOGERR("CONTROLVM_BUS_DESTROY Failed: device %i attached to bus %d.",
i, bus_no);
read_unlock(&bus_list_lock); read_unlock(&bus_list_lock);
return CONTROLVM_RESP_ERROR_BUS_DEVICE_ATTACHED; return CONTROLVM_RESP_ERROR_BUS_DEVICE_ATTACHED;
} }
...@@ -310,14 +296,11 @@ destroy_bus(struct controlvm_message *msg, char *buf) ...@@ -310,14 +296,11 @@ destroy_bus(struct controlvm_message *msg, char *buf)
with this bus. */ with this bus. */
cmd.msgtype = GUEST_DEL_VBUS; cmd.msgtype = GUEST_DEL_VBUS;
cmd.del_vbus.bus_no = bus_no; cmd.del_vbus.bus_no = bus_no;
if (!virt_control_chan_func) { if (!virt_control_chan_func)
LOGERR("CONTROLVM_BUS_DESTROY Failed: virtpci callback not registered.");
return CONTROLVM_RESP_ERROR_VIRTPCI_DRIVER_FAILURE; return CONTROLVM_RESP_ERROR_VIRTPCI_DRIVER_FAILURE;
}
if (!virt_control_chan_func(&cmd)) { if (!virt_control_chan_func(&cmd))
LOGERR("CONTROLVM_BUS_DESTROY Failed: virtpci GUEST_DEL_VBUS returned error.");
return CONTROLVM_RESP_ERROR_VIRTPCI_DRIVER_CALLBACK_ERROR; return CONTROLVM_RESP_ERROR_VIRTPCI_DRIVER_CALLBACK_ERROR;
}
/* finally, remove the bus from the list */ /* finally, remove the bus from the list */
remove: remove:
...@@ -379,9 +362,6 @@ static int create_device(struct controlvm_message *msg, char *buf) ...@@ -379,9 +362,6 @@ static int create_device(struct controlvm_message *msg, char *buf)
*/ */
min_size = req_handler->min_channel_bytes; min_size = req_handler->min_channel_bytes;
if (min_size > msg->cmd.create_device.channel_bytes) { if (min_size > msg->cmd.create_device.channel_bytes) {
LOGERR("CONTROLVM_DEVICE_CREATE Failed: channel size is too small, channel size:0x%lx, required size:0x%lx",
(ulong)msg->cmd.create_device.channel_bytes,
(ulong)min_size);
POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC, dev_no, POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC, dev_no,
bus_no, POSTCODE_SEVERITY_ERR); bus_no, POSTCODE_SEVERITY_ERR);
result = CONTROLVM_RESP_ERROR_CHANNEL_SIZE_TOO_SMALL; result = CONTROLVM_RESP_ERROR_CHANNEL_SIZE_TOO_SMALL;
...@@ -391,9 +371,6 @@ static int create_device(struct controlvm_message *msg, char *buf) ...@@ -391,9 +371,6 @@ static int create_device(struct controlvm_message *msg, char *buf)
uislib_ioremap_cache(dev->channel_addr, uislib_ioremap_cache(dev->channel_addr,
msg->cmd.create_device.channel_bytes); msg->cmd.create_device.channel_bytes);
if (!dev->chanptr) { if (!dev->chanptr) {
LOGERR("CONTROLVM_DEVICE_CREATE Failed: ioremap_cache of channelAddr:%Lx for channelBytes:%llu failed",
dev->channel_addr,
msg->cmd.create_device.channel_bytes);
result = CONTROLVM_RESP_ERROR_IOREMAP_FAILED; result = CONTROLVM_RESP_ERROR_IOREMAP_FAILED;
POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC, dev_no, POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC, dev_no,
bus_no, POSTCODE_SEVERITY_ERR); bus_no, POSTCODE_SEVERITY_ERR);
...@@ -409,8 +386,6 @@ static int create_device(struct controlvm_message *msg, char *buf) ...@@ -409,8 +386,6 @@ static int create_device(struct controlvm_message *msg, char *buf)
continue; continue;
/* make sure the device number is valid */ /* make sure the device number is valid */
if (dev_no >= bus->device_count) { if (dev_no >= bus->device_count) {
LOGERR("CONTROLVM_DEVICE_CREATE Failed: device (%d) >= deviceCount (%d).",
dev_no, bus->device_count);
result = CONTROLVM_RESP_ERROR_MAX_DEVICES; result = CONTROLVM_RESP_ERROR_MAX_DEVICES;
POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC, dev_no, POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC, dev_no,
bus_no, POSTCODE_SEVERITY_ERR); bus_no, POSTCODE_SEVERITY_ERR);
...@@ -419,8 +394,6 @@ static int create_device(struct controlvm_message *msg, char *buf) ...@@ -419,8 +394,6 @@ static int create_device(struct controlvm_message *msg, char *buf)
} }
/* make sure this device is not already set */ /* make sure this device is not already set */
if (bus->device[dev_no]) { if (bus->device[dev_no]) {
LOGERR("CONTROLVM_DEVICE_CREATE Failed: device %d is already exists.",
dev_no);
POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC, POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC,
dev_no, bus_no, dev_no, bus_no,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
...@@ -443,8 +416,6 @@ static int create_device(struct controlvm_message *msg, char *buf) ...@@ -443,8 +416,6 @@ static int create_device(struct controlvm_message *msg, char *buf)
wait_for_valid_guid(&((struct channel_header __iomem *) wait_for_valid_guid(&((struct channel_header __iomem *)
(dev->chanptr))->chtype); (dev->chanptr))->chtype);
if (!SPAR_VHBA_CHANNEL_OK_CLIENT(dev->chanptr)) { if (!SPAR_VHBA_CHANNEL_OK_CLIENT(dev->chanptr)) {
LOGERR("CONTROLVM_DEVICE_CREATE Failed:[CLIENT]VHBA dev %d chan invalid.",
dev_no);
POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC, POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC,
dev_no, bus_no, dev_no, bus_no,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
...@@ -462,8 +433,6 @@ static int create_device(struct controlvm_message *msg, char *buf) ...@@ -462,8 +433,6 @@ static int create_device(struct controlvm_message *msg, char *buf)
wait_for_valid_guid(&((struct channel_header __iomem *) wait_for_valid_guid(&((struct channel_header __iomem *)
(dev->chanptr))->chtype); (dev->chanptr))->chtype);
if (!SPAR_VNIC_CHANNEL_OK_CLIENT(dev->chanptr)) { if (!SPAR_VNIC_CHANNEL_OK_CLIENT(dev->chanptr)) {
LOGERR("CONTROLVM_DEVICE_CREATE Failed: VNIC[CLIENT] dev %d chan invalid.",
dev_no);
POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC, POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC,
dev_no, bus_no, dev_no, bus_no,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
...@@ -477,7 +446,6 @@ static int create_device(struct controlvm_message *msg, char *buf) ...@@ -477,7 +446,6 @@ static int create_device(struct controlvm_message *msg, char *buf)
cmd.add_vnic.instance_uuid = dev->instance_uuid; cmd.add_vnic.instance_uuid = dev->instance_uuid;
cmd.add_vhba.intr = dev->intr; cmd.add_vhba.intr = dev->intr;
} else { } else {
LOGERR("CONTROLVM_DEVICE_CREATE Failed: unknown channelTypeGuid.\n");
POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC, dev_no, POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC, dev_no,
bus_no, POSTCODE_SEVERITY_ERR); bus_no, POSTCODE_SEVERITY_ERR);
result = CONTROLVM_RESP_ERROR_CHANNEL_TYPE_UNKNOWN; result = CONTROLVM_RESP_ERROR_CHANNEL_TYPE_UNKNOWN;
...@@ -485,7 +453,6 @@ static int create_device(struct controlvm_message *msg, char *buf) ...@@ -485,7 +453,6 @@ static int create_device(struct controlvm_message *msg, char *buf)
} }
if (!virt_control_chan_func) { if (!virt_control_chan_func) {
LOGERR("CONTROLVM_DEVICE_CREATE Failed: virtpci callback not registered.");
POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC, dev_no, POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC, dev_no,
bus_no, POSTCODE_SEVERITY_ERR); bus_no, POSTCODE_SEVERITY_ERR);
result = CONTROLVM_RESP_ERROR_VIRTPCI_DRIVER_FAILURE; result = CONTROLVM_RESP_ERROR_VIRTPCI_DRIVER_FAILURE;
...@@ -493,7 +460,6 @@ static int create_device(struct controlvm_message *msg, char *buf) ...@@ -493,7 +460,6 @@ static int create_device(struct controlvm_message *msg, char *buf)
} }
if (!virt_control_chan_func(&cmd)) { if (!virt_control_chan_func(&cmd)) {
LOGERR("CONTROLVM_DEVICE_CREATE Failed: virtpci GUEST_ADD_[VHBA||VNIC] returned error.");
POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC, dev_no, POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC, dev_no,
bus_no, POSTCODE_SEVERITY_ERR); bus_no, POSTCODE_SEVERITY_ERR);
result = result =
...@@ -508,8 +474,6 @@ static int create_device(struct controlvm_message *msg, char *buf) ...@@ -508,8 +474,6 @@ static int create_device(struct controlvm_message *msg, char *buf)
} }
read_unlock(&bus_list_lock); read_unlock(&bus_list_lock);
LOGERR("CONTROLVM_DEVICE_CREATE Failed: failed to find bus %d.",
bus_no);
POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC, dev_no, bus_no, POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC, dev_no, bus_no,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
result = CONTROLVM_RESP_ERROR_BUS_INVALID; result = CONTROLVM_RESP_ERROR_BUS_INVALID;
...@@ -540,15 +504,11 @@ static int pause_device(struct controlvm_message *msg) ...@@ -540,15 +504,11 @@ static int pause_device(struct controlvm_message *msg)
if (bus->bus_no == bus_no) { if (bus->bus_no == bus_no) {
/* make sure the device number is valid */ /* make sure the device number is valid */
if (dev_no >= bus->device_count) { if (dev_no >= bus->device_count) {
LOGERR("CONTROLVM_DEVICE_CHANGESTATE:pause Failed: device(%d) >= deviceCount(%d).",
dev_no, bus->device_count);
retval = CONTROLVM_RESP_ERROR_DEVICE_INVALID; retval = CONTROLVM_RESP_ERROR_DEVICE_INVALID;
} else { } else {
/* make sure this device exists */ /* make sure this device exists */
dev = bus->device[dev_no]; dev = bus->device[dev_no];
if (!dev) { if (!dev) {
LOGERR("CONTROLVM_DEVICE_CHANGESTATE:pause Failed: device %d does not exist.",
dev_no);
retval = retval =
CONTROLVM_RESP_ERROR_ALREADY_DONE; CONTROLVM_RESP_ERROR_ALREADY_DONE;
} }
...@@ -556,11 +516,9 @@ static int pause_device(struct controlvm_message *msg) ...@@ -556,11 +516,9 @@ static int pause_device(struct controlvm_message *msg)
break; break;
} }
} }
if (!bus) { if (!bus)
LOGERR("CONTROLVM_DEVICE_CHANGESTATE:pause Failed: bus %d does not exist",
bus_no);
retval = CONTROLVM_RESP_ERROR_BUS_INVALID; retval = CONTROLVM_RESP_ERROR_BUS_INVALID;
}
read_unlock(&bus_list_lock); read_unlock(&bus_list_lock);
if (retval == CONTROLVM_RESP_SUCCESS) { if (retval == CONTROLVM_RESP_SUCCESS) {
/* the msg is bound for virtpci; send /* the msg is bound for virtpci; send
...@@ -575,15 +533,12 @@ static int pause_device(struct controlvm_message *msg) ...@@ -575,15 +533,12 @@ static int pause_device(struct controlvm_message *msg)
cmd.msgtype = GUEST_PAUSE_VNIC; cmd.msgtype = GUEST_PAUSE_VNIC;
cmd.pause_vnic.chanptr = dev->chanptr; cmd.pause_vnic.chanptr = dev->chanptr;
} else { } else {
LOGERR("CONTROLVM_DEVICE_CHANGESTATE:pause Failed: unknown channelTypeGuid.\n");
return CONTROLVM_RESP_ERROR_CHANNEL_TYPE_UNKNOWN; return CONTROLVM_RESP_ERROR_CHANNEL_TYPE_UNKNOWN;
} }
if (!virt_control_chan_func) { if (!virt_control_chan_func) {
LOGERR("CONTROLVM_DEVICE_CHANGESTATE Failed: virtpci callback not registered.");
return CONTROLVM_RESP_ERROR_VIRTPCI_DRIVER_FAILURE; return CONTROLVM_RESP_ERROR_VIRTPCI_DRIVER_FAILURE;
} }
if (!virt_control_chan_func(&cmd)) { if (!virt_control_chan_func(&cmd)) {
LOGERR("CONTROLVM_DEVICE_CHANGESTATE:pause Failed: virtpci GUEST_PAUSE_[VHBA||VNIC] returned error.");
return return
CONTROLVM_RESP_ERROR_VIRTPCI_DRIVER_CALLBACK_ERROR; CONTROLVM_RESP_ERROR_VIRTPCI_DRIVER_CALLBACK_ERROR;
} }
...@@ -607,15 +562,11 @@ static int resume_device(struct controlvm_message *msg) ...@@ -607,15 +562,11 @@ static int resume_device(struct controlvm_message *msg)
if (bus->bus_no == bus_no) { if (bus->bus_no == bus_no) {
/* make sure the device number is valid */ /* make sure the device number is valid */
if (dev_no >= bus->device_count) { if (dev_no >= bus->device_count) {
LOGERR("CONTROLVM_DEVICE_CHANGESTATE:resume Failed: device(%d) >= deviceCount(%d).",
dev_no, bus->device_count);
retval = CONTROLVM_RESP_ERROR_DEVICE_INVALID; retval = CONTROLVM_RESP_ERROR_DEVICE_INVALID;
} else { } else {
/* make sure this device exists */ /* make sure this device exists */
dev = bus->device[dev_no]; dev = bus->device[dev_no];
if (!dev) { if (!dev) {
LOGERR("CONTROLVM_DEVICE_CHANGESTATE:resume Failed: device %d does not exist.",
dev_no);
retval = retval =
CONTROLVM_RESP_ERROR_ALREADY_DONE; CONTROLVM_RESP_ERROR_ALREADY_DONE;
} }
...@@ -624,11 +575,9 @@ static int resume_device(struct controlvm_message *msg) ...@@ -624,11 +575,9 @@ static int resume_device(struct controlvm_message *msg)
} }
} }
if (!bus) { if (!bus)
LOGERR("CONTROLVM_DEVICE_CHANGESTATE:resume Failed: bus %d does not exist",
bus_no);
retval = CONTROLVM_RESP_ERROR_BUS_INVALID; retval = CONTROLVM_RESP_ERROR_BUS_INVALID;
}
read_unlock(&bus_list_lock); read_unlock(&bus_list_lock);
/* the msg is bound for virtpci; send /* the msg is bound for virtpci; send
* guest_msgs struct to callback * guest_msgs struct to callback
...@@ -643,15 +592,12 @@ static int resume_device(struct controlvm_message *msg) ...@@ -643,15 +592,12 @@ static int resume_device(struct controlvm_message *msg)
cmd.msgtype = GUEST_RESUME_VNIC; cmd.msgtype = GUEST_RESUME_VNIC;
cmd.resume_vnic.chanptr = dev->chanptr; cmd.resume_vnic.chanptr = dev->chanptr;
} else { } else {
LOGERR("CONTROLVM_DEVICE_CHANGESTATE:resume Failed: unknown channelTypeGuid.\n");
return CONTROLVM_RESP_ERROR_CHANNEL_TYPE_UNKNOWN; return CONTROLVM_RESP_ERROR_CHANNEL_TYPE_UNKNOWN;
} }
if (!virt_control_chan_func) { if (!virt_control_chan_func) {
LOGERR("CONTROLVM_DEVICE_CHANGESTATE Failed: virtpci callback not registered.");
return CONTROLVM_RESP_ERROR_VIRTPCI_DRIVER_FAILURE; return CONTROLVM_RESP_ERROR_VIRTPCI_DRIVER_FAILURE;
} }
if (!virt_control_chan_func(&cmd)) { if (!virt_control_chan_func(&cmd)) {
LOGERR("CONTROLVM_DEVICE_CHANGESTATE:resume Failed: virtpci GUEST_RESUME_[VHBA||VNIC] returned error.");
return return
CONTROLVM_RESP_ERROR_VIRTPCI_DRIVER_CALLBACK_ERROR; CONTROLVM_RESP_ERROR_VIRTPCI_DRIVER_CALLBACK_ERROR;
} }
...@@ -675,15 +621,11 @@ static int destroy_device(struct controlvm_message *msg, char *buf) ...@@ -675,15 +621,11 @@ static int destroy_device(struct controlvm_message *msg, char *buf)
if (bus->bus_no == bus_no) { if (bus->bus_no == bus_no) {
/* make sure the device number is valid */ /* make sure the device number is valid */
if (dev_no >= bus->device_count) { if (dev_no >= bus->device_count) {
LOGERR("CONTROLVM_DEVICE_DESTROY Failed: device(%d) >= device_count(%d).",
dev_no, bus->device_count);
retval = CONTROLVM_RESP_ERROR_DEVICE_INVALID; retval = CONTROLVM_RESP_ERROR_DEVICE_INVALID;
} else { } else {
/* make sure this device exists */ /* make sure this device exists */
dev = bus->device[dev_no]; dev = bus->device[dev_no];
if (!dev) { if (!dev) {
LOGERR("CONTROLVM_DEVICE_DESTROY Failed: device %d does not exist.",
dev_no);
retval = retval =
CONTROLVM_RESP_ERROR_ALREADY_DONE; CONTROLVM_RESP_ERROR_ALREADY_DONE;
} }
...@@ -692,11 +634,8 @@ static int destroy_device(struct controlvm_message *msg, char *buf) ...@@ -692,11 +634,8 @@ static int destroy_device(struct controlvm_message *msg, char *buf)
} }
} }
if (!bus) { if (!bus)
LOGERR("CONTROLVM_DEVICE_DESTROY Failed: bus %d does not exist",
bus_no);
retval = CONTROLVM_RESP_ERROR_BUS_INVALID; retval = CONTROLVM_RESP_ERROR_BUS_INVALID;
}
read_unlock(&bus_list_lock); read_unlock(&bus_list_lock);
if (retval == CONTROLVM_RESP_SUCCESS) { if (retval == CONTROLVM_RESP_SUCCESS) {
/* the msg is bound for virtpci; send /* the msg is bound for virtpci; send
...@@ -711,17 +650,14 @@ static int destroy_device(struct controlvm_message *msg, char *buf) ...@@ -711,17 +650,14 @@ static int destroy_device(struct controlvm_message *msg, char *buf)
cmd.msgtype = GUEST_DEL_VNIC; cmd.msgtype = GUEST_DEL_VNIC;
cmd.del_vnic.chanptr = dev->chanptr; cmd.del_vnic.chanptr = dev->chanptr;
} else { } else {
LOGERR("CONTROLVM_DEVICE_DESTROY Failed: unknown channelTypeGuid.\n");
return return
CONTROLVM_RESP_ERROR_CHANNEL_TYPE_UNKNOWN; CONTROLVM_RESP_ERROR_CHANNEL_TYPE_UNKNOWN;
} }
if (!virt_control_chan_func) { if (!virt_control_chan_func) {
LOGERR("CONTROLVM_DEVICE_DESTROY Failed: virtpci callback not registered.");
return return
CONTROLVM_RESP_ERROR_VIRTPCI_DRIVER_FAILURE; CONTROLVM_RESP_ERROR_VIRTPCI_DRIVER_FAILURE;
} }
if (!virt_control_chan_func(&cmd)) { if (!virt_control_chan_func(&cmd)) {
LOGERR("CONTROLVM_DEVICE_DESTROY Failed: virtpci GUEST_DEL_[VHBA||VNIC] returned error.");
return return
CONTROLVM_RESP_ERROR_VIRTPCI_DRIVER_CALLBACK_ERROR; CONTROLVM_RESP_ERROR_VIRTPCI_DRIVER_CALLBACK_ERROR;
} }
...@@ -774,10 +710,8 @@ static int delete_bus_glue(u32 bus_no) ...@@ -774,10 +710,8 @@ static int delete_bus_glue(u32 bus_no)
init_msg_header(&msg, CONTROLVM_BUS_DESTROY, 0, 0); init_msg_header(&msg, CONTROLVM_BUS_DESTROY, 0, 0);
msg.cmd.destroy_bus.bus_no = bus_no; msg.cmd.destroy_bus.bus_no = bus_no;
if (destroy_bus(&msg, NULL) != CONTROLVM_RESP_SUCCESS) { if (destroy_bus(&msg, NULL) != CONTROLVM_RESP_SUCCESS)
LOGERR("destroy_bus failed. bus_no=0x%x\n", bus_no);
return 0; return 0;
}
return 1; return 1;
} }
...@@ -788,11 +722,8 @@ static int delete_device_glue(u32 bus_no, u32 dev_no) ...@@ -788,11 +722,8 @@ static int delete_device_glue(u32 bus_no, u32 dev_no)
init_msg_header(&msg, CONTROLVM_DEVICE_DESTROY, 0, 0); init_msg_header(&msg, CONTROLVM_DEVICE_DESTROY, 0, 0);
msg.cmd.destroy_device.bus_no = bus_no; msg.cmd.destroy_device.bus_no = bus_no;
msg.cmd.destroy_device.dev_no = dev_no; msg.cmd.destroy_device.dev_no = dev_no;
if (destroy_device(&msg, NULL) != CONTROLVM_RESP_SUCCESS) { if (destroy_device(&msg, NULL) != CONTROLVM_RESP_SUCCESS)
LOGERR("destroy_device failed. bus_no=0x%x dev_no=0x%x\n",
bus_no, dev_no);
return 0; return 0;
}
return 1; return 1;
} }
...@@ -817,10 +748,8 @@ uislib_client_inject_add_bus(u32 bus_no, uuid_le inst_uuid, ...@@ -817,10 +748,8 @@ uislib_client_inject_add_bus(u32 bus_no, uuid_le inst_uuid,
*/ */
msg.cmd.init_chipset.bus_count = 23; msg.cmd.init_chipset.bus_count = 23;
msg.cmd.init_chipset.switch_count = 0; msg.cmd.init_chipset.switch_count = 0;
if (init_chipset(&msg, NULL) != CONTROLVM_RESP_SUCCESS) { if (init_chipset(&msg, NULL) != CONTROLVM_RESP_SUCCESS)
LOGERR("init_chipset failed.\n");
return 0; return 0;
}
POSTCODE_LINUX_3(CHIPSET_INIT_EXIT_PC, bus_no, POSTCODE_LINUX_3(CHIPSET_INIT_EXIT_PC, bus_no,
POSTCODE_SEVERITY_INFO); POSTCODE_SEVERITY_INFO);
} }
...@@ -834,7 +763,6 @@ uislib_client_inject_add_bus(u32 bus_no, uuid_le inst_uuid, ...@@ -834,7 +763,6 @@ uislib_client_inject_add_bus(u32 bus_no, uuid_le inst_uuid,
msg.cmd.create_bus.channel_addr = channel_addr; msg.cmd.create_bus.channel_addr = channel_addr;
msg.cmd.create_bus.channel_bytes = n_channel_bytes; msg.cmd.create_bus.channel_bytes = n_channel_bytes;
if (create_bus(&msg, NULL) != CONTROLVM_RESP_SUCCESS) { if (create_bus(&msg, NULL) != CONTROLVM_RESP_SUCCESS) {
LOGERR("create_bus failed.\n");
POSTCODE_LINUX_3(BUS_CREATE_FAILURE_PC, bus_no, POSTCODE_LINUX_3(BUS_CREATE_FAILURE_PC, bus_no,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
return 0; return 0;
...@@ -863,11 +791,8 @@ uislib_client_inject_pause_vhba(u32 bus_no, u32 dev_no) ...@@ -863,11 +791,8 @@ uislib_client_inject_pause_vhba(u32 bus_no, u32 dev_no)
msg.cmd.device_change_state.dev_no = dev_no; msg.cmd.device_change_state.dev_no = dev_no;
msg.cmd.device_change_state.state = segment_state_standby; msg.cmd.device_change_state.state = segment_state_standby;
rc = pause_device(&msg); rc = pause_device(&msg);
if (rc != CONTROLVM_RESP_SUCCESS) { if (rc != CONTROLVM_RESP_SUCCESS)
LOGERR("VHBA pause_device failed. busNo=0x%x devNo=0x%x\n",
bus_no, dev_no);
return rc; return rc;
}
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(uislib_client_inject_pause_vhba); EXPORT_SYMBOL_GPL(uislib_client_inject_pause_vhba);
...@@ -883,11 +808,8 @@ uislib_client_inject_resume_vhba(u32 bus_no, u32 dev_no) ...@@ -883,11 +808,8 @@ uislib_client_inject_resume_vhba(u32 bus_no, u32 dev_no)
msg.cmd.device_change_state.dev_no = dev_no; msg.cmd.device_change_state.dev_no = dev_no;
msg.cmd.device_change_state.state = segment_state_running; msg.cmd.device_change_state.state = segment_state_running;
rc = resume_device(&msg); rc = resume_device(&msg);
if (rc != CONTROLVM_RESP_SUCCESS) { if (rc != CONTROLVM_RESP_SUCCESS)
LOGERR("VHBA resume_device failed. busNo=0x%x devNo=0x%x\n",
bus_no, dev_no);
return rc; return rc;
}
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(uislib_client_inject_resume_vhba); EXPORT_SYMBOL_GPL(uislib_client_inject_resume_vhba);
...@@ -923,8 +845,6 @@ uislib_client_inject_add_vhba(u32 bus_no, u32 dev_no, ...@@ -923,8 +845,6 @@ uislib_client_inject_add_vhba(u32 bus_no, u32 dev_no,
sizeof(struct irq_info)); sizeof(struct irq_info));
msg.cmd.create_device.channel_addr = phys_chan_addr; msg.cmd.create_device.channel_addr = phys_chan_addr;
if (chan_bytes < MIN_IO_CHANNEL_SIZE) { if (chan_bytes < MIN_IO_CHANNEL_SIZE) {
LOGERR("wrong channel size.chan_bytes = 0x%x IO_CHANNEL_SIZE= 0x%x\n",
chan_bytes, (unsigned int)MIN_IO_CHANNEL_SIZE);
POSTCODE_LINUX_4(VHBA_CREATE_FAILURE_PC, chan_bytes, POSTCODE_LINUX_4(VHBA_CREATE_FAILURE_PC, chan_bytes,
MIN_IO_CHANNEL_SIZE, POSTCODE_SEVERITY_ERR); MIN_IO_CHANNEL_SIZE, POSTCODE_SEVERITY_ERR);
return 0; return 0;
...@@ -932,7 +852,6 @@ uislib_client_inject_add_vhba(u32 bus_no, u32 dev_no, ...@@ -932,7 +852,6 @@ uislib_client_inject_add_vhba(u32 bus_no, u32 dev_no,
msg.cmd.create_device.channel_bytes = chan_bytes; msg.cmd.create_device.channel_bytes = chan_bytes;
msg.cmd.create_device.data_type_uuid = spar_vhba_channel_protocol_uuid; msg.cmd.create_device.data_type_uuid = spar_vhba_channel_protocol_uuid;
if (create_device(&msg, NULL) != CONTROLVM_RESP_SUCCESS) { if (create_device(&msg, NULL) != CONTROLVM_RESP_SUCCESS) {
LOGERR("VHBA create_device failed.\n");
POSTCODE_LINUX_4(VHBA_CREATE_FAILURE_PC, dev_no, bus_no, POSTCODE_LINUX_4(VHBA_CREATE_FAILURE_PC, dev_no, bus_no,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
return 0; return 0;
...@@ -981,8 +900,6 @@ uislib_client_inject_add_vnic(u32 bus_no, u32 dev_no, ...@@ -981,8 +900,6 @@ uislib_client_inject_add_vnic(u32 bus_no, u32 dev_no,
sizeof(struct irq_info)); sizeof(struct irq_info));
msg.cmd.create_device.channel_addr = phys_chan_addr; msg.cmd.create_device.channel_addr = phys_chan_addr;
if (chan_bytes < MIN_IO_CHANNEL_SIZE) { if (chan_bytes < MIN_IO_CHANNEL_SIZE) {
LOGERR("wrong channel size.chan_bytes = 0x%x IO_CHANNEL_SIZE= 0x%x\n",
chan_bytes, (unsigned int)MIN_IO_CHANNEL_SIZE);
POSTCODE_LINUX_4(VNIC_CREATE_FAILURE_PC, chan_bytes, POSTCODE_LINUX_4(VNIC_CREATE_FAILURE_PC, chan_bytes,
MIN_IO_CHANNEL_SIZE, POSTCODE_SEVERITY_ERR); MIN_IO_CHANNEL_SIZE, POSTCODE_SEVERITY_ERR);
return 0; return 0;
...@@ -990,7 +907,6 @@ uislib_client_inject_add_vnic(u32 bus_no, u32 dev_no, ...@@ -990,7 +907,6 @@ uislib_client_inject_add_vnic(u32 bus_no, u32 dev_no,
msg.cmd.create_device.channel_bytes = chan_bytes; msg.cmd.create_device.channel_bytes = chan_bytes;
msg.cmd.create_device.data_type_uuid = spar_vnic_channel_protocol_uuid; msg.cmd.create_device.data_type_uuid = spar_vnic_channel_protocol_uuid;
if (create_device(&msg, NULL) != CONTROLVM_RESP_SUCCESS) { if (create_device(&msg, NULL) != CONTROLVM_RESP_SUCCESS) {
LOGERR("VNIC create_device failed.\n");
POSTCODE_LINUX_4(VNIC_CREATE_FAILURE_PC, dev_no, bus_no, POSTCODE_LINUX_4(VNIC_CREATE_FAILURE_PC, dev_no, bus_no,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
return 0; return 0;
...@@ -1014,8 +930,6 @@ uislib_client_inject_pause_vnic(u32 bus_no, u32 dev_no) ...@@ -1014,8 +930,6 @@ uislib_client_inject_pause_vnic(u32 bus_no, u32 dev_no)
msg.cmd.device_change_state.state = segment_state_standby; msg.cmd.device_change_state.state = segment_state_standby;
rc = pause_device(&msg); rc = pause_device(&msg);
if (rc != CONTROLVM_RESP_SUCCESS) { if (rc != CONTROLVM_RESP_SUCCESS) {
LOGERR("VNIC pause_device failed. busNo=0x%x devNo=0x%x\n",
bus_no, dev_no);
return -1; return -1;
} }
return 0; return 0;
...@@ -1033,11 +947,8 @@ uislib_client_inject_resume_vnic(u32 bus_no, u32 dev_no) ...@@ -1033,11 +947,8 @@ uislib_client_inject_resume_vnic(u32 bus_no, u32 dev_no)
msg.cmd.device_change_state.dev_no = dev_no; msg.cmd.device_change_state.dev_no = dev_no;
msg.cmd.device_change_state.state = segment_state_running; msg.cmd.device_change_state.state = segment_state_running;
rc = resume_device(&msg); rc = resume_device(&msg);
if (rc != CONTROLVM_RESP_SUCCESS) { if (rc != CONTROLVM_RESP_SUCCESS)
LOGERR("VNIC resume_device failed. busNo=0x%x devNo=0x%x\n",
bus_no, dev_no);
return -1; return -1;
}
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(uislib_client_inject_resume_vnic); EXPORT_SYMBOL_GPL(uislib_client_inject_resume_vnic);
...@@ -1059,11 +970,8 @@ uislib_cache_alloc(struct kmem_cache *cur_pool, char *fn, int ln) ...@@ -1059,11 +970,8 @@ uislib_cache_alloc(struct kmem_cache *cur_pool, char *fn, int ln)
*/ */
void *p = kmem_cache_alloc(cur_pool, GFP_ATOMIC | __GFP_NORETRY); void *p = kmem_cache_alloc(cur_pool, GFP_ATOMIC | __GFP_NORETRY);
if (p == NULL) { if (p == NULL)
LOGERR("uislib_malloc failed to alloc uiscmdrsp @%s:%d",
fn, ln);
return NULL; return NULL;
}
return p; return p;
} }
EXPORT_SYMBOL_GPL(uislib_cache_alloc); EXPORT_SYMBOL_GPL(uislib_cache_alloc);
...@@ -1071,10 +979,8 @@ EXPORT_SYMBOL_GPL(uislib_cache_alloc); ...@@ -1071,10 +979,8 @@ EXPORT_SYMBOL_GPL(uislib_cache_alloc);
void void
uislib_cache_free(struct kmem_cache *cur_pool, void *p, char *fn, int ln) uislib_cache_free(struct kmem_cache *cur_pool, void *p, char *fn, int ln)
{ {
if (p == NULL) { if (p == NULL)
LOGERR("uislib_free NULL pointer @%s:%d", fn, ln);
return; return;
}
kmem_cache_free(cur_pool, p); kmem_cache_free(cur_pool, p);
} }
EXPORT_SYMBOL_GPL(uislib_cache_free); EXPORT_SYMBOL_GPL(uislib_cache_free);
...@@ -1155,10 +1061,8 @@ static ssize_t info_debugfs_read(struct file *file, char __user *buf, ...@@ -1155,10 +1061,8 @@ static ssize_t info_debugfs_read(struct file *file, char __user *buf,
if (debug_buf == NULL) { if (debug_buf == NULL) {
debug_buf = vmalloc(PROC_READ_BUFFER_SIZE); debug_buf = vmalloc(PROC_READ_BUFFER_SIZE);
if (debug_buf == NULL) { if (debug_buf == NULL)
LOGERR("failed to allocate buffer to provide proc data.\n");
return -ENOMEM; return -ENOMEM;
}
} }
temp = debug_buf; temp = debug_buf;
...@@ -1184,17 +1088,9 @@ static struct device_info *find_dev(u32 bus_no, u32 dev_no) ...@@ -1184,17 +1088,9 @@ static struct device_info *find_dev(u32 bus_no, u32 dev_no)
for (bus = bus_list; bus; bus = bus->next) { for (bus = bus_list; bus; bus = bus->next) {
if (bus->bus_no == bus_no) { if (bus->bus_no == bus_no) {
/* make sure the device number is valid */ /* make sure the device number is valid */
if (dev_no >= bus->device_count) { if (dev_no >= bus->device_count)
LOGERR("%s bad bus_no, dev_no=%d,%d",
__func__,
(int)bus_no, (int)dev_no);
break; break;
}
dev = bus->device[dev_no]; dev = bus->device[dev_no];
if (!dev)
LOGERR("%s bad bus_no, dev_no=%d,%d",
__func__,
(int)bus_no, (int)dev_no);
break; break;
} }
} }
...@@ -1331,7 +1227,6 @@ initialize_incoming_thread(void) ...@@ -1331,7 +1227,6 @@ initialize_incoming_thread(void)
return TRUE; return TRUE;
if (!uisthread_start(&incoming_ti, if (!uisthread_start(&incoming_ti,
&process_incoming, NULL, "dev_incoming")) { &process_incoming, NULL, "dev_incoming")) {
LOGERR("uisthread_start initialize_incoming_thread ****FAILED");
return FALSE; return FALSE;
} }
incoming_started = TRUE; incoming_started = TRUE;
...@@ -1352,11 +1247,9 @@ uislib_enable_channel_interrupts(u32 bus_no, u32 dev_no, ...@@ -1352,11 +1247,9 @@ uislib_enable_channel_interrupts(u32 bus_no, u32 dev_no,
struct device_info *dev; struct device_info *dev;
dev = find_dev(bus_no, dev_no); dev = find_dev(bus_no, dev_no);
if (!dev) { if (!dev)
LOGERR("%s busNo=%d, devNo=%d", __func__, (int)(bus_no),
(int)(dev_no));
return; return;
}
down(&poll_dev_lock); down(&poll_dev_lock);
initialize_incoming_thread(); initialize_incoming_thread();
dev->interrupt = interrupt; dev->interrupt = interrupt;
...@@ -1377,11 +1270,8 @@ uislib_disable_channel_interrupts(u32 bus_no, u32 dev_no) ...@@ -1377,11 +1270,8 @@ uislib_disable_channel_interrupts(u32 bus_no, u32 dev_no)
struct device_info *dev; struct device_info *dev;
dev = find_dev(bus_no, dev_no); dev = find_dev(bus_no, dev_no);
if (!dev) { if (!dev)
LOGERR("%s busNo=%d, devNo=%d", __func__, (int)(bus_no),
(int)(dev_no));
return; return;
}
down(&poll_dev_lock); down(&poll_dev_lock);
list_del(&dev->list_polling_device_channels); list_del(&dev->list_polling_device_channels);
dev->polling = FALSE; dev->polling = FALSE;
......
...@@ -295,12 +295,10 @@ uisqueue_put_cmdrsp_with_lock_client(struct uisqueue_info *queueinfo, ...@@ -295,12 +295,10 @@ uisqueue_put_cmdrsp_with_lock_client(struct uisqueue_info *queueinfo,
while (!do_locked_client_insert(queueinfo, whichqueue, cmdrsp, while (!do_locked_client_insert(queueinfo, whichqueue, cmdrsp,
(spinlock_t *)insertlock, (spinlock_t *)insertlock,
channel_id)) { channel_id)) {
if (oktowait != OK_TO_WAIT) { if (oktowait != OK_TO_WAIT)
LOGERR("****FAILED visor_signal_insert failed; cannot wait; insert aborted\n");
return 0; /* failed to queue */ return 0; /* failed to queue */
}
/* try again */ /* try again */
LOGERR("****FAILED visor_signal_insert failed; waiting to try again\n");
set_current_state(TASK_INTERRUPTIBLE); set_current_state(TASK_INTERRUPTIBLE);
schedule_timeout(msecs_to_jiffies(10)); schedule_timeout(msecs_to_jiffies(10));
} }
......
...@@ -60,7 +60,6 @@ uisutil_add_proc_line_ex(int *total, char **buffer, int *buffer_remaining, ...@@ -60,7 +60,6 @@ uisutil_add_proc_line_ex(int *total, char **buffer, int *buffer_remaining,
*buffer += *buffer_remaining; *buffer += *buffer_remaining;
*total += *buffer_remaining; *total += *buffer_remaining;
*buffer_remaining = 0; *buffer_remaining = 0;
LOGERR("bytes remaining is too small!\n");
return -1; return -1;
} }
*buffer_remaining -= len; *buffer_remaining -= len;
...@@ -88,7 +87,6 @@ uisctrl_register_req_handler(int type, void *fptr, ...@@ -88,7 +87,6 @@ uisctrl_register_req_handler(int type, void *fptr,
break; break;
default: default:
LOGERR("invalid type %d.\n", type);
return 0; return 0;
} }
if (chipset_driver_info) if (chipset_driver_info)
......
...@@ -262,8 +262,6 @@ add_scsipending_entry(struct virthba_info *vhbainfo, char cmdtype, void *new) ...@@ -262,8 +262,6 @@ add_scsipending_entry(struct virthba_info *vhbainfo, char cmdtype, void *new)
while (vhbainfo->pending[insert_location].sent != NULL) { while (vhbainfo->pending[insert_location].sent != NULL) {
insert_location = (insert_location + 1) % MAX_PENDING_REQUESTS; insert_location = (insert_location + 1) % MAX_PENDING_REQUESTS;
if (insert_location == (int)vhbainfo->nextinsert) { if (insert_location == (int)vhbainfo->nextinsert) {
LOGERR("Queue should be full. insert_location<<%d>> Unable to find open slot for pending commands.\n",
insert_location);
spin_unlock_irqrestore(&vhbainfo->privlock, flags); spin_unlock_irqrestore(&vhbainfo->privlock, flags);
return -1; return -1;
} }
...@@ -284,7 +282,6 @@ add_scsipending_entry_with_wait(struct virthba_info *vhbainfo, char cmdtype, ...@@ -284,7 +282,6 @@ add_scsipending_entry_with_wait(struct virthba_info *vhbainfo, char cmdtype,
int insert_location = add_scsipending_entry(vhbainfo, cmdtype, new); int insert_location = add_scsipending_entry(vhbainfo, cmdtype, new);
while (insert_location == -1) { while (insert_location == -1) {
LOGERR("Failed to find empty queue slot. Waiting to try again\n");
set_current_state(TASK_INTERRUPTIBLE); set_current_state(TASK_INTERRUPTIBLE);
schedule_timeout(msecs_to_jiffies(10)); schedule_timeout(msecs_to_jiffies(10));
insert_location = add_scsipending_entry(vhbainfo, cmdtype, new); insert_location = add_scsipending_entry(vhbainfo, cmdtype, new);
...@@ -299,16 +296,8 @@ del_scsipending_entry(struct virthba_info *vhbainfo, uintptr_t del) ...@@ -299,16 +296,8 @@ del_scsipending_entry(struct virthba_info *vhbainfo, uintptr_t del)
unsigned long flags; unsigned long flags;
void *sent = NULL; void *sent = NULL;
if (del >= MAX_PENDING_REQUESTS) { if (del < MAX_PENDING_REQUESTS) {
LOGERR("Invalid queue position <<%lu>> given to delete. MAX_PENDING_REQUESTS <<%d>>\n",
(unsigned long)del, MAX_PENDING_REQUESTS);
} else {
spin_lock_irqsave(&vhbainfo->privlock, flags); spin_lock_irqsave(&vhbainfo->privlock, flags);
if (vhbainfo->pending[del].sent == NULL)
LOGERR("Deleting already cleared queue entry at <<%lu>>.\n",
(unsigned long)del);
sent = vhbainfo->pending[del].sent; sent = vhbainfo->pending[del].sent;
vhbainfo->pending[del].cmdtype = 0; vhbainfo->pending[del].cmdtype = 0;
...@@ -355,13 +344,7 @@ send_disk_add_remove(struct diskaddremove *dar) ...@@ -355,13 +344,7 @@ send_disk_add_remove(struct diskaddremove *dar)
error = error =
scsi_add_device(dar->shost, dar->channel, dar->id, scsi_add_device(dar->shost, dar->channel, dar->id,
dar->lun); dar->lun);
if (error) }
LOGERR("Failed scsi_add_device: host_no=%d[chan=%d:id=%d:lun=%d]\n",
dar->shost->host_no, dar->channel, dar->id,
dar->lun);
} else
LOGERR("Failed scsi_device_lookup:[chan=%d:id=%d:lun=%d]\n",
dar->channel, dar->id, dar->lun);
kfree(dar); kfree(dar);
} }
...@@ -406,10 +389,6 @@ process_disk_notify(struct Scsi_Host *shost, struct uiscmdrsp *cmdrsp) ...@@ -406,10 +389,6 @@ process_disk_notify(struct Scsi_Host *shost, struct uiscmdrsp *cmdrsp)
dar->id = cmdrsp->disknotify.id; dar->id = cmdrsp->disknotify.id;
dar->lun = cmdrsp->disknotify.lun; dar->lun = cmdrsp->disknotify.lun;
QUEUE_DISKADDREMOVE(dar); QUEUE_DISKADDREMOVE(dar);
} else {
LOGERR("kmalloc failed for dar. host_no=%d[chan=%d:id=%d:lun=%d]\n",
shost->host_no, cmdrsp->disknotify.channel,
cmdrsp->disknotify.id, cmdrsp->disknotify.lun);
} }
} }
...@@ -510,7 +489,6 @@ virthba_probe(struct virtpci_dev *virtpcidev, const struct pci_device_id *id) ...@@ -510,7 +489,6 @@ virthba_probe(struct virtpci_dev *virtpcidev, const struct pci_device_id *id)
*/ */
error = scsi_add_host(scsihost, &virtpcidev->generic_dev); error = scsi_add_host(scsihost, &virtpcidev->generic_dev);
if (error) { if (error) {
LOGERR("scsi_add_host ****FAILED 0x%x TBD - RECOVER\n", error);
POSTCODE_LINUX_2(VHBA_PROBE_FAILURE_PC, POSTCODE_SEVERITY_ERR); POSTCODE_LINUX_2(VHBA_PROBE_FAILURE_PC, POSTCODE_SEVERITY_ERR);
/* decr refcount on scsihost which was incremented by /* decr refcount on scsihost which was incremented by
* scsi_add_host so the scsi_host gets deleted * scsi_add_host so the scsi_host gets deleted
...@@ -563,7 +541,6 @@ virthba_probe(struct virtpci_dev *virtpcidev, const struct pci_device_id *id) ...@@ -563,7 +541,6 @@ virthba_probe(struct virtpci_dev *virtpcidev, const struct pci_device_id *id)
if (!uisthread_start(&virthbainfo->chinfo.threadinfo, if (!uisthread_start(&virthbainfo->chinfo.threadinfo,
process_incoming_rsps, process_incoming_rsps,
virthbainfo, "vhba_incoming")) { virthbainfo, "vhba_incoming")) {
LOGERR("uisthread_start rsp ****FAILED\n");
/* decr refcount on scsihost which was incremented by /* decr refcount on scsihost which was incremented by
* scsi_add_host so the scsi_host gets deleted * scsi_add_host so the scsi_host gets deleted
*/ */
...@@ -576,15 +553,11 @@ virthba_probe(struct virtpci_dev *virtpcidev, const struct pci_device_id *id) ...@@ -576,15 +553,11 @@ virthba_probe(struct virtpci_dev *virtpcidev, const struct pci_device_id *id)
rsp = request_irq(virthbainfo->interrupt_vector, handler, IRQF_SHARED, rsp = request_irq(virthbainfo->interrupt_vector, handler, IRQF_SHARED,
scsihost->hostt->name, virthbainfo); scsihost->hostt->name, virthbainfo);
if (rsp != 0) { if (rsp != 0) {
LOGERR("request_irq(%d) uislib_virthba_ISR request failed with rsp=%d\n",
virthbainfo->interrupt_vector, rsp);
virthbainfo->interrupt_vector = -1; virthbainfo->interrupt_vector = -1;
POSTCODE_LINUX_2(VHBA_PROBE_FAILURE_PC, POSTCODE_SEVERITY_ERR); POSTCODE_LINUX_2(VHBA_PROBE_FAILURE_PC, POSTCODE_SEVERITY_ERR);
} else { } else {
u64 __iomem *Features_addr = u64 __iomem *Features_addr =
&virthbainfo->chinfo.queueinfo->chan->features; &virthbainfo->chinfo.queueinfo->chan->features;
LOGERR("request_irq(%d) uislib_virthba_ISR request succeeded\n",
virthbainfo->interrupt_vector);
mask = ~(ULTRA_IO_CHANNEL_IS_POLLING | mask = ~(ULTRA_IO_CHANNEL_IS_POLLING |
ULTRA_IO_DRIVER_DISABLES_INTS); ULTRA_IO_DRIVER_DISABLES_INTS);
uisqueue_interlocked_and(Features_addr, mask); uisqueue_interlocked_and(Features_addr, mask);
...@@ -807,7 +780,6 @@ static int ...@@ -807,7 +780,6 @@ static int
virthba_host_reset_handler(struct scsi_cmnd *scsicmd) virthba_host_reset_handler(struct scsi_cmnd *scsicmd)
{ {
/* issue TASK_MGMT_TARGET_RESET for each target on each bus for host */ /* issue TASK_MGMT_TARGET_RESET for each target on each bus for host */
LOGERR("virthba_host_reset_handler Not yet implemented\n");
return SUCCESS; return SUCCESS;
} }
...@@ -866,7 +838,6 @@ virthba_queue_command_lck(struct scsi_cmnd *scsicmd, ...@@ -866,7 +838,6 @@ virthba_queue_command_lck(struct scsi_cmnd *scsicmd,
if (insert_location != -1) { if (insert_location != -1) {
cmdrsp->scsi.scsicmd = (void *)(uintptr_t)insert_location; cmdrsp->scsi.scsicmd = (void *)(uintptr_t)insert_location;
} else { } else {
LOGERR("Queue is full. Returning busy.\n");
kfree(cmdrsp); kfree(cmdrsp);
return SCSI_MLQUEUE_DEVICE_BUSY; return SCSI_MLQUEUE_DEVICE_BUSY;
} }
...@@ -887,8 +858,6 @@ virthba_queue_command_lck(struct scsi_cmnd *scsicmd, ...@@ -887,8 +858,6 @@ virthba_queue_command_lck(struct scsi_cmnd *scsicmd,
max_buff_len = cmdrsp->scsi.bufflen; max_buff_len = cmdrsp->scsi.bufflen;
if (scsi_sg_count(scsicmd) > MAX_PHYS_INFO) { if (scsi_sg_count(scsicmd) > MAX_PHYS_INFO) {
LOGERR("scsicmd use_sg:%d greater than MAX:%d\n",
scsi_sg_count(scsicmd), MAX_PHYS_INFO);
del_scsipending_entry(virthbainfo, (uintptr_t)insert_location); del_scsipending_entry(virthbainfo, (uintptr_t)insert_location);
kfree(cmdrsp); kfree(cmdrsp);
return 1; /* reject the command */ return 1; /* reject the command */
...@@ -901,7 +870,6 @@ virthba_queue_command_lck(struct scsi_cmnd *scsicmd, ...@@ -901,7 +870,6 @@ virthba_queue_command_lck(struct scsi_cmnd *scsicmd,
/* convert buffer to phys information */ /* convert buffer to phys information */
if (scsi_sg_count(scsicmd) == 0) { if (scsi_sg_count(scsicmd) == 0) {
if (scsi_bufflen(scsicmd) > 0) { if (scsi_bufflen(scsicmd) > 0) {
LOGERR("**** FAILED No scatter list for bufflen > 0\n");
BUG_ON(scsi_sg_count(scsicmd) == 0); BUG_ON(scsi_sg_count(scsicmd) == 0);
} }
} else { } else {
...@@ -914,15 +882,6 @@ virthba_queue_command_lck(struct scsi_cmnd *scsicmd, ...@@ -914,15 +882,6 @@ virthba_queue_command_lck(struct scsi_cmnd *scsicmd,
} }
if (sg_failed) { if (sg_failed) {
LOGERR("Start sg_list dump (entries %d, bufflen %d)...\n",
scsi_sg_count(scsicmd), cmdrsp->scsi.bufflen);
for_each_sg(sgl, sg, scsi_sg_count(scsicmd), i) {
LOGERR(" Entry(%d): page->[0x%p], phys->[0x%Lx], off(%d), len(%d)\n",
i, sg_page(sg),
(unsigned long long)sg_phys(sg),
sg->offset, sg->length);
}
LOGERR("Done sg_list dump.\n");
/* BUG(); ***** For now, let it fail in uissd /* BUG(); ***** For now, let it fail in uissd
* if it is a problem, as it might just * if it is a problem, as it might just
* work * work
...@@ -941,7 +900,6 @@ virthba_queue_command_lck(struct scsi_cmnd *scsicmd, ...@@ -941,7 +900,6 @@ virthba_queue_command_lck(struct scsi_cmnd *scsicmd,
(u64)NULL, DONT_WAIT, "vhba"); (u64)NULL, DONT_WAIT, "vhba");
if (i == 0) { if (i == 0) {
/* queue must be full - and we said don't wait - return busy */ /* queue must be full - and we said don't wait - return busy */
LOGERR("uisqueue_put_cmdrsp_with_lock ****FAILED\n");
kfree(cmdrsp); kfree(cmdrsp);
del_scsipending_entry(virthbainfo, (uintptr_t)insert_location); del_scsipending_entry(virthbainfo, (uintptr_t)insert_location);
return SCSI_MLQUEUE_DEVICE_BUSY; return SCSI_MLQUEUE_DEVICE_BUSY;
...@@ -966,10 +924,9 @@ virthba_slave_alloc(struct scsi_device *scsidev) ...@@ -966,10 +924,9 @@ virthba_slave_alloc(struct scsi_device *scsidev)
struct Scsi_Host *scsihost = (struct Scsi_Host *)scsidev->host; struct Scsi_Host *scsihost = (struct Scsi_Host *)scsidev->host;
virthbainfo = (struct virthba_info *)scsihost->hostdata; virthbainfo = (struct virthba_info *)scsihost->hostdata;
if (!virthbainfo) { if (!virthbainfo)
LOGERR("Could not find virthba_info for scsihost\n");
return 0; /* even though we errored, treat as success */ return 0; /* even though we errored, treat as success */
}
for (vdisk = &virthbainfo->head; vdisk->next; vdisk = vdisk->next) { for (vdisk = &virthbainfo->head; vdisk->next; vdisk = vdisk->next) {
if (vdisk->next->valid && if (vdisk->next->valid &&
(vdisk->next->channel == scsidev->channel) && (vdisk->next->channel == scsidev->channel) &&
...@@ -1006,8 +963,6 @@ virthba_slave_destroy(struct scsi_device *scsidev) ...@@ -1006,8 +963,6 @@ virthba_slave_destroy(struct scsi_device *scsidev)
struct Scsi_Host *scsihost = (struct Scsi_Host *)scsidev->host; struct Scsi_Host *scsihost = (struct Scsi_Host *)scsidev->host;
virthbainfo = (struct virthba_info *)scsihost->hostdata; virthbainfo = (struct virthba_info *)scsihost->hostdata;
if (!virthbainfo)
LOGERR("Could not find virthba_info for scsihost\n");
for (vdisk = &virthbainfo->head; vdisk->next; vdisk = vdisk->next) { for (vdisk = &virthbainfo->head; vdisk->next; vdisk = vdisk->next) {
if (vdisk->next->valid && if (vdisk->next->valid &&
(vdisk->next->channel == scsidev->channel) && (vdisk->next->channel == scsidev->channel) &&
...@@ -1052,19 +1007,6 @@ do_scsi_linuxstat(struct uiscmdrsp *cmdrsp, struct scsi_cmnd *scsicmd) ...@@ -1052,19 +1007,6 @@ do_scsi_linuxstat(struct uiscmdrsp *cmdrsp, struct scsi_cmnd *scsicmd)
if (atomic_read(&vdisk->error_count) < VIRTHBA_ERROR_COUNT) { if (atomic_read(&vdisk->error_count) < VIRTHBA_ERROR_COUNT) {
atomic_inc(&vdisk->error_count); atomic_inc(&vdisk->error_count);
LOGERR("SCSICMD ****FAILED scsicmd:0x%p op:0x%x <%d:%d:%d:%llu> 0x%x-0x%x-0x%x-0x%x-0x%x.\n",
scsicmd, cmdrsp->scsi.cmnd[0],
scsidev->host->host_no, scsidev->id,
scsidev->channel, scsidev->lun,
cmdrsp->scsi.linuxstat, sd->valid, sd->sense_key,
sd->additional_sense_code,
sd->additional_sense_code_qualifier);
if (atomic_read(&vdisk->error_count) ==
VIRTHBA_ERROR_COUNT) {
LOGERR("Throtling SCSICMD errors disk <%d:%d:%d:%llu>\n",
scsidev->host->host_no, scsidev->id,
scsidev->channel, scsidev->lun);
}
atomic_set(&vdisk->ios_threshold, IOS_ERROR_THRESHOLD); atomic_set(&vdisk->ios_threshold, IOS_ERROR_THRESHOLD);
} }
} }
...@@ -1100,7 +1042,6 @@ do_scsi_nolinuxstat(struct uiscmdrsp *cmdrsp, struct scsi_cmnd *scsicmd) ...@@ -1100,7 +1042,6 @@ do_scsi_nolinuxstat(struct uiscmdrsp *cmdrsp, struct scsi_cmnd *scsicmd)
if (scsi_sg_count(scsicmd) == 0) { if (scsi_sg_count(scsicmd) == 0) {
if (scsi_bufflen(scsicmd) > 0) { if (scsi_bufflen(scsicmd) > 0) {
LOGERR("**** FAILED No scatter list for bufflen > 0\n");
BUG_ON(scsi_sg_count(scsicmd) == BUG_ON(scsi_sg_count(scsicmd) ==
0); 0);
} }
...@@ -1129,7 +1070,6 @@ do_scsi_nolinuxstat(struct uiscmdrsp *cmdrsp, struct scsi_cmnd *scsicmd) ...@@ -1129,7 +1070,6 @@ do_scsi_nolinuxstat(struct uiscmdrsp *cmdrsp, struct scsi_cmnd *scsicmd)
if (atomic_read(&vdisk->ios_threshold) > 0) { if (atomic_read(&vdisk->ios_threshold) > 0) {
atomic_dec(&vdisk->ios_threshold); atomic_dec(&vdisk->ios_threshold);
if (atomic_read(&vdisk->ios_threshold) == 0) { if (atomic_read(&vdisk->ios_threshold) == 0) {
LOGERR("Resetting error count for disk\n");
atomic_set(&vdisk->error_count, 0); atomic_set(&vdisk->error_count, 0);
} }
} }
...@@ -1223,8 +1163,7 @@ drain_queue(struct virthba_info *virthbainfo, struct chaninfo *dc, ...@@ -1223,8 +1163,7 @@ drain_queue(struct virthba_info *virthbainfo, struct chaninfo *dc,
cmdrsp->vdiskmgmt.scsicmd)) cmdrsp->vdiskmgmt.scsicmd))
break; break;
complete_vdiskmgmt_command(cmdrsp); complete_vdiskmgmt_command(cmdrsp);
} else }
LOGERR("Invalid cmdtype %d\n", cmdrsp->cmdtype);
/* cmdrsp is now available for reuse */ /* cmdrsp is now available for reuse */
} }
} }
...@@ -1338,19 +1277,13 @@ static ssize_t enable_ints_write(struct file *file, const char __user *buffer, ...@@ -1338,19 +1277,13 @@ static ssize_t enable_ints_write(struct file *file, const char __user *buffer,
return -EINVAL; return -EINVAL;
buf[count] = '\0'; buf[count] = '\0';
if (copy_from_user(buf, buffer, count)) { if (copy_from_user(buf, buffer, count))
LOGERR("copy_from_user failed. buf<<%.*s>> count<<%lu>>\n",
(int)count, buf, count);
return -EFAULT; return -EFAULT;
}
i = kstrtoint(buf, 10, &new_value); i = kstrtoint(buf, 10, &new_value);
if (i != 0) { if (i != 0)
LOGERR("Failed to scan value for enable_ints, buf<<%.*s>>",
(int)count, buf);
return -EFAULT; return -EFAULT;
}
/* set all counts to new_value usually 0 */ /* set all counts to new_value usually 0 */
for (i = 0; i < VIRTHBASOPENMAX; i++) { for (i = 0; i < VIRTHBASOPENMAX; i++) {
...@@ -1389,10 +1322,8 @@ virthba_serverup(struct virtpci_dev *virtpcidev) ...@@ -1389,10 +1322,8 @@ virthba_serverup(struct virtpci_dev *virtpcidev)
if (!virthbainfo->serverdown) if (!virthbainfo->serverdown)
return 1; return 1;
if (virthbainfo->serverchangingstate) { if (virthbainfo->serverchangingstate)
LOGERR("Server already processing change state message\n");
return 0; return 0;
}
virthbainfo->serverchangingstate = true; virthbainfo->serverchangingstate = true;
/* Must transition channel to ATTACHED state BEFORE we /* Must transition channel to ATTACHED state BEFORE we
...@@ -1406,7 +1337,6 @@ virthba_serverup(struct virtpci_dev *virtpcidev) ...@@ -1406,7 +1337,6 @@ virthba_serverup(struct virtpci_dev *virtpcidev)
if (!uisthread_start(&virthbainfo->chinfo.threadinfo, if (!uisthread_start(&virthbainfo->chinfo.threadinfo,
process_incoming_rsps, process_incoming_rsps,
virthbainfo, "vhba_incoming")) { virthbainfo, "vhba_incoming")) {
LOGERR("uisthread_start rsp ****FAILED\n");
return 0; return 0;
} }
virthbainfo->serverdown = false; virthbainfo->serverdown = false;
...@@ -1460,9 +1390,7 @@ virthba_serverdown_complete(struct work_struct *work) ...@@ -1460,9 +1390,7 @@ virthba_serverdown_complete(struct work_struct *work)
cmdrsp->vdiskmgmt.notify); cmdrsp->vdiskmgmt.notify);
break; break;
default: default:
if (pendingdel->sent != NULL) break;
LOGERR("Unknown command type: 0x%x. Only freeing list structure.\n",
pendingdel->cmdtype);
} }
pendingdel->cmdtype = 0; pendingdel->cmdtype = 0;
pendingdel->sent = NULL; pendingdel->sent = NULL;
...@@ -1493,10 +1421,7 @@ virthba_serverdown(struct virtpci_dev *virtpcidev, u32 state) ...@@ -1493,10 +1421,7 @@ virthba_serverdown(struct virtpci_dev *virtpcidev, u32 state)
queue_work(virthba_serverdown_workqueue, queue_work(virthba_serverdown_workqueue,
&virthbainfo->serverdown_completion); &virthbainfo->serverdown_completion);
} else if (virthbainfo->serverchangingstate) { } else if (virthbainfo->serverchangingstate) {
LOGERR("Server already processing change state message\n");
stat = 0; stat = 0;
} else {
LOGERR("Server already down, but another server down message received.");
} }
return stat; return stat;
...@@ -1544,7 +1469,6 @@ virthba_mod_init(void) ...@@ -1544,7 +1469,6 @@ virthba_mod_init(void)
error = virtpci_register_driver(&virthba_driver); error = virtpci_register_driver(&virthba_driver);
if (error < 0) { if (error < 0) {
LOGERR("register ****FAILED 0x%x\n", error);
POSTCODE_LINUX_3(VHBA_CREATE_FAILURE_PC, error, POSTCODE_LINUX_3(VHBA_CREATE_FAILURE_PC, error,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
} else { } else {
...@@ -1568,7 +1492,6 @@ virthba_mod_init(void) ...@@ -1568,7 +1492,6 @@ virthba_mod_init(void)
virthba_serverdown_workqueue = virthba_serverdown_workqueue =
create_singlethread_workqueue("virthba_serverdown"); create_singlethread_workqueue("virthba_serverdown");
if (virthba_serverdown_workqueue == NULL) { if (virthba_serverdown_workqueue == NULL) {
LOGERR("**** FAILED virthba_serverdown_workqueue creation\n");
POSTCODE_LINUX_2(VHBA_CREATE_FAILURE_PC, POSTCODE_LINUX_2(VHBA_CREATE_FAILURE_PC,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
error = -1; error = -1;
......
...@@ -187,13 +187,11 @@ static int write_vbus_chp_info(struct spar_vbus_channel_protocol *chan, ...@@ -187,13 +187,11 @@ static int write_vbus_chp_info(struct spar_vbus_channel_protocol *chan,
{ {
int off; int off;
if (!chan) { if (!chan)
LOGERR("vbus channel not present");
return -1; return -1;
}
off = sizeof(struct channel_header) + chan->hdr_info.chp_info_offset; off = sizeof(struct channel_header) + chan->hdr_info.chp_info_offset;
if (chan->hdr_info.chp_info_offset == 0) { if (chan->hdr_info.chp_info_offset == 0) {
LOGERR("vbus channel not used, because chp_info_offset == 0");
return -1; return -1;
} }
memcpy(((u8 *)(chan)) + off, info, sizeof(*info)); memcpy(((u8 *)(chan)) + off, info, sizeof(*info));
...@@ -206,15 +204,12 @@ static int write_vbus_bus_info(struct spar_vbus_channel_protocol *chan, ...@@ -206,15 +204,12 @@ static int write_vbus_bus_info(struct spar_vbus_channel_protocol *chan,
{ {
int off; int off;
if (!chan) { if (!chan)
LOGERR("vbus channel not present");
return -1; return -1;
}
off = sizeof(struct channel_header) + chan->hdr_info.bus_info_offset; off = sizeof(struct channel_header) + chan->hdr_info.bus_info_offset;
if (chan->hdr_info.bus_info_offset == 0) { if (chan->hdr_info.bus_info_offset == 0)
LOGERR("vbus channel not used, because bus_info_offset == 0");
return -1; return -1;
}
memcpy(((u8 *)(chan)) + off, info, sizeof(*info)); memcpy(((u8 *)(chan)) + off, info, sizeof(*info));
return 0; return 0;
} }
...@@ -228,18 +223,16 @@ write_vbus_dev_info(struct spar_vbus_channel_protocol *chan, ...@@ -228,18 +223,16 @@ write_vbus_dev_info(struct spar_vbus_channel_protocol *chan,
{ {
int off; int off;
if (!chan) { if (!chan)
LOGERR("vbus channel not present");
return -1; return -1;
}
off = off =
(sizeof(struct channel_header) + (sizeof(struct channel_header) +
chan->hdr_info.dev_info_offset) + chan->hdr_info.dev_info_offset) +
(chan->hdr_info.device_info_struct_bytes * devix); (chan->hdr_info.device_info_struct_bytes * devix);
if (chan->hdr_info.dev_info_offset == 0) { if (chan->hdr_info.dev_info_offset == 0)
LOGERR("vbus channel not used, because dev_info_offset == 0");
return -1; return -1;
}
memcpy(((u8 *)(chan)) + off, info, sizeof(*info)); memcpy(((u8 *)(chan)) + off, info, sizeof(*info));
return 0; return 0;
} }
...@@ -271,7 +264,6 @@ static int add_vbus(struct add_vbus_guestpart *addparams) ...@@ -271,7 +264,6 @@ static int add_vbus(struct add_vbus_guestpart *addparams)
*/ */
ret = device_register(vbus); ret = device_register(vbus);
if (ret) { if (ret) {
LOGERR("device_register FAILED:%d\n", ret);
POSTCODE_LINUX_2(VPCI_CREATE_FAILURE_PC, POSTCODE_SEVERITY_ERR); POSTCODE_LINUX_2(VPCI_CREATE_FAILURE_PC, POSTCODE_SEVERITY_ERR);
return 0; return 0;
} }
...@@ -310,7 +302,6 @@ static int add_vhba(struct add_virt_guestpart *addparams) ...@@ -310,7 +302,6 @@ static int add_vhba(struct add_virt_guestpart *addparams)
POSTCODE_LINUX_2(VPCI_CREATE_ENTRY_PC, POSTCODE_SEVERITY_INFO); POSTCODE_LINUX_2(VPCI_CREATE_ENTRY_PC, POSTCODE_SEVERITY_INFO);
if (!WAIT_FOR_IO_CHANNEL if (!WAIT_FOR_IO_CHANNEL
((struct spar_io_channel_protocol __iomem *)addparams->chanptr)) { ((struct spar_io_channel_protocol __iomem *)addparams->chanptr)) {
LOGERR("Timed out. Channel not ready\n");
POSTCODE_LINUX_2(VPCI_CREATE_FAILURE_PC, POSTCODE_SEVERITY_ERR); POSTCODE_LINUX_2(VPCI_CREATE_FAILURE_PC, POSTCODE_SEVERITY_ERR);
return 0; return 0;
} }
...@@ -321,10 +312,8 @@ static int add_vhba(struct add_virt_guestpart *addparams) ...@@ -321,10 +312,8 @@ static int add_vhba(struct add_virt_guestpart *addparams)
sprintf(busid, "vbus%d", addparams->bus_no); sprintf(busid, "vbus%d", addparams->bus_no);
vbus = bus_find_device(&virtpci_bus_type, NULL, vbus = bus_find_device(&virtpci_bus_type, NULL,
(void *)busid, match_busid); (void *)busid, match_busid);
if (!vbus) { if (!vbus)
LOGERR("**** FAILED to find vbus %s\n", busid);
return 0; return 0;
}
i = virtpci_device_add(vbus, VIRTHBA_TYPE, addparams, &scsi, NULL); i = virtpci_device_add(vbus, VIRTHBA_TYPE, addparams, &scsi, NULL);
if (i) { if (i) {
...@@ -367,7 +356,6 @@ add_vnic(struct add_virt_guestpart *addparams) ...@@ -367,7 +356,6 @@ add_vnic(struct add_virt_guestpart *addparams)
POSTCODE_LINUX_2(VPCI_CREATE_ENTRY_PC, POSTCODE_SEVERITY_INFO); POSTCODE_LINUX_2(VPCI_CREATE_ENTRY_PC, POSTCODE_SEVERITY_INFO);
if (!WAIT_FOR_IO_CHANNEL if (!WAIT_FOR_IO_CHANNEL
((struct spar_io_channel_protocol __iomem *)addparams->chanptr)) { ((struct spar_io_channel_protocol __iomem *)addparams->chanptr)) {
LOGERR("Timed out, channel not ready\n");
POSTCODE_LINUX_2(VPCI_CREATE_FAILURE_PC, POSTCODE_SEVERITY_ERR); POSTCODE_LINUX_2(VPCI_CREATE_FAILURE_PC, POSTCODE_SEVERITY_ERR);
return 0; return 0;
} }
...@@ -378,10 +366,8 @@ add_vnic(struct add_virt_guestpart *addparams) ...@@ -378,10 +366,8 @@ add_vnic(struct add_virt_guestpart *addparams)
sprintf(busid, "vbus%d", addparams->bus_no); sprintf(busid, "vbus%d", addparams->bus_no);
vbus = bus_find_device(&virtpci_bus_type, NULL, vbus = bus_find_device(&virtpci_bus_type, NULL,
(void *)busid, match_busid); (void *)busid, match_busid);
if (!vbus) { if (!vbus)
LOGERR("**** FAILED to find vbus %s\n", busid);
return 0; return 0;
}
i = virtpci_device_add(vbus, VIRTNIC_TYPE, addparams, NULL, &net); i = virtpci_device_add(vbus, VIRTNIC_TYPE, addparams, NULL, &net);
if (i) { if (i) {
...@@ -405,10 +391,8 @@ delete_vbus(struct del_vbus_guestpart *delparams) ...@@ -405,10 +391,8 @@ delete_vbus(struct del_vbus_guestpart *delparams)
sprintf(busid, "vbus%d", delparams->bus_no); sprintf(busid, "vbus%d", delparams->bus_no);
vbus = bus_find_device(&virtpci_bus_type, NULL, vbus = bus_find_device(&virtpci_bus_type, NULL,
(void *)busid, match_busid); (void *)busid, match_busid);
if (!vbus) { if (!vbus)
LOGERR("**** FAILED to find vbus %s\n", busid);
return 0; return 0;
}
/* ensure that bus has no devices? -- TBD */ /* ensure that bus has no devices? -- TBD */
return 1; return 1;
...@@ -571,16 +555,11 @@ static int delete_all_virt(enum virtpci_dev_type devtype, ...@@ -571,16 +555,11 @@ static int delete_all_virt(enum virtpci_dev_type devtype,
sprintf(busid, "vbus%d", delparams->bus_no); sprintf(busid, "vbus%d", delparams->bus_no);
vbus = bus_find_device(&virtpci_bus_type, NULL, vbus = bus_find_device(&virtpci_bus_type, NULL,
(void *)busid, match_busid); (void *)busid, match_busid);
if (!vbus) { if (!vbus)
LOGERR("**** FAILED to find vbus %s\n", busid);
return 0; return 0;
}
if ((devtype != VIRTHBA_TYPE) && (devtype != VIRTNIC_TYPE)) { if ((devtype != VIRTHBA_TYPE) && (devtype != VIRTNIC_TYPE))
LOGERR("**** FAILED to delete all devices; devtype:%d not vhba:%d or vnic:%d\n",
devtype, VIRTHBA_TYPE, VIRTNIC_TYPE);
return 0; return 0;
}
/* delete all vhbas/vnics */ /* delete all vhbas/vnics */
i = virtpci_device_del(vbus, devtype, NULL, NULL); i = virtpci_device_del(vbus, devtype, NULL, NULL);
...@@ -618,7 +597,6 @@ static int virtpci_ctrlchan_func(struct guest_msgs *msg) ...@@ -618,7 +597,6 @@ static int virtpci_ctrlchan_func(struct guest_msgs *msg)
case GUEST_RESUME_VNIC: case GUEST_RESUME_VNIC:
return resume_vnic(&msg->resume_vnic); return resume_vnic(&msg->resume_vnic);
default: default:
LOGERR("invalid message type %d.\n", msg->msgtype);
return 0; return 0;
} }
} }
...@@ -692,24 +670,19 @@ static void fix_vbus_dev_info(struct device *dev, int dev_no, int dev_type, ...@@ -692,24 +670,19 @@ static void fix_vbus_dev_info(struct device *dev, int dev_no, int dev_type,
struct ultra_vbus_deviceinfo dev_info; struct ultra_vbus_deviceinfo dev_info;
const char *stype; const char *stype;
if (!dev) { if (!dev)
LOGERR("%s dev is NULL", __func__);
return; return;
} if (!virtpcidrv)
if (!virtpcidrv) {
LOGERR("%s driver is NULL", __func__);
return; return;
}
vbus = dev->parent; vbus = dev->parent;
if (!vbus) { if (!vbus)
LOGERR("%s dev has no parent bus", __func__);
return; return;
}
chan = vbus->platform_data; chan = vbus->platform_data;
if (!chan) { if (!chan)
LOGERR("%s dev bus has no channel", __func__);
return; return;
}
switch (dev_type) { switch (dev_type) {
case PCI_DEVICE_ID_VIRTHBA: case PCI_DEVICE_ID_VIRTHBA:
stype = "vHBA"; stype = "vHBA";
...@@ -831,8 +804,6 @@ static int virtpci_device_add(struct device *parentbus, int devtype, ...@@ -831,8 +804,6 @@ static int virtpci_device_add(struct device *parentbus, int devtype,
POSTCODE_LINUX_2(VPCI_CREATE_ENTRY_PC, POSTCODE_SEVERITY_INFO); POSTCODE_LINUX_2(VPCI_CREATE_ENTRY_PC, POSTCODE_SEVERITY_INFO);
if ((devtype != VIRTHBA_TYPE) && (devtype != VIRTNIC_TYPE)) { if ((devtype != VIRTHBA_TYPE) && (devtype != VIRTNIC_TYPE)) {
LOGERR("**** FAILED to add device; devtype:%d not vhba:%d or vnic:%d\n",
devtype, VIRTHBA_TYPE, VIRTNIC_TYPE);
POSTCODE_LINUX_3(VPCI_CREATE_FAILURE_PC, devtype, POSTCODE_LINUX_3(VPCI_CREATE_FAILURE_PC, devtype,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
return 0; return 0;
...@@ -902,7 +873,6 @@ static int virtpci_device_add(struct device *parentbus, int devtype, ...@@ -902,7 +873,6 @@ static int virtpci_device_add(struct device *parentbus, int devtype,
*/ */
write_unlock_irqrestore(&vpcidev_list_lock, flags); write_unlock_irqrestore(&vpcidev_list_lock, flags);
kfree(virtpcidev); kfree(virtpcidev);
LOGERR("**** FAILED vhba/vnic already exists in the list\n");
POSTCODE_LINUX_2(VPCI_CREATE_FAILURE_PC, POSTCODE_SEVERITY_ERR); POSTCODE_LINUX_2(VPCI_CREATE_FAILURE_PC, POSTCODE_SEVERITY_ERR);
return 0; return 0;
} }
...@@ -944,7 +914,6 @@ static int virtpci_device_add(struct device *parentbus, int devtype, ...@@ -944,7 +914,6 @@ static int virtpci_device_add(struct device *parentbus, int devtype,
* virtpci_device_probe is successful * virtpci_device_probe is successful
*/ */
if (ret) { if (ret) {
LOGERR("device_register returned %d\n", ret);
dev = &virtpcidev->generic_dev; dev = &virtpcidev->generic_dev;
SPAR_CHANNEL_CLIENT_TRANSITION(addparams->chanptr, SPAR_CHANNEL_CLIENT_TRANSITION(addparams->chanptr,
BUS_ID(dev), BUS_ID(dev),
...@@ -983,11 +952,8 @@ static int virtpci_device_serverdown(struct device *parentbus, ...@@ -983,11 +952,8 @@ static int virtpci_device_serverdown(struct device *parentbus,
unsigned long flags; unsigned long flags;
int rc = 0; int rc = 0;
if ((devtype != VIRTHBA_TYPE) && (devtype != VIRTNIC_TYPE)) { if ((devtype != VIRTHBA_TYPE) && (devtype != VIRTNIC_TYPE))
LOGERR("**** FAILED to pause device; devtype:%d not vhba:%d or vnic:%d\n",
devtype, VIRTHBA_TYPE, VIRTNIC_TYPE);
return 0; return 0;
}
/* find the vhba or vnic in virtpci device list */ /* find the vhba or vnic in virtpci device list */
write_lock_irqsave(&vpcidev_list_lock, flags); write_lock_irqsave(&vpcidev_list_lock, flags);
...@@ -1022,10 +988,8 @@ static int virtpci_device_serverdown(struct device *parentbus, ...@@ -1022,10 +988,8 @@ static int virtpci_device_serverdown(struct device *parentbus,
} }
write_unlock_irqrestore(&vpcidev_list_lock, flags); write_unlock_irqrestore(&vpcidev_list_lock, flags);
if (!found) { if (!found)
LOGERR("**** FAILED to find vhba/vnic in the list\n");
return 0; return 0;
}
return rc; return rc;
} }
...@@ -1042,11 +1006,9 @@ static int virtpci_device_serverup(struct device *parentbus, ...@@ -1042,11 +1006,9 @@ static int virtpci_device_serverup(struct device *parentbus,
unsigned long flags; unsigned long flags;
int rc = 0; int rc = 0;
if ((devtype != VIRTHBA_TYPE) && (devtype != VIRTNIC_TYPE)) { if ((devtype != VIRTHBA_TYPE) && (devtype != VIRTNIC_TYPE))
LOGERR("**** FAILED to resume device; devtype:%d not vhba:%d or vnic:%d\n",
devtype, VIRTHBA_TYPE, VIRTNIC_TYPE);
return 0; return 0;
}
/* find the vhba or vnic in virtpci device list */ /* find the vhba or vnic in virtpci device list */
write_lock_irqsave(&vpcidev_list_lock, flags); write_lock_irqsave(&vpcidev_list_lock, flags);
...@@ -1090,10 +1052,8 @@ static int virtpci_device_serverup(struct device *parentbus, ...@@ -1090,10 +1052,8 @@ static int virtpci_device_serverup(struct device *parentbus,
write_unlock_irqrestore(&vpcidev_list_lock, flags); write_unlock_irqrestore(&vpcidev_list_lock, flags);
if (!found) { if (!found)
LOGERR("**** FAILED to find vhba/vnic in the list\n");
return 0; return 0;
}
return rc; return rc;
} }
...@@ -1112,11 +1072,8 @@ static int virtpci_device_del(struct device *parentbus, ...@@ -1112,11 +1072,8 @@ static int virtpci_device_del(struct device *parentbus,
continue; \ continue; \
} }
if ((devtype != VIRTHBA_TYPE) && (devtype != VIRTNIC_TYPE)) { if ((devtype != VIRTHBA_TYPE) && (devtype != VIRTNIC_TYPE))
LOGERR("**** FAILED to delete device; devtype:%d not vhba:%d or vnic:%d\n",
devtype, VIRTHBA_TYPE, VIRTNIC_TYPE);
return 0; return 0;
}
/* see if we are to delete all - NOTE: all implies we have a /* see if we are to delete all - NOTE: all implies we have a
* valid parentbus * valid parentbus
...@@ -1183,10 +1140,8 @@ static int virtpci_device_del(struct device *parentbus, ...@@ -1183,10 +1140,8 @@ static int virtpci_device_del(struct device *parentbus,
} }
write_unlock_irqrestore(&vpcidev_list_lock, flags); write_unlock_irqrestore(&vpcidev_list_lock, flags);
if (!all && (count == 0)) { if (!all && (count == 0))
LOGERR("**** FAILED to find vhba/vnic in the list\n");
return 0; return 0;
}
/* now delete each one from delete list */ /* now delete each one from delete list */
while (dellist) { while (dellist) {
...@@ -1253,10 +1208,9 @@ int virtpci_register_driver(struct virtpci_driver *drv) ...@@ -1253,10 +1208,9 @@ int virtpci_register_driver(struct virtpci_driver *drv)
{ {
int result = 0; int result = 0;
if (drv->id_table == NULL) { if (drv->id_table == NULL)
LOGERR("id_table missing\n");
return 1; return 1;
}
/* initialize core driver fields needed to call driver_register */ /* initialize core driver fields needed to call driver_register */
drv->core_driver.name = drv->name; /* name of driver in sysfs */ drv->core_driver.name = drv->name; /* name of driver in sysfs */
drv->core_driver.bus = &virtpci_bus_type; /* type of bus this drv->core_driver.bus = &virtpci_bus_type; /* type of bus this
...@@ -1338,7 +1292,6 @@ static ssize_t info_debugfs_read(struct file *file, char __user *buf, ...@@ -1338,7 +1292,6 @@ static ssize_t info_debugfs_read(struct file *file, char __user *buf,
printparam.len = &len; printparam.len = &len;
if (bus_for_each_dev(&virtpci_bus_type, NULL, if (bus_for_each_dev(&virtpci_bus_type, NULL,
(void *)&printparam, print_vbus)) (void *)&printparam, print_vbus))
LOGERR("Failed to find bus\n");
str_pos += scnprintf(vbuf + str_pos, len - str_pos, str_pos += scnprintf(vbuf + str_pos, len - str_pos,
"\n Virtual PCI devices\n"); "\n Virtual PCI devices\n");
...@@ -1401,7 +1354,6 @@ static int __init virtpci_mod_init(void) ...@@ -1401,7 +1354,6 @@ static int __init virtpci_mod_init(void)
* drivers directory * drivers directory
*/ */
if (ret) { if (ret) {
LOGERR("bus_register ****FAILED:%d\n", ret);
POSTCODE_LINUX_3(VPCI_CREATE_FAILURE_PC, ret, POSTCODE_LINUX_3(VPCI_CREATE_FAILURE_PC, ret,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
return ret; return ret;
...@@ -1412,7 +1364,6 @@ static int __init virtpci_mod_init(void) ...@@ -1412,7 +1364,6 @@ static int __init virtpci_mod_init(void)
/* create a root bus used to parent all the virtpci buses. */ /* create a root bus used to parent all the virtpci buses. */
ret = device_register(&virtpci_rootbus_device); ret = device_register(&virtpci_rootbus_device);
if (ret) { if (ret) {
LOGERR("device_register FAILED:%d\n", ret);
bus_unregister(&virtpci_bus_type); bus_unregister(&virtpci_bus_type);
POSTCODE_LINUX_3(VPCI_CREATE_FAILURE_PC, ret, POSTCODE_LINUX_3(VPCI_CREATE_FAILURE_PC, ret,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
...@@ -1421,7 +1372,6 @@ static int __init virtpci_mod_init(void) ...@@ -1421,7 +1372,6 @@ static int __init virtpci_mod_init(void)
if (!uisctrl_register_req_handler(2, (void *)&virtpci_ctrlchan_func, if (!uisctrl_register_req_handler(2, (void *)&virtpci_ctrlchan_func,
&chipset_driver_info)) { &chipset_driver_info)) {
LOGERR("uisctrl_register_req_handler ****FAILED.\n");
POSTCODE_LINUX_2(VPCI_CREATE_FAILURE_PC, POSTCODE_SEVERITY_ERR); POSTCODE_LINUX_2(VPCI_CREATE_FAILURE_PC, POSTCODE_SEVERITY_ERR);
device_unregister(&virtpci_rootbus_device); device_unregister(&virtpci_rootbus_device);
bus_unregister(&virtpci_bus_type); bus_unregister(&virtpci_bus_type);
...@@ -1439,9 +1389,6 @@ static int __init virtpci_mod_init(void) ...@@ -1439,9 +1389,6 @@ static int __init virtpci_mod_init(void)
static void __exit virtpci_mod_exit(void) static void __exit virtpci_mod_exit(void)
{ {
/* unregister the callback function */ /* unregister the callback function */
if (!uisctrl_register_req_handler(2, NULL, NULL))
LOGERR("uisctrl_register_req_handler ****FAILED.\n");
device_unregister(&virtpci_rootbus_device); device_unregister(&virtpci_rootbus_device);
bus_unregister(&virtpci_bus_type); bus_unregister(&virtpci_bus_type);
debugfs_remove_recursive(virtpci_debugfs_dir); debugfs_remove_recursive(virtpci_debugfs_dir);
......
...@@ -77,13 +77,11 @@ visorchannel_create_guts(HOSTADDRESS physaddr, ulong channel_bytes, ...@@ -77,13 +77,11 @@ visorchannel_create_guts(HOSTADDRESS physaddr, ulong channel_bytes,
visor_memregion_create_overlapped(parent->memregion, visor_memregion_create_overlapped(parent->memregion,
off, sizeof(struct channel_header)); off, sizeof(struct channel_header));
if (p->memregion == NULL) { if (p->memregion == NULL) {
ERRDRV("visor_memregion_create failed failed: (status=0)\n");
rc = NULL; rc = NULL;
goto cleanup; goto cleanup;
} }
if (visor_memregion_read(p->memregion, 0, &p->chan_hdr, if (visor_memregion_read(p->memregion, 0, &p->chan_hdr,
sizeof(struct channel_header)) < 0) { sizeof(struct channel_header)) < 0) {
ERRDRV("visor_memregion_read failed: (status=0)\n");
rc = NULL; rc = NULL;
goto cleanup; goto cleanup;
} }
...@@ -94,7 +92,6 @@ visorchannel_create_guts(HOSTADDRESS physaddr, ulong channel_bytes, ...@@ -94,7 +92,6 @@ visorchannel_create_guts(HOSTADDRESS physaddr, ulong channel_bytes,
/* we had better be a CLIENT of this channel */ /* we had better be a CLIENT of this channel */
guid = p->chan_hdr.chtype; guid = p->chan_hdr.chtype;
if (visor_memregion_resize(p->memregion, channel_bytes) < 0) { if (visor_memregion_resize(p->memregion, channel_bytes) < 0) {
ERRDRV("visor_memregion_resize failed: (status=0)\n");
rc = NULL; rc = NULL;
goto cleanup; goto cleanup;
} }
...@@ -255,10 +252,9 @@ visorchannel_clear(struct visorchannel *channel, ulong offset, u8 ch, ...@@ -255,10 +252,9 @@ visorchannel_clear(struct visorchannel *channel, ulong offset, u8 ch,
int written = 0; int written = 0;
u8 *buf = vmalloc(bufsize); u8 *buf = vmalloc(bufsize);
if (buf == NULL) { if (buf == NULL)
ERRDRV("%s failed memory allocation", __func__);
goto cleanup; goto cleanup;
}
memset(buf, ch, bufsize); memset(buf, ch, bufsize);
while (nbytes > 0) { while (nbytes > 0) {
ulong thisbytes = bufsize; ulong thisbytes = bufsize;
...@@ -323,10 +319,8 @@ sig_read_header(struct visorchannel *channel, u32 queue, ...@@ -323,10 +319,8 @@ sig_read_header(struct visorchannel *channel, u32 queue,
{ {
BOOL rc = FALSE; BOOL rc = FALSE;
if (channel->chan_hdr.ch_space_offset < sizeof(struct channel_header)) { if (channel->chan_hdr.ch_space_offset < sizeof(struct channel_header))
ERRDRV("oChannelSpace too small: (status=%d)\n", rc);
goto cleanup; goto cleanup;
}
/* Read the appropriate SIGNAL_QUEUE_HEADER into local memory. */ /* Read the appropriate SIGNAL_QUEUE_HEADER into local memory. */
...@@ -334,10 +328,6 @@ sig_read_header(struct visorchannel *channel, u32 queue, ...@@ -334,10 +328,6 @@ sig_read_header(struct visorchannel *channel, u32 queue,
SIG_QUEUE_OFFSET(&channel->chan_hdr, queue), SIG_QUEUE_OFFSET(&channel->chan_hdr, queue),
sig_hdr, sig_hdr,
sizeof(struct signal_queue_header)) < 0) { sizeof(struct signal_queue_header)) < 0) {
ERRDRV("queue=%d SIG_QUEUE_OFFSET=%d",
queue, (int)SIG_QUEUE_OFFSET(&channel->chan_hdr, queue));
ERRDRV("visor_memregion_read of signal queue failed: (status=%d)\n",
rc);
goto cleanup; goto cleanup;
} }
rc = TRUE; rc = TRUE;
...@@ -357,15 +347,11 @@ sig_do_data(struct visorchannel *channel, u32 queue, ...@@ -357,15 +347,11 @@ sig_do_data(struct visorchannel *channel, u32 queue,
if (visor_memregion_write(channel->memregion, if (visor_memregion_write(channel->memregion,
signal_data_offset, signal_data_offset,
data, sig_hdr->signal_size) < 0) { data, sig_hdr->signal_size) < 0) {
ERRDRV("visor_memregion_write of signal data failed: (status=%d)\n",
rc);
goto cleanup; goto cleanup;
} }
} else { } else {
if (visor_memregion_read(channel->memregion, signal_data_offset, if (visor_memregion_read(channel->memregion, signal_data_offset,
data, sig_hdr->signal_size) < 0) { data, sig_hdr->signal_size) < 0) {
ERRDRV("visor_memregion_read of signal data failed: (status=%d)\n",
rc);
goto cleanup; goto cleanup;
} }
} }
...@@ -403,8 +389,6 @@ safe_sig_queue_validate(struct signal_queue_header *psafe_sqh, ...@@ -403,8 +389,6 @@ safe_sig_queue_validate(struct signal_queue_header *psafe_sqh,
punsafe_sqh->head = *phead; punsafe_sqh->head = *phead;
punsafe_sqh->tail = *ptail; punsafe_sqh->tail = *ptail;
ERRDRV("safe_sig_queue_validate: head = 0x%x, tail = 0x%x, MaxSlots = 0x%x",
*phead, *ptail, psafe_sqh->max_slots);
return 0; return 0;
} }
return 1; return 1;
...@@ -422,7 +406,6 @@ signalremove_inner(struct visorchannel *channel, u32 queue, void *msg) ...@@ -422,7 +406,6 @@ signalremove_inner(struct visorchannel *channel, u32 queue, void *msg)
sig_hdr.tail = (sig_hdr.tail + 1) % sig_hdr.max_slots; sig_hdr.tail = (sig_hdr.tail + 1) % sig_hdr.max_slots;
if (!sig_read_data(channel, queue, &sig_hdr, sig_hdr.tail, msg)) { if (!sig_read_data(channel, queue, &sig_hdr, sig_hdr.tail, msg)) {
ERRDRV("sig_read_data failed\n");
return FALSE; return FALSE;
} }
sig_hdr.num_received++; sig_hdr.num_received++;
...@@ -431,14 +414,10 @@ signalremove_inner(struct visorchannel *channel, u32 queue, void *msg) ...@@ -431,14 +414,10 @@ signalremove_inner(struct visorchannel *channel, u32 queue, void *msg)
* update host memory. * update host memory.
*/ */
mb(); /* required for channel synch */ mb(); /* required for channel synch */
if (!SIG_WRITE_FIELD(channel, queue, &sig_hdr, tail)) { if (!SIG_WRITE_FIELD(channel, queue, &sig_hdr, tail))
ERRDRV("visor_memregion_write of Tail failed\n");
return FALSE; return FALSE;
} if (!SIG_WRITE_FIELD(channel, queue, &sig_hdr, num_received))
if (!SIG_WRITE_FIELD(channel, queue, &sig_hdr, num_received)) {
ERRDRV("visor_memregion_write of NumSignalsReceived failed\n");
return FALSE; return FALSE;
}
return TRUE; return TRUE;
} }
...@@ -470,28 +449,28 @@ signalinsert_inner(struct visorchannel *channel, u32 queue, void *msg) ...@@ -470,28 +449,28 @@ signalinsert_inner(struct visorchannel *channel, u32 queue, void *msg)
sig_hdr.head = ((sig_hdr.head + 1) % sig_hdr.max_slots); sig_hdr.head = ((sig_hdr.head + 1) % sig_hdr.max_slots);
if (sig_hdr.head == sig_hdr.tail) { if (sig_hdr.head == sig_hdr.tail) {
sig_hdr.num_overflows++; sig_hdr.num_overflows++;
if (!SIG_WRITE_FIELD(channel, queue, &sig_hdr, num_overflows)) visor_memregion_write(channel->memregion,
ERRDRV("visor_memregion_write of NumOverflows failed\n"); SIG_QUEUE_OFFSET(&channel->chan_hdr,
queue) +
offsetof(struct signal_queue_header,
num_overflows),
&(sig_hdr.num_overflows),
sizeof(sig_hdr.num_overflows));
return FALSE; return FALSE;
} }
if (!sig_write_data(channel, queue, &sig_hdr, sig_hdr.head, msg)) { if (!sig_write_data(channel, queue, &sig_hdr, sig_hdr.head, msg))
ERRDRV("sig_write_data failed\n");
return FALSE; return FALSE;
}
sig_hdr.num_sent++; sig_hdr.num_sent++;
/* For each data field in SIGNAL_QUEUE_HEADER that was modified, /* For each data field in SIGNAL_QUEUE_HEADER that was modified,
* update host memory. * update host memory.
*/ */
mb(); /* required for channel synch */ mb(); /* required for channel synch */
if (!SIG_WRITE_FIELD(channel, queue, &sig_hdr, head)) { if (!SIG_WRITE_FIELD(channel, queue, &sig_hdr, head))
ERRDRV("visor_memregion_write of Head failed\n");
return FALSE; return FALSE;
}
if (!SIG_WRITE_FIELD(channel, queue, &sig_hdr, num_sent)) { if (!SIG_WRITE_FIELD(channel, queue, &sig_hdr, num_sent)) {
ERRDRV("visor_memregion_write of NumSignalsSent failed\n");
return FALSE; return FALSE;
} }
...@@ -581,15 +560,13 @@ visorchannel_debug(struct visorchannel *channel, int num_queues, ...@@ -581,15 +560,13 @@ visorchannel_debug(struct visorchannel *channel, int num_queues,
int i = 0; int i = 0;
int errcode = 0; int errcode = 0;
if (channel == NULL) { if (channel == NULL)
ERRDRV("%s no channel", __func__);
return; return;
}
memregion = channel->memregion; memregion = channel->memregion;
if (memregion == NULL) { if (memregion == NULL)
ERRDRV("%s no memregion", __func__);
return; return;
}
addr = visor_memregion_get_physaddr(memregion); addr = visor_memregion_get_physaddr(memregion);
nbytes_region = visor_memregion_get_nbytes(memregion); nbytes_region = visor_memregion_get_nbytes(memregion);
errcode = visorchannel_read(channel, off, errcode = visorchannel_read(channel, off,
...@@ -669,11 +646,8 @@ visorchannel_dump_section(struct visorchannel *chan, char *s, ...@@ -669,11 +646,8 @@ visorchannel_dump_section(struct visorchannel *chan, char *s,
goto fmt_failed; goto fmt_failed;
errcode = visorchannel_read(chan, off, buf, len); errcode = visorchannel_read(chan, off, buf, len);
if (errcode < 0) { if (errcode < 0)
ERRDRV("%s failed to read %s from channel errcode=%d",
s, __func__, errcode);
goto read_failed; goto read_failed;
}
seq_printf(seq, "channel %s:\n", s); seq_printf(seq, "channel %s:\n", s);
tbuf = buf; tbuf = buf;
while (len > 0) { while (len > 0) {
......
...@@ -60,25 +60,18 @@ visorchipset_file_init(dev_t major_dev, struct visorchannel **controlvm_channel) ...@@ -60,25 +60,18 @@ visorchipset_file_init(dev_t major_dev, struct visorchannel **controlvm_channel)
file_cdev.owner = THIS_MODULE; file_cdev.owner = THIS_MODULE;
if (MAJOR(majordev) == 0) { if (MAJOR(majordev) == 0) {
/* dynamic major device number registration required */ /* dynamic major device number registration required */
if (alloc_chrdev_region(&majordev, 0, 1, MYDRVNAME) < 0) { if (alloc_chrdev_region(&majordev, 0, 1, MYDRVNAME) < 0)
ERRDRV("Unable to allocate+register char device %s",
MYDRVNAME);
return -1; return -1;
}
registered = TRUE; registered = TRUE;
} else { } else {
/* static major device number registration required */ /* static major device number registration required */
if (register_chrdev_region(majordev, 1, MYDRVNAME) < 0) { if (register_chrdev_region(majordev, 1, MYDRVNAME) < 0)
ERRDRV("Unable to register char device %s", MYDRVNAME);
return -1; return -1;
}
registered = TRUE; registered = TRUE;
} }
rc = cdev_add(&file_cdev, MKDEV(MAJOR(majordev), 0), 1); rc = cdev_add(&file_cdev, MKDEV(MAJOR(majordev), 0), 1);
if (rc < 0) { if (rc < 0)
ERRDRV("failed to create char device: (status=%d)\n", rc);
return -1; return -1;
}
return 0; return 0;
} }
...@@ -122,15 +115,13 @@ visorchipset_mmap(struct file *file, struct vm_area_struct *vma) ...@@ -122,15 +115,13 @@ visorchipset_mmap(struct file *file, struct vm_area_struct *vma)
GUEST_PHYSICAL_ADDRESS addr = 0; GUEST_PHYSICAL_ADDRESS addr = 0;
/* sv_enable_dfp(); */ /* sv_enable_dfp(); */
if (offset & (PAGE_SIZE - 1)) { if (offset & (PAGE_SIZE - 1))
ERRDRV("%s virtual address NOT page-aligned!", __func__);
return -ENXIO; /* need aligned offsets */ return -ENXIO; /* need aligned offsets */
}
switch (offset) { switch (offset) {
case VISORCHIPSET_MMAP_CONTROLCHANOFFSET: case VISORCHIPSET_MMAP_CONTROLCHANOFFSET:
vma->vm_flags |= VM_IO; vma->vm_flags |= VM_IO;
if (*file_controlvm_channel == NULL) { if (*file_controlvm_channel == NULL) {
ERRDRV("%s no controlvm channel yet", __func__);
return -ENXIO; return -ENXIO;
} }
visorchannel_read(*file_controlvm_channel, visorchannel_read(*file_controlvm_channel,
...@@ -138,7 +129,6 @@ visorchipset_mmap(struct file *file, struct vm_area_struct *vma) ...@@ -138,7 +129,6 @@ visorchipset_mmap(struct file *file, struct vm_area_struct *vma)
gp_control_channel), gp_control_channel),
&addr, sizeof(addr)); &addr, sizeof(addr));
if (addr == 0) { if (addr == 0) {
ERRDRV("%s control channel address is 0", __func__);
return -ENXIO; return -ENXIO;
} }
physaddr = (ulong)addr; physaddr = (ulong)addr;
...@@ -147,7 +137,6 @@ visorchipset_mmap(struct file *file, struct vm_area_struct *vma) ...@@ -147,7 +137,6 @@ visorchipset_mmap(struct file *file, struct vm_area_struct *vma)
vma->vm_end - vma->vm_start, vma->vm_end - vma->vm_start,
/*pgprot_noncached */ /*pgprot_noncached */
(vma->vm_page_prot))) { (vma->vm_page_prot))) {
ERRDRV("%s remap_pfn_range failed", __func__);
return -EAGAIN; return -EAGAIN;
} }
break; break;
...@@ -179,7 +168,6 @@ static long visorchipset_ioctl(struct file *file, unsigned int cmd, ...@@ -179,7 +168,6 @@ static long visorchipset_ioctl(struct file *file, unsigned int cmd,
} }
return issue_vmcall_update_physical_time(adjustment); return issue_vmcall_update_physical_time(adjustment);
default: default:
LOGERR("visorchipset_ioctl received invalid command");
return -EFAULT; return -EFAULT;
} }
} }
...@@ -59,9 +59,6 @@ parser_init_guts(u64 addr, u32 bytes, BOOL isLocal, ...@@ -59,9 +59,6 @@ parser_init_guts(u64 addr, u32 bytes, BOOL isLocal,
allocbytes++; allocbytes++;
if ((Controlvm_Payload_Bytes_Buffered + bytes) if ((Controlvm_Payload_Bytes_Buffered + bytes)
> MAX_CONTROLVM_PAYLOAD_BYTES) { > MAX_CONTROLVM_PAYLOAD_BYTES) {
ERRDRV("%s (%s:%d) - prevented allocation of %d bytes to prevent exceeding throttling max (%d)",
__func__, __FILE__, __LINE__, allocbytes,
MAX_CONTROLVM_PAYLOAD_BYTES);
if (tryAgain) if (tryAgain)
*tryAgain = TRUE; *tryAgain = TRUE;
rc = NULL; rc = NULL;
...@@ -84,9 +81,6 @@ parser_init_guts(u64 addr, u32 bytes, BOOL isLocal, ...@@ -84,9 +81,6 @@ parser_init_guts(u64 addr, u32 bytes, BOOL isLocal,
void *p; void *p;
if (addr > virt_to_phys(high_memory - 1)) { if (addr > virt_to_phys(high_memory - 1)) {
ERRDRV("%s - bad local address (0x%-16.16Lx for %lu)",
__func__,
(unsigned long long) addr, (ulong) bytes);
rc = NULL; rc = NULL;
goto Away; goto Away;
} }
...@@ -110,27 +104,15 @@ parser_init_guts(u64 addr, u32 bytes, BOOL isLocal, ...@@ -110,27 +104,15 @@ parser_init_guts(u64 addr, u32 bytes, BOOL isLocal,
} }
phdr = (struct spar_controlvm_parameters_header *)(ctx->data); phdr = (struct spar_controlvm_parameters_header *)(ctx->data);
if (phdr->total_length != bytes) { if (phdr->total_length != bytes) {
ERRDRV("%s - bad total length %lu (should be %lu)",
__func__,
(ulong) (phdr->total_length), (ulong) (bytes));
rc = NULL; rc = NULL;
goto Away; goto Away;
} }
if (phdr->total_length < phdr->header_length) { if (phdr->total_length < phdr->header_length) {
ERRDRV("%s - total length < header length (%lu < %lu)",
__func__,
(ulong) (phdr->total_length),
(ulong) (phdr->header_length));
rc = NULL; rc = NULL;
goto Away; goto Away;
} }
if (phdr->header_length < if (phdr->header_length <
sizeof(struct spar_controlvm_parameters_header)) { sizeof(struct spar_controlvm_parameters_header)) {
ERRDRV("%s - header is too small (%lu < %lu)",
__func__,
(ulong) (phdr->header_length),
(ulong)(sizeof(
struct spar_controlvm_parameters_header)));
rc = NULL; rc = NULL;
goto Away; goto Away;
} }
...@@ -198,11 +180,8 @@ parser_id_get(PARSER_CONTEXT *ctx) ...@@ -198,11 +180,8 @@ parser_id_get(PARSER_CONTEXT *ctx)
{ {
struct spar_controlvm_parameters_header *phdr = NULL; struct spar_controlvm_parameters_header *phdr = NULL;
if (ctx == NULL) { if (ctx == NULL)
ERRDRV("%s (%s:%d) - no context",
__func__, __FILE__, __LINE__);
return NULL_UUID_LE; return NULL_UUID_LE;
}
phdr = (struct spar_controlvm_parameters_header *)(ctx->data); phdr = (struct spar_controlvm_parameters_header *)(ctx->data);
return phdr->id; return phdr->id;
} }
...@@ -212,11 +191,8 @@ parser_param_start(PARSER_CONTEXT *ctx, PARSER_WHICH_STRING which_string) ...@@ -212,11 +191,8 @@ parser_param_start(PARSER_CONTEXT *ctx, PARSER_WHICH_STRING which_string)
{ {
struct spar_controlvm_parameters_header *phdr = NULL; struct spar_controlvm_parameters_header *phdr = NULL;
if (ctx == NULL) { if (ctx == NULL)
ERRDRV("%s (%s:%d) - no context",
__func__, __FILE__, __LINE__);
goto Away; goto Away;
}
phdr = (struct spar_controlvm_parameters_header *)(ctx->data); phdr = (struct spar_controlvm_parameters_header *)(ctx->data);
switch (which_string) { switch (which_string) {
case PARSERSTRING_INITIATOR: case PARSERSTRING_INITIATOR:
...@@ -236,7 +212,6 @@ parser_param_start(PARSER_CONTEXT *ctx, PARSER_WHICH_STRING which_string) ...@@ -236,7 +212,6 @@ parser_param_start(PARSER_CONTEXT *ctx, PARSER_WHICH_STRING which_string)
ctx->bytes_remaining = phdr->name_length; ctx->bytes_remaining = phdr->name_length;
break; break;
default: default:
ERRDRV("%s - bad which_string %d", __func__, which_string);
break; break;
} }
...@@ -319,25 +294,18 @@ parser_param_get(PARSER_CONTEXT *ctx, char *nam, int namesize) ...@@ -319,25 +294,18 @@ parser_param_get(PARSER_CONTEXT *ctx, char *nam, int namesize)
} }
while (*pscan != ':') { while (*pscan != ':') {
if (namesize <= 0) { if (namesize <= 0)
ERRDRV("%s - name too big", __func__);
return NULL; return NULL;
}
*pnam = toupper(*pscan); *pnam = toupper(*pscan);
pnam++; pnam++;
namesize--; namesize--;
pscan++; pscan++;
nscan--; nscan--;
if (nscan == 0) { if (nscan == 0)
ERRDRV("%s - unexpected end of input parsing name",
__func__);
return NULL; return NULL;
}
} }
if (namesize <= 0) { if (namesize <= 0)
ERRDRV("%s - name too big", __func__);
return NULL; return NULL;
}
*pnam = '\0'; *pnam = '\0';
nam[string_length_no_trail(nam, strlen(nam))] = '\0'; nam[string_length_no_trail(nam, strlen(nam))] = '\0';
...@@ -348,26 +316,17 @@ parser_param_get(PARSER_CONTEXT *ctx, char *nam, int namesize) ...@@ -348,26 +316,17 @@ parser_param_get(PARSER_CONTEXT *ctx, char *nam, int namesize)
while (isspace(*pscan)) { while (isspace(*pscan)) {
pscan++; pscan++;
nscan--; nscan--;
if (nscan == 0) { if (nscan == 0)
ERRDRV("%s - unexpected end of input looking for value",
__func__);
return NULL; return NULL;
}
} }
if (nscan == 0) { if (nscan == 0)
ERRDRV("%s - unexpected end of input looking for value",
__func__);
return NULL; return NULL;
}
if (*pscan == '\'' || *pscan == '"') { if (*pscan == '\'' || *pscan == '"') {
closing_quote = *pscan; closing_quote = *pscan;
pscan++; pscan++;
nscan--; nscan--;
if (nscan == 0) { if (nscan == 0)
ERRDRV("%s - unexpected end of input after %c",
__func__, closing_quote);
return NULL; return NULL;
}
} }
/* look for a separator character, terminator character, or /* look for a separator character, terminator character, or
...@@ -375,10 +334,8 @@ parser_param_get(PARSER_CONTEXT *ctx, char *nam, int namesize) ...@@ -375,10 +334,8 @@ parser_param_get(PARSER_CONTEXT *ctx, char *nam, int namesize)
*/ */
for (i = 0, value_length = -1; i < nscan; i++) { for (i = 0, value_length = -1; i < nscan; i++) {
if (closing_quote) { if (closing_quote) {
if (pscan[i] == '\0') { if (pscan[i] == '\0')
ERRDRV("%s - unexpected end of input parsing quoted value", __func__);
return NULL; return NULL;
}
if (pscan[i] == closing_quote) { if (pscan[i] == closing_quote) {
value_length = i; value_length = i;
break; break;
...@@ -391,10 +348,8 @@ parser_param_get(PARSER_CONTEXT *ctx, char *nam, int namesize) ...@@ -391,10 +348,8 @@ parser_param_get(PARSER_CONTEXT *ctx, char *nam, int namesize)
} }
} }
if (value_length < 0) { if (value_length < 0) {
if (closing_quote) { if (closing_quote)
ERRDRV("%s - unexpected end of input parsing quoted value", __func__);
return NULL; return NULL;
}
value_length = nscan; value_length = nscan;
} }
orig_value_length = value_length; orig_value_length = value_length;
...@@ -431,7 +386,6 @@ parser_param_get(PARSER_CONTEXT *ctx, char *nam, int namesize) ...@@ -431,7 +386,6 @@ parser_param_get(PARSER_CONTEXT *ctx, char *nam, int namesize)
pscan++; pscan++;
nscan--; nscan--;
} else if (*pscan != '\0') { } else if (*pscan != '\0') {
ERRDRV("%s - missing separator after quoted string", __func__);
kfree(value); kfree(value);
value = NULL; value = NULL;
return NULL; return NULL;
......
...@@ -659,7 +659,6 @@ chipset_init(struct controlvm_message *inmsg) ...@@ -659,7 +659,6 @@ chipset_init(struct controlvm_message *inmsg)
POSTCODE_LINUX_2(CHIPSET_INIT_ENTRY_PC, POSTCODE_SEVERITY_INFO); POSTCODE_LINUX_2(CHIPSET_INIT_ENTRY_PC, POSTCODE_SEVERITY_INFO);
if (chipset_inited) { if (chipset_inited) {
LOGERR("CONTROLVM_CHIPSET_INIT Failed: Already Done.");
rc = -CONTROLVM_RESP_ERROR_ALREADY_DONE; rc = -CONTROLVM_RESP_ERROR_ALREADY_DONE;
goto Away; goto Away;
} }
...@@ -717,7 +716,6 @@ controlvm_respond(struct controlvm_message_header *msgHdr, int response) ...@@ -717,7 +716,6 @@ controlvm_respond(struct controlvm_message_header *msgHdr, int response)
if (!visorchannel_signalinsert(ControlVm_channel, if (!visorchannel_signalinsert(ControlVm_channel,
CONTROLVM_QUEUE_REQUEST, &outmsg)) { CONTROLVM_QUEUE_REQUEST, &outmsg)) {
LOGERR("signalinsert failed!");
return; return;
} }
} }
...@@ -733,7 +731,6 @@ controlvm_respond_chipset_init(struct controlvm_message_header *msgHdr, ...@@ -733,7 +731,6 @@ controlvm_respond_chipset_init(struct controlvm_message_header *msgHdr,
outmsg.cmd.init_chipset.features = features; outmsg.cmd.init_chipset.features = features;
if (!visorchannel_signalinsert(ControlVm_channel, if (!visorchannel_signalinsert(ControlVm_channel,
CONTROLVM_QUEUE_REQUEST, &outmsg)) { CONTROLVM_QUEUE_REQUEST, &outmsg)) {
LOGERR("signalinsert failed!");
return; return;
} }
} }
...@@ -749,7 +746,6 @@ static void controlvm_respond_physdev_changestate( ...@@ -749,7 +746,6 @@ static void controlvm_respond_physdev_changestate(
outmsg.cmd.device_change_state.flags.phys_device = 1; outmsg.cmd.device_change_state.flags.phys_device = 1;
if (!visorchannel_signalinsert(ControlVm_channel, if (!visorchannel_signalinsert(ControlVm_channel,
CONTROLVM_QUEUE_REQUEST, &outmsg)) { CONTROLVM_QUEUE_REQUEST, &outmsg)) {
LOGERR("signalinsert failed!");
return; return;
} }
} }
...@@ -766,15 +762,12 @@ visorchipset_save_message(struct controlvm_message *msg, ...@@ -766,15 +762,12 @@ visorchipset_save_message(struct controlvm_message *msg,
offsetof(struct spar_controlvm_channel_protocol, offsetof(struct spar_controlvm_channel_protocol,
saved_crash_message_count), saved_crash_message_count),
&localSavedCrashMsgCount, sizeof(u16)) < 0) { &localSavedCrashMsgCount, sizeof(u16)) < 0) {
LOGERR("failed to get Saved Message Count");
POSTCODE_LINUX_2(CRASH_DEV_CTRL_RD_FAILURE_PC, POSTCODE_LINUX_2(CRASH_DEV_CTRL_RD_FAILURE_PC,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
return; return;
} }
if (localSavedCrashMsgCount != CONTROLVM_CRASHMSG_MAX) { if (localSavedCrashMsgCount != CONTROLVM_CRASHMSG_MAX) {
LOGERR("Saved Message Count incorrect %d",
localSavedCrashMsgCount);
POSTCODE_LINUX_3(CRASH_DEV_COUNT_FAILURE_PC, POSTCODE_LINUX_3(CRASH_DEV_COUNT_FAILURE_PC,
localSavedCrashMsgCount, localSavedCrashMsgCount,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
...@@ -786,7 +779,6 @@ visorchipset_save_message(struct controlvm_message *msg, ...@@ -786,7 +779,6 @@ visorchipset_save_message(struct controlvm_message *msg,
offsetof(struct spar_controlvm_channel_protocol, offsetof(struct spar_controlvm_channel_protocol,
saved_crash_message_offset), saved_crash_message_offset),
&localSavedCrashMsgOffset, sizeof(u32)) < 0) { &localSavedCrashMsgOffset, sizeof(u32)) < 0) {
LOGERR("failed to get Saved Message Offset");
POSTCODE_LINUX_2(CRASH_DEV_CTRL_RD_FAILURE_PC, POSTCODE_LINUX_2(CRASH_DEV_CTRL_RD_FAILURE_PC,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
return; return;
...@@ -797,7 +789,6 @@ visorchipset_save_message(struct controlvm_message *msg, ...@@ -797,7 +789,6 @@ visorchipset_save_message(struct controlvm_message *msg,
localSavedCrashMsgOffset, localSavedCrashMsgOffset,
msg, msg,
sizeof(struct controlvm_message)) < 0) { sizeof(struct controlvm_message)) < 0) {
LOGERR("SAVE_MSG_BUS_FAILURE: Failed to write CrashCreateBusMsg!");
POSTCODE_LINUX_2(SAVE_MSG_BUS_FAILURE_PC, POSTCODE_LINUX_2(SAVE_MSG_BUS_FAILURE_PC,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
return; return;
...@@ -807,7 +798,6 @@ visorchipset_save_message(struct controlvm_message *msg, ...@@ -807,7 +798,6 @@ visorchipset_save_message(struct controlvm_message *msg,
localSavedCrashMsgOffset + localSavedCrashMsgOffset +
sizeof(struct controlvm_message), msg, sizeof(struct controlvm_message), msg,
sizeof(struct controlvm_message)) < 0) { sizeof(struct controlvm_message)) < 0) {
LOGERR("SAVE_MSG_DEV_FAILURE: Failed to write CrashCreateDevMsg!");
POSTCODE_LINUX_2(SAVE_MSG_DEV_FAILURE_PC, POSTCODE_LINUX_2(SAVE_MSG_DEV_FAILURE_PC,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
return; return;
...@@ -823,10 +813,9 @@ bus_responder(enum controlvm_id cmdId, ulong busNo, int response) ...@@ -823,10 +813,9 @@ bus_responder(enum controlvm_id cmdId, ulong busNo, int response)
BOOL need_clear = FALSE; BOOL need_clear = FALSE;
p = findbus(&BusInfoList, busNo); p = findbus(&BusInfoList, busNo);
if (!p) { if (!p)
LOGERR("internal error busNo=%lu", busNo);
return; return;
}
if (response < 0) { if (response < 0) {
if ((cmdId == CONTROLVM_BUS_CREATE) && if ((cmdId == CONTROLVM_BUS_CREATE) &&
(response != (-CONTROLVM_RESP_ERROR_ALREADY_DONE))) (response != (-CONTROLVM_RESP_ERROR_ALREADY_DONE)))
...@@ -839,14 +828,10 @@ bus_responder(enum controlvm_id cmdId, ulong busNo, int response) ...@@ -839,14 +828,10 @@ bus_responder(enum controlvm_id cmdId, ulong busNo, int response)
need_clear = TRUE; need_clear = TRUE;
} }
if (p->pending_msg_hdr.id == CONTROLVM_INVALID) { if (p->pending_msg_hdr.id == CONTROLVM_INVALID)
LOGERR("bus_responder no pending msg");
return; /* no controlvm response needed */ return; /* no controlvm response needed */
} if (p->pending_msg_hdr.id != (u32) cmdId)
if (p->pending_msg_hdr.id != (u32) cmdId) {
LOGERR("expected=%d, found=%d", cmdId, p->pending_msg_hdr.id);
return; return;
}
controlvm_respond(&p->pending_msg_hdr, response); controlvm_respond(&p->pending_msg_hdr, response);
p->pending_msg_hdr.id = CONTROLVM_INVALID; p->pending_msg_hdr.id = CONTROLVM_INVALID;
if (need_clear) { if (need_clear) {
...@@ -864,18 +849,12 @@ device_changestate_responder(enum controlvm_id cmdId, ...@@ -864,18 +849,12 @@ device_changestate_responder(enum controlvm_id cmdId,
struct controlvm_message outmsg; struct controlvm_message outmsg;
p = finddevice(&DevInfoList, busNo, devNo); p = finddevice(&DevInfoList, busNo, devNo);
if (!p) { if (!p)
LOGERR("internal error; busNo=%lu, devNo=%lu", busNo, devNo);
return; return;
} if (p->pending_msg_hdr.id == CONTROLVM_INVALID)
if (p->pending_msg_hdr.id == CONTROLVM_INVALID) {
LOGERR("device_responder no pending msg");
return; /* no controlvm response needed */ return; /* no controlvm response needed */
} if (p->pending_msg_hdr.id != cmdId)
if (p->pending_msg_hdr.id != cmdId) {
LOGERR("expected=%d, found=%d", cmdId, p->pending_msg_hdr.id);
return; return;
}
controlvm_init_response(&outmsg, &p->pending_msg_hdr, response); controlvm_init_response(&outmsg, &p->pending_msg_hdr, response);
...@@ -884,10 +863,8 @@ device_changestate_responder(enum controlvm_id cmdId, ...@@ -884,10 +863,8 @@ device_changestate_responder(enum controlvm_id cmdId,
outmsg.cmd.device_change_state.state = responseState; outmsg.cmd.device_change_state.state = responseState;
if (!visorchannel_signalinsert(ControlVm_channel, if (!visorchannel_signalinsert(ControlVm_channel,
CONTROLVM_QUEUE_REQUEST, &outmsg)) { CONTROLVM_QUEUE_REQUEST, &outmsg))
LOGERR("signalinsert failed!");
return; return;
}
p->pending_msg_hdr.id = CONTROLVM_INVALID; p->pending_msg_hdr.id = CONTROLVM_INVALID;
} }
...@@ -900,10 +877,8 @@ device_responder(enum controlvm_id cmdId, ulong busNo, ulong devNo, ...@@ -900,10 +877,8 @@ device_responder(enum controlvm_id cmdId, ulong busNo, ulong devNo,
BOOL need_clear = FALSE; BOOL need_clear = FALSE;
p = finddevice(&DevInfoList, busNo, devNo); p = finddevice(&DevInfoList, busNo, devNo);
if (!p) { if (!p)
LOGERR("internal error; busNo=%lu, devNo=%lu", busNo, devNo);
return; return;
}
if (response >= 0) { if (response >= 0) {
if (cmdId == CONTROLVM_DEVICE_CREATE) if (cmdId == CONTROLVM_DEVICE_CREATE)
p->state.created = 1; p->state.created = 1;
...@@ -911,14 +886,12 @@ device_responder(enum controlvm_id cmdId, ulong busNo, ulong devNo, ...@@ -911,14 +886,12 @@ device_responder(enum controlvm_id cmdId, ulong busNo, ulong devNo,
need_clear = TRUE; need_clear = TRUE;
} }
if (p->pending_msg_hdr.id == CONTROLVM_INVALID) { if (p->pending_msg_hdr.id == CONTROLVM_INVALID)
LOGERR("device_responder no pending msg");
return; /* no controlvm response needed */ return; /* no controlvm response needed */
}
if (p->pending_msg_hdr.id != (u32) cmdId) { if (p->pending_msg_hdr.id != (u32) cmdId)
LOGERR("expected=%d, found=%d", cmdId, p->pending_msg_hdr.id);
return; return;
}
controlvm_respond(&p->pending_msg_hdr, response); controlvm_respond(&p->pending_msg_hdr, response);
p->pending_msg_hdr.id = CONTROLVM_INVALID; p->pending_msg_hdr.id = CONTROLVM_INVALID;
if (need_clear) if (need_clear)
...@@ -934,10 +907,9 @@ bus_epilog(u32 busNo, ...@@ -934,10 +907,9 @@ bus_epilog(u32 busNo,
struct visorchipset_bus_info *pBusInfo = findbus(&BusInfoList, busNo); struct visorchipset_bus_info *pBusInfo = findbus(&BusInfoList, busNo);
if (!pBusInfo) { if (!pBusInfo)
LOGERR("HUH? bad busNo=%d", busNo);
return; return;
}
if (needResponse) { if (needResponse) {
memcpy(&pBusInfo->pending_msg_hdr, msgHdr, memcpy(&pBusInfo->pending_msg_hdr, msgHdr,
sizeof(struct controlvm_message_header)); sizeof(struct controlvm_message_header));
...@@ -1007,10 +979,9 @@ device_epilog(u32 busNo, u32 devNo, struct spar_segment_state state, u32 cmd, ...@@ -1007,10 +979,9 @@ device_epilog(u32 busNo, u32 devNo, struct spar_segment_state state, u32 cmd,
NULL NULL
}; };
if (!pDevInfo) { if (!pDevInfo)
LOGERR("HUH? bad busNo=%d, devNo=%d", busNo, devNo);
return; return;
}
if (for_visorbus) if (for_visorbus)
notifiers = &BusDev_Server_Notifiers; notifiers = &BusDev_Server_Notifiers;
else else
...@@ -1100,8 +1071,6 @@ bus_create(struct controlvm_message *inmsg) ...@@ -1100,8 +1071,6 @@ bus_create(struct controlvm_message *inmsg)
pBusInfo = findbus(&BusInfoList, busNo); pBusInfo = findbus(&BusInfoList, busNo);
if (pBusInfo && (pBusInfo->state.created == 1)) { if (pBusInfo && (pBusInfo->state.created == 1)) {
LOGERR("CONTROLVM_BUS_CREATE Failed: bus %lu already exists",
busNo);
POSTCODE_LINUX_3(BUS_CREATE_FAILURE_PC, busNo, POSTCODE_LINUX_3(BUS_CREATE_FAILURE_PC, busNo,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
rc = -CONTROLVM_RESP_ERROR_ALREADY_DONE; rc = -CONTROLVM_RESP_ERROR_ALREADY_DONE;
...@@ -1152,13 +1121,10 @@ bus_destroy(struct controlvm_message *inmsg) ...@@ -1152,13 +1121,10 @@ bus_destroy(struct controlvm_message *inmsg)
pBusInfo = findbus(&BusInfoList, busNo); pBusInfo = findbus(&BusInfoList, busNo);
if (!pBusInfo) { if (!pBusInfo) {
LOGERR("CONTROLVM_BUS_DESTROY Failed: bus %lu invalid", busNo);
rc = -CONTROLVM_RESP_ERROR_BUS_INVALID; rc = -CONTROLVM_RESP_ERROR_BUS_INVALID;
goto Away; goto Away;
} }
if (pBusInfo->state.created == 0) { if (pBusInfo->state.created == 0) {
LOGERR("CONTROLVM_BUS_DESTROY Failed: bus %lu already destroyed",
busNo);
rc = -CONTROLVM_RESP_ERROR_ALREADY_DONE; rc = -CONTROLVM_RESP_ERROR_ALREADY_DONE;
goto Away; goto Away;
} }
...@@ -1182,16 +1148,12 @@ bus_configure(struct controlvm_message *inmsg, PARSER_CONTEXT *parser_ctx) ...@@ -1182,16 +1148,12 @@ bus_configure(struct controlvm_message *inmsg, PARSER_CONTEXT *parser_ctx)
pBusInfo = findbus(&BusInfoList, busNo); pBusInfo = findbus(&BusInfoList, busNo);
if (!pBusInfo) { if (!pBusInfo) {
LOGERR("CONTROLVM_BUS_CONFIGURE Failed: bus %lu invalid",
busNo);
POSTCODE_LINUX_3(BUS_CONFIGURE_FAILURE_PC, busNo, POSTCODE_LINUX_3(BUS_CONFIGURE_FAILURE_PC, busNo,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
rc = -CONTROLVM_RESP_ERROR_BUS_INVALID; rc = -CONTROLVM_RESP_ERROR_BUS_INVALID;
goto Away; goto Away;
} }
if (pBusInfo->state.created == 0) { if (pBusInfo->state.created == 0) {
LOGERR("CONTROLVM_BUS_CONFIGURE Failed: Invalid bus %lu - not created yet",
busNo);
POSTCODE_LINUX_3(BUS_CONFIGURE_FAILURE_PC, busNo, POSTCODE_LINUX_3(BUS_CONFIGURE_FAILURE_PC, busNo,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
rc = -CONTROLVM_RESP_ERROR_BUS_INVALID; rc = -CONTROLVM_RESP_ERROR_BUS_INVALID;
...@@ -1199,8 +1161,6 @@ bus_configure(struct controlvm_message *inmsg, PARSER_CONTEXT *parser_ctx) ...@@ -1199,8 +1161,6 @@ bus_configure(struct controlvm_message *inmsg, PARSER_CONTEXT *parser_ctx)
} }
/* TBD - add this check to other commands also... */ /* TBD - add this check to other commands also... */
if (pBusInfo->pending_msg_hdr.id != CONTROLVM_INVALID) { if (pBusInfo->pending_msg_hdr.id != CONTROLVM_INVALID) {
LOGERR("CONTROLVM_BUS_CONFIGURE Failed: bus %lu MsgId=%u outstanding",
busNo, (uint) pBusInfo->pending_msg_hdr.id);
POSTCODE_LINUX_3(BUS_CONFIGURE_FAILURE_PC, busNo, POSTCODE_LINUX_3(BUS_CONFIGURE_FAILURE_PC, busNo,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
rc = -CONTROLVM_RESP_ERROR_MESSAGE_ID_INVALID_FOR_CLIENT; rc = -CONTROLVM_RESP_ERROR_MESSAGE_ID_INVALID_FOR_CLIENT;
...@@ -1231,8 +1191,6 @@ my_device_create(struct controlvm_message *inmsg) ...@@ -1231,8 +1191,6 @@ my_device_create(struct controlvm_message *inmsg)
pDevInfo = finddevice(&DevInfoList, busNo, devNo); pDevInfo = finddevice(&DevInfoList, busNo, devNo);
if (pDevInfo && (pDevInfo->state.created == 1)) { if (pDevInfo && (pDevInfo->state.created == 1)) {
LOGERR("CONTROLVM_DEVICE_CREATE Failed: busNo=%lu, devNo=%lu already exists",
busNo, devNo);
POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC, devNo, busNo, POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC, devNo, busNo,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
rc = -CONTROLVM_RESP_ERROR_ALREADY_DONE; rc = -CONTROLVM_RESP_ERROR_ALREADY_DONE;
...@@ -1240,16 +1198,12 @@ my_device_create(struct controlvm_message *inmsg) ...@@ -1240,16 +1198,12 @@ my_device_create(struct controlvm_message *inmsg)
} }
pBusInfo = findbus(&BusInfoList, busNo); pBusInfo = findbus(&BusInfoList, busNo);
if (!pBusInfo) { if (!pBusInfo) {
LOGERR("CONTROLVM_DEVICE_CREATE Failed: Invalid bus %lu - out of range",
busNo);
POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC, devNo, busNo, POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC, devNo, busNo,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
rc = -CONTROLVM_RESP_ERROR_BUS_INVALID; rc = -CONTROLVM_RESP_ERROR_BUS_INVALID;
goto Away; goto Away;
} }
if (pBusInfo->state.created == 0) { if (pBusInfo->state.created == 0) {
LOGERR("CONTROLVM_DEVICE_CREATE Failed: Invalid bus %lu - not created yet",
busNo);
POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC, devNo, busNo, POSTCODE_LINUX_4(DEVICE_CREATE_FAILURE_PC, devNo, busNo,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
rc = -CONTROLVM_RESP_ERROR_BUS_INVALID; rc = -CONTROLVM_RESP_ERROR_BUS_INVALID;
...@@ -1307,16 +1261,12 @@ my_device_changestate(struct controlvm_message *inmsg) ...@@ -1307,16 +1261,12 @@ my_device_changestate(struct controlvm_message *inmsg)
pDevInfo = finddevice(&DevInfoList, busNo, devNo); pDevInfo = finddevice(&DevInfoList, busNo, devNo);
if (!pDevInfo) { if (!pDevInfo) {
LOGERR("CONTROLVM_DEVICE_CHANGESTATE Failed: busNo=%lu, devNo=%lu invalid (doesn't exist)",
busNo, devNo);
POSTCODE_LINUX_4(DEVICE_CHANGESTATE_FAILURE_PC, devNo, busNo, POSTCODE_LINUX_4(DEVICE_CHANGESTATE_FAILURE_PC, devNo, busNo,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
rc = -CONTROLVM_RESP_ERROR_DEVICE_INVALID; rc = -CONTROLVM_RESP_ERROR_DEVICE_INVALID;
goto Away; goto Away;
} }
if (pDevInfo->state.created == 0) { if (pDevInfo->state.created == 0) {
LOGERR("CONTROLVM_DEVICE_CHANGESTATE Failed: busNo=%lu, devNo=%lu invalid (not created)",
busNo, devNo);
POSTCODE_LINUX_4(DEVICE_CHANGESTATE_FAILURE_PC, devNo, busNo, POSTCODE_LINUX_4(DEVICE_CHANGESTATE_FAILURE_PC, devNo, busNo,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
rc = -CONTROLVM_RESP_ERROR_DEVICE_INVALID; rc = -CONTROLVM_RESP_ERROR_DEVICE_INVALID;
...@@ -1341,14 +1291,10 @@ my_device_destroy(struct controlvm_message *inmsg) ...@@ -1341,14 +1291,10 @@ my_device_destroy(struct controlvm_message *inmsg)
pDevInfo = finddevice(&DevInfoList, busNo, devNo); pDevInfo = finddevice(&DevInfoList, busNo, devNo);
if (!pDevInfo) { if (!pDevInfo) {
LOGERR("CONTROLVM_DEVICE_DESTROY Failed: busNo=%lu, devNo=%lu invalid",
busNo, devNo);
rc = -CONTROLVM_RESP_ERROR_DEVICE_INVALID; rc = -CONTROLVM_RESP_ERROR_DEVICE_INVALID;
goto Away; goto Away;
} }
if (pDevInfo->state.created == 0) { if (pDevInfo->state.created == 0) {
LOGERR("CONTROLVM_DEVICE_DESTROY Failed: busNo=%lu, devNo=%lu already destroyed",
busNo, devNo);
rc = -CONTROLVM_RESP_ERROR_ALREADY_DONE; rc = -CONTROLVM_RESP_ERROR_ALREADY_DONE;
} }
...@@ -1375,22 +1321,16 @@ initialize_controlvm_payload_info(HOSTADDRESS phys_addr, u64 offset, u32 bytes, ...@@ -1375,22 +1321,16 @@ initialize_controlvm_payload_info(HOSTADDRESS phys_addr, u64 offset, u32 bytes,
int rc = CONTROLVM_RESP_SUCCESS; int rc = CONTROLVM_RESP_SUCCESS;
if (info == NULL) { if (info == NULL) {
LOGERR("HUH ? CONTROLVM_PAYLOAD_INIT Failed : Programmer check at %s:%d",
__FILE__, __LINE__);
rc = -CONTROLVM_RESP_ERROR_PAYLOAD_INVALID; rc = -CONTROLVM_RESP_ERROR_PAYLOAD_INVALID;
goto Away; goto Away;
} }
memset(info, 0, sizeof(struct controlvm_payload_info)); memset(info, 0, sizeof(struct controlvm_payload_info));
if ((offset == 0) || (bytes == 0)) { if ((offset == 0) || (bytes == 0)) {
LOGERR("CONTROLVM_PAYLOAD_INIT Failed: request_payload_offset=%llu request_payload_bytes=%llu!",
(u64) offset, (u64) bytes);
rc = -CONTROLVM_RESP_ERROR_PAYLOAD_INVALID; rc = -CONTROLVM_RESP_ERROR_PAYLOAD_INVALID;
goto Away; goto Away;
} }
payload = ioremap_cache(phys_addr + offset, bytes); payload = ioremap_cache(phys_addr + offset, bytes);
if (payload == NULL) { if (payload == NULL) {
LOGERR("CONTROLVM_PAYLOAD_INIT Failed: ioremap_cache %llu for %llu bytes failed",
(u64) offset, (u64) bytes);
rc = -CONTROLVM_RESP_ERROR_IOREMAP_FAILED; rc = -CONTROLVM_RESP_ERROR_IOREMAP_FAILED;
goto Away; goto Away;
} }
...@@ -1430,7 +1370,6 @@ initialize_controlvm_payload(void) ...@@ -1430,7 +1370,6 @@ initialize_controlvm_payload(void)
offsetof(struct spar_controlvm_channel_protocol, offsetof(struct spar_controlvm_channel_protocol,
request_payload_offset), request_payload_offset),
&payloadOffset, sizeof(payloadOffset)) < 0) { &payloadOffset, sizeof(payloadOffset)) < 0) {
LOGERR("CONTROLVM_PAYLOAD_INIT Failed to read controlvm channel!");
POSTCODE_LINUX_2(CONTROLVM_INIT_FAILURE_PC, POSTCODE_LINUX_2(CONTROLVM_INIT_FAILURE_PC,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
return; return;
...@@ -1439,7 +1378,6 @@ initialize_controlvm_payload(void) ...@@ -1439,7 +1378,6 @@ initialize_controlvm_payload(void)
offsetof(struct spar_controlvm_channel_protocol, offsetof(struct spar_controlvm_channel_protocol,
request_payload_bytes), request_payload_bytes),
&payloadBytes, sizeof(payloadBytes)) < 0) { &payloadBytes, sizeof(payloadBytes)) < 0) {
LOGERR("CONTROLVM_PAYLOAD_INIT Failed to read controlvm channel!");
POSTCODE_LINUX_2(CONTROLVM_INIT_FAILURE_PC, POSTCODE_LINUX_2(CONTROLVM_INIT_FAILURE_PC,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
return; return;
...@@ -1532,11 +1470,8 @@ read_controlvm_event(struct controlvm_message *msg) ...@@ -1532,11 +1470,8 @@ read_controlvm_event(struct controlvm_message *msg)
if (visorchannel_signalremove(ControlVm_channel, if (visorchannel_signalremove(ControlVm_channel,
CONTROLVM_QUEUE_EVENT, msg)) { CONTROLVM_QUEUE_EVENT, msg)) {
/* got a message */ /* got a message */
if (msg->hdr.flags.test_message == 1) { if (msg->hdr.flags.test_message == 1)
LOGERR("ignoring bad CONTROLVM_QUEUE_EVENT msg with controlvm_msg_id=0x%x because Flags.testMessage is nonsensical (=1)",
msg->hdr.id);
return FALSE; return FALSE;
}
return TRUE; return TRUE;
} }
return FALSE; return FALSE;
...@@ -1714,10 +1649,8 @@ parahotplug_process_message(struct controlvm_message *inmsg) ...@@ -1714,10 +1649,8 @@ parahotplug_process_message(struct controlvm_message *inmsg)
req = parahotplug_request_create(inmsg); req = parahotplug_request_create(inmsg);
if (req == NULL) { if (req == NULL)
LOGERR("parahotplug_process_message: couldn't allocate request");
return; return;
}
if (inmsg->cmd.device_change_state.state.active) { if (inmsg->cmd.device_change_state.state.active) {
/* For enable messages, just respond with success /* For enable messages, just respond with success
...@@ -1771,10 +1704,8 @@ handle_command(struct controlvm_message inmsg, HOSTADDRESS channel_addr) ...@@ -1771,10 +1704,8 @@ handle_command(struct controlvm_message inmsg, HOSTADDRESS channel_addr)
/* create parsing context if necessary */ /* create parsing context if necessary */
isLocalAddr = (inmsg.hdr.flags.test_message == 1); isLocalAddr = (inmsg.hdr.flags.test_message == 1);
if (channel_addr == 0) { if (channel_addr == 0)
LOGERR("HUH? channel_addr is 0!");
return TRUE; return TRUE;
}
parametersAddr = channel_addr + inmsg.hdr.payload_vm_offset; parametersAddr = channel_addr + inmsg.hdr.payload_vm_offset;
parametersBytes = inmsg.hdr.payload_bytes; parametersBytes = inmsg.hdr.payload_bytes;
...@@ -1856,7 +1787,6 @@ handle_command(struct controlvm_message inmsg, HOSTADDRESS channel_addr) ...@@ -1856,7 +1787,6 @@ handle_command(struct controlvm_message inmsg, HOSTADDRESS channel_addr)
chipset_notready(&inmsg.hdr); chipset_notready(&inmsg.hdr);
break; break;
default: default:
LOGERR("unrecognized controlvm cmd=%d", (int) inmsg.hdr.id);
if (inmsg.hdr.flags.response_expected) if (inmsg.hdr.flags.response_expected)
controlvm_respond(&inmsg.hdr, controlvm_respond(&inmsg.hdr,
-CONTROLVM_RESP_ERROR_MESSAGE_ID_UNKNOWN); -CONTROLVM_RESP_ERROR_MESSAGE_ID_UNKNOWN);
...@@ -1875,11 +1805,9 @@ static HOSTADDRESS controlvm_get_channel_address(void) ...@@ -1875,11 +1805,9 @@ static HOSTADDRESS controlvm_get_channel_address(void)
u64 addr = 0; u64 addr = 0;
u32 size = 0; u32 size = 0;
if (!VMCALL_SUCCESSFUL(issue_vmcall_io_controlvm_addr(&addr, &size))) { if (!VMCALL_SUCCESSFUL(issue_vmcall_io_controlvm_addr(&addr, &size)))
ERRDRV("%s - vmcall to determine controlvm channel addr failed",
__func__);
return 0; return 0;
}
return addr; return addr;
} }
...@@ -1922,12 +1850,6 @@ controlvm_periodic_work(struct work_struct *work) ...@@ -1922,12 +1850,6 @@ controlvm_periodic_work(struct work_struct *work)
while (visorchannel_signalremove(ControlVm_channel, while (visorchannel_signalremove(ControlVm_channel,
CONTROLVM_QUEUE_RESPONSE, CONTROLVM_QUEUE_RESPONSE,
&inmsg)) { &inmsg)) {
if (inmsg.hdr.payload_max_bytes != 0) {
LOGERR("Payload of size %lu returned @%lu with unexpected message id %d.",
(ulong) inmsg.hdr.payload_max_bytes,
(ulong) inmsg.hdr.payload_vm_offset,
inmsg.hdr.id);
}
} }
if (!gotACommand) { if (!gotACommand) {
if (ControlVm_Pending_Msg_Valid) { if (ControlVm_Pending_Msg_Valid) {
...@@ -2020,15 +1942,12 @@ setup_crash_devices_work_queue(struct work_struct *work) ...@@ -2020,15 +1942,12 @@ setup_crash_devices_work_queue(struct work_struct *work)
offsetof(struct spar_controlvm_channel_protocol, offsetof(struct spar_controlvm_channel_protocol,
saved_crash_message_count), saved_crash_message_count),
&localSavedCrashMsgCount, sizeof(u16)) < 0) { &localSavedCrashMsgCount, sizeof(u16)) < 0) {
LOGERR("failed to get Saved Message Count");
POSTCODE_LINUX_2(CRASH_DEV_CTRL_RD_FAILURE_PC, POSTCODE_LINUX_2(CRASH_DEV_CTRL_RD_FAILURE_PC,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
return; return;
} }
if (localSavedCrashMsgCount != CONTROLVM_CRASHMSG_MAX) { if (localSavedCrashMsgCount != CONTROLVM_CRASHMSG_MAX) {
LOGERR("Saved Message Count incorrect %d",
localSavedCrashMsgCount);
POSTCODE_LINUX_3(CRASH_DEV_COUNT_FAILURE_PC, POSTCODE_LINUX_3(CRASH_DEV_COUNT_FAILURE_PC,
localSavedCrashMsgCount, localSavedCrashMsgCount,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
...@@ -2040,7 +1959,6 @@ setup_crash_devices_work_queue(struct work_struct *work) ...@@ -2040,7 +1959,6 @@ setup_crash_devices_work_queue(struct work_struct *work)
offsetof(struct spar_controlvm_channel_protocol, offsetof(struct spar_controlvm_channel_protocol,
saved_crash_message_offset), saved_crash_message_offset),
&localSavedCrashMsgOffset, sizeof(u32)) < 0) { &localSavedCrashMsgOffset, sizeof(u32)) < 0) {
LOGERR("failed to get Saved Message Offset");
POSTCODE_LINUX_2(CRASH_DEV_CTRL_RD_FAILURE_PC, POSTCODE_LINUX_2(CRASH_DEV_CTRL_RD_FAILURE_PC,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
return; return;
...@@ -2051,7 +1969,6 @@ setup_crash_devices_work_queue(struct work_struct *work) ...@@ -2051,7 +1969,6 @@ setup_crash_devices_work_queue(struct work_struct *work)
localSavedCrashMsgOffset, localSavedCrashMsgOffset,
&localCrashCreateBusMsg, &localCrashCreateBusMsg,
sizeof(struct controlvm_message)) < 0) { sizeof(struct controlvm_message)) < 0) {
LOGERR("CRASH_DEV_RD_BUS_FAIULRE: Failed to read CrashCreateBusMsg!");
POSTCODE_LINUX_2(CRASH_DEV_RD_BUS_FAIULRE_PC, POSTCODE_LINUX_2(CRASH_DEV_RD_BUS_FAIULRE_PC,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
return; return;
...@@ -2063,7 +1980,6 @@ setup_crash_devices_work_queue(struct work_struct *work) ...@@ -2063,7 +1980,6 @@ setup_crash_devices_work_queue(struct work_struct *work)
sizeof(struct controlvm_message), sizeof(struct controlvm_message),
&localCrashCreateDevMsg, &localCrashCreateDevMsg,
sizeof(struct controlvm_message)) < 0) { sizeof(struct controlvm_message)) < 0) {
LOGERR("CRASH_DEV_RD_DEV_FAIULRE: Failed to read CrashCreateDevMsg!");
POSTCODE_LINUX_2(CRASH_DEV_RD_DEV_FAIULRE_PC, POSTCODE_LINUX_2(CRASH_DEV_RD_DEV_FAIULRE_PC,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
return; return;
...@@ -2073,7 +1989,6 @@ setup_crash_devices_work_queue(struct work_struct *work) ...@@ -2073,7 +1989,6 @@ setup_crash_devices_work_queue(struct work_struct *work)
if (localCrashCreateBusMsg.cmd.create_bus.channel_addr != 0) if (localCrashCreateBusMsg.cmd.create_bus.channel_addr != 0)
bus_create(&localCrashCreateBusMsg); bus_create(&localCrashCreateBusMsg);
else { else {
LOGERR("CrashCreateBusMsg is null, no dump will be taken");
POSTCODE_LINUX_2(CRASH_DEV_BUS_NULL_FAILURE_PC, POSTCODE_LINUX_2(CRASH_DEV_BUS_NULL_FAILURE_PC,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
return; return;
...@@ -2083,7 +1998,6 @@ setup_crash_devices_work_queue(struct work_struct *work) ...@@ -2083,7 +1998,6 @@ setup_crash_devices_work_queue(struct work_struct *work)
if (localCrashCreateDevMsg.cmd.create_device.channel_addr != 0) if (localCrashCreateDevMsg.cmd.create_device.channel_addr != 0)
my_device_create(&localCrashCreateDevMsg); my_device_create(&localCrashCreateDevMsg);
else { else {
LOGERR("CrashCreateDevMsg is null, no dump will be taken");
POSTCODE_LINUX_2(CRASH_DEV_DEV_NULL_FAILURE_PC, POSTCODE_LINUX_2(CRASH_DEV_DEV_NULL_FAILURE_PC,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
return; return;
...@@ -2146,10 +2060,8 @@ visorchipset_get_bus_info(ulong bus_no, struct visorchipset_bus_info *bus_info) ...@@ -2146,10 +2060,8 @@ visorchipset_get_bus_info(ulong bus_no, struct visorchipset_bus_info *bus_info)
{ {
void *p = findbus(&BusInfoList, bus_no); void *p = findbus(&BusInfoList, bus_no);
if (!p) { if (!p)
LOGERR("(%lu) failed", bus_no);
return FALSE; return FALSE;
}
memcpy(bus_info, p, sizeof(struct visorchipset_bus_info)); memcpy(bus_info, p, sizeof(struct visorchipset_bus_info));
return TRUE; return TRUE;
} }
...@@ -2160,10 +2072,8 @@ visorchipset_set_bus_context(ulong bus_no, void *context) ...@@ -2160,10 +2072,8 @@ visorchipset_set_bus_context(ulong bus_no, void *context)
{ {
struct visorchipset_bus_info *p = findbus(&BusInfoList, bus_no); struct visorchipset_bus_info *p = findbus(&BusInfoList, bus_no);
if (!p) { if (!p)
LOGERR("(%lu) failed", bus_no);
return FALSE; return FALSE;
}
p->bus_driver_context = context; p->bus_driver_context = context;
return TRUE; return TRUE;
} }
...@@ -2175,10 +2085,8 @@ visorchipset_get_device_info(ulong bus_no, ulong dev_no, ...@@ -2175,10 +2085,8 @@ visorchipset_get_device_info(ulong bus_no, ulong dev_no,
{ {
void *p = finddevice(&DevInfoList, bus_no, dev_no); void *p = finddevice(&DevInfoList, bus_no, dev_no);
if (!p) { if (!p)
LOGERR("(%lu,%lu) failed", bus_no, dev_no);
return FALSE; return FALSE;
}
memcpy(dev_info, p, sizeof(struct visorchipset_device_info)); memcpy(dev_info, p, sizeof(struct visorchipset_device_info));
return TRUE; return TRUE;
} }
...@@ -2190,10 +2098,8 @@ visorchipset_set_device_context(ulong bus_no, ulong dev_no, void *context) ...@@ -2190,10 +2098,8 @@ visorchipset_set_device_context(ulong bus_no, ulong dev_no, void *context)
struct visorchipset_device_info *p = struct visorchipset_device_info *p =
finddevice(&DevInfoList, bus_no, dev_no); finddevice(&DevInfoList, bus_no, dev_no);
if (!p) { if (!p)
LOGERR("(%lu,%lu) failed", bus_no, dev_no);
return FALSE; return FALSE;
}
p->bus_driver_context = context; p->bus_driver_context = context;
return TRUE; return TRUE;
} }
...@@ -2221,10 +2127,9 @@ visorchipset_cache_alloc(struct kmem_cache *pool, BOOL ok_to_block, ...@@ -2221,10 +2127,9 @@ visorchipset_cache_alloc(struct kmem_cache *pool, BOOL ok_to_block,
*/ */
gfp |= __GFP_NORETRY; gfp |= __GFP_NORETRY;
p = kmem_cache_alloc(pool, gfp); p = kmem_cache_alloc(pool, gfp);
if (!p) { if (!p)
LOGERR("kmem_cache_alloc failed early @%s:%d\n", fn, ln);
return NULL; return NULL;
}
atomic_inc(&Visorchipset_cache_buffers_in_use); atomic_inc(&Visorchipset_cache_buffers_in_use);
return p; return p;
} }
...@@ -2234,10 +2139,9 @@ visorchipset_cache_alloc(struct kmem_cache *pool, BOOL ok_to_block, ...@@ -2234,10 +2139,9 @@ visorchipset_cache_alloc(struct kmem_cache *pool, BOOL ok_to_block,
void void
visorchipset_cache_free(struct kmem_cache *pool, void *p, char *fn, int ln) visorchipset_cache_free(struct kmem_cache *pool, void *p, char *fn, int ln)
{ {
if (!p) { if (!p)
LOGERR("NULL pointer @%s:%d\n", fn, ln);
return; return;
}
atomic_dec(&Visorchipset_cache_buffers_in_use); atomic_dec(&Visorchipset_cache_buffers_in_use);
kmem_cache_free(pool, p); kmem_cache_free(pool, p);
} }
...@@ -2308,8 +2212,6 @@ visorchipset_init(void) ...@@ -2308,8 +2212,6 @@ visorchipset_init(void)
atomic_set(&LiveDump_info.buffers_in_use, 0); atomic_set(&LiveDump_info.buffers_in_use, 0);
if (visorchipset_testvnic) { if (visorchipset_testvnic) {
ERRDRV("testvnic option no longer supported: (status = %d)\n",
x);
POSTCODE_LINUX_3(CHIPSET_INIT_FAILURE_PC, x, DIAG_SEVERITY_ERR); POSTCODE_LINUX_3(CHIPSET_INIT_FAILURE_PC, x, DIAG_SEVERITY_ERR);
rc = x; rc = x;
goto Away; goto Away;
...@@ -2326,20 +2228,17 @@ visorchipset_init(void) ...@@ -2326,20 +2228,17 @@ visorchipset_init(void)
visorchannel_get_header(ControlVm_channel))) { visorchannel_get_header(ControlVm_channel))) {
initialize_controlvm_payload(); initialize_controlvm_payload();
} else { } else {
LOGERR("controlvm channel is invalid");
visorchannel_destroy(ControlVm_channel); visorchannel_destroy(ControlVm_channel);
ControlVm_channel = NULL; ControlVm_channel = NULL;
return -ENODEV; return -ENODEV;
} }
} else { } else {
LOGERR("no controlvm channel discovered");
return -ENODEV; return -ENODEV;
} }
MajorDev = MKDEV(visorchipset_major, 0); MajorDev = MKDEV(visorchipset_major, 0);
rc = visorchipset_file_init(MajorDev, &ControlVm_channel); rc = visorchipset_file_init(MajorDev, &ControlVm_channel);
if (rc < 0) { if (rc < 0) {
ERRDRV("visorchipset_file_init(MajorDev, &ControlVm_channel): error (status=%d)\n", rc);
POSTCODE_LINUX_2(CHIPSET_INIT_FAILURE_PC, DIAG_SEVERITY_ERR); POSTCODE_LINUX_2(CHIPSET_INIT_FAILURE_PC, DIAG_SEVERITY_ERR);
goto Away; goto Away;
} }
...@@ -2355,7 +2254,6 @@ visorchipset_init(void) ...@@ -2355,7 +2254,6 @@ visorchipset_init(void)
sizeof(struct putfile_buffer_entry), sizeof(struct putfile_buffer_entry),
0, SLAB_HWCACHE_ALIGN, NULL); 0, SLAB_HWCACHE_ALIGN, NULL);
if (!Putfile_buffer_list_pool) { if (!Putfile_buffer_list_pool) {
ERRDRV("failed to alloc Putfile_buffer_list_pool: (status=-1)\n");
POSTCODE_LINUX_2(CHIPSET_INIT_FAILURE_PC, DIAG_SEVERITY_ERR); POSTCODE_LINUX_2(CHIPSET_INIT_FAILURE_PC, DIAG_SEVERITY_ERR);
rc = -1; rc = -1;
goto Away; goto Away;
...@@ -2372,8 +2270,6 @@ visorchipset_init(void) ...@@ -2372,8 +2270,6 @@ visorchipset_init(void)
create_singlethread_workqueue("visorchipset_controlvm"); create_singlethread_workqueue("visorchipset_controlvm");
if (Periodic_controlvm_workqueue == NULL) { if (Periodic_controlvm_workqueue == NULL) {
ERRDRV("cannot create controlvm workqueue: (status=%d)\n",
-ENOMEM);
POSTCODE_LINUX_2(CREATE_WORKQUEUE_FAILED_PC, POSTCODE_LINUX_2(CREATE_WORKQUEUE_FAILED_PC,
DIAG_SEVERITY_ERR); DIAG_SEVERITY_ERR);
rc = -ENOMEM; rc = -ENOMEM;
...@@ -2384,7 +2280,6 @@ visorchipset_init(void) ...@@ -2384,7 +2280,6 @@ visorchipset_init(void)
rc = queue_delayed_work(Periodic_controlvm_workqueue, rc = queue_delayed_work(Periodic_controlvm_workqueue,
&Periodic_controlvm_work, Poll_jiffies); &Periodic_controlvm_work, Poll_jiffies);
if (rc < 0) { if (rc < 0) {
ERRDRV("queue_delayed_work(Periodic_controlvm_workqueue, &Periodic_controlvm_work, Poll_jiffies): error (status=%d)\n", rc);
POSTCODE_LINUX_2(QUEUE_DELAYED_WORK_PC, POSTCODE_LINUX_2(QUEUE_DELAYED_WORK_PC,
DIAG_SEVERITY_ERR); DIAG_SEVERITY_ERR);
goto Away; goto Away;
...@@ -2394,7 +2289,6 @@ visorchipset_init(void) ...@@ -2394,7 +2289,6 @@ visorchipset_init(void)
Visorchipset_platform_device.dev.devt = MajorDev; Visorchipset_platform_device.dev.devt = MajorDev;
if (platform_device_register(&Visorchipset_platform_device) < 0) { if (platform_device_register(&Visorchipset_platform_device) < 0) {
ERRDRV("platform_device_register(visorchipset) failed: (status=-1)\n");
POSTCODE_LINUX_2(DEVICE_REGISTER_FAILURE_PC, DIAG_SEVERITY_ERR); POSTCODE_LINUX_2(DEVICE_REGISTER_FAILURE_PC, DIAG_SEVERITY_ERR);
rc = -1; rc = -1;
goto Away; goto Away;
...@@ -2403,7 +2297,6 @@ visorchipset_init(void) ...@@ -2403,7 +2297,6 @@ visorchipset_init(void)
rc = 0; rc = 0;
Away: Away:
if (rc) { if (rc) {
LOGERR("visorchipset_init failed");
POSTCODE_LINUX_3(CHIPSET_INIT_FAILURE_PC, rc, POSTCODE_LINUX_3(CHIPSET_INIT_FAILURE_PC, rc,
POSTCODE_SEVERITY_ERR); POSTCODE_SEVERITY_ERR);
} }
......
...@@ -39,11 +39,8 @@ struct charqueue *visor_charqueue_create(ulong nslots) ...@@ -39,11 +39,8 @@ struct charqueue *visor_charqueue_create(ulong nslots)
struct charqueue *cq; struct charqueue *cq;
cq = kmalloc(alloc_size, GFP_KERNEL|__GFP_NORETRY); cq = kmalloc(alloc_size, GFP_KERNEL|__GFP_NORETRY);
if (cq == NULL) { if (cq == NULL)
ERRDRV("visor_charqueue_create allocation failed (alloc_size=%d)",
alloc_size);
return NULL; return NULL;
}
cq->alloc_size = alloc_size; cq->alloc_size = alloc_size;
cq->nslots = nslots; cq->nslots = nslots;
cq->head = 0; cq->head = 0;
......
...@@ -61,9 +61,6 @@ static struct proc_dir_entry * ...@@ -61,9 +61,6 @@ static struct proc_dir_entry *
createProcDir(char *name, struct proc_dir_entry *parent) createProcDir(char *name, struct proc_dir_entry *parent)
{ {
struct proc_dir_entry *p = proc_mkdir_mode(name, S_IFDIR, parent); struct proc_dir_entry *p = proc_mkdir_mode(name, S_IFDIR, parent);
if (p == NULL)
ERRDRV("failed to create /proc directory %s", name);
return p; return p;
} }
...@@ -114,8 +111,6 @@ void visor_easyproc_InitDriver(struct easyproc_driver_info *pdriver, ...@@ -114,8 +111,6 @@ void visor_easyproc_InitDriver(struct easyproc_driver_info *pdriver,
{ {
memset(pdriver, 0, sizeof(struct easyproc_driver_info)); memset(pdriver, 0, sizeof(struct easyproc_driver_info));
pdriver->ProcId = procId; pdriver->ProcId = procId;
if (pdriver->ProcId == NULL)
ERRDRV("ProcId cannot be NULL (trouble ahead)!");
pdriver->Show_driver_info = show_driver_info; pdriver->Show_driver_info = show_driver_info;
pdriver->Show_device_info = show_device_info; pdriver->Show_device_info = show_device_info;
if (pdriver->ProcDir == NULL) if (pdriver->ProcDir == NULL)
...@@ -132,9 +127,6 @@ void visor_easyproc_InitDriver(struct easyproc_driver_info *pdriver, ...@@ -132,9 +127,6 @@ void visor_easyproc_InitDriver(struct easyproc_driver_info *pdriver,
proc_create_data("diag", 0, proc_create_data("diag", 0,
pdriver->ProcDriverDir, pdriver->ProcDriverDir,
&proc_fops_driver, pdriver); &proc_fops_driver, pdriver);
if (pdriver->ProcDriverDiagFile == NULL)
ERRDRV("failed to register /proc/%s/driver/diag entry",
pdriver->ProcId);
} }
} }
EXPORT_SYMBOL_GPL(visor_easyproc_InitDriver); EXPORT_SYMBOL_GPL(visor_easyproc_InitDriver);
...@@ -209,10 +201,6 @@ void visor_easyproc_InitDevice(struct easyproc_driver_info *pdriver, ...@@ -209,10 +201,6 @@ void visor_easyproc_InitDevice(struct easyproc_driver_info *pdriver,
p->procDevicexDiagFile = p->procDevicexDiagFile =
proc_create_data("diag", 0, p->procDevicexDir, proc_create_data("diag", 0, p->procDevicexDir,
&proc_fops_device, p); &proc_fops_device, p);
if (p->procDevicexDiagFile == NULL)
ERRDEVX(devno, "failed to register /proc/%s/device/%d/diag entry",
pdriver->ProcId, devno
);
} }
memset(&(p->device_property_info[0]), 0, memset(&(p->device_property_info[0]), 0,
sizeof(p->device_property_info)); sizeof(p->device_property_info));
...@@ -229,34 +217,26 @@ void visor_easyproc_CreateDeviceProperty(struct easyproc_device_info *p, ...@@ -229,34 +217,26 @@ void visor_easyproc_CreateDeviceProperty(struct easyproc_device_info *p,
size_t i; size_t i;
struct easyproc_device_property_info *px = NULL; struct easyproc_device_property_info *px = NULL;
if (p->procDevicexDir == NULL) { if (p->procDevicexDir == NULL)
ERRDRV("state error");
return; return;
}
for (i = 0; i < ARRAY_SIZE(p->device_property_info); i++) { for (i = 0; i < ARRAY_SIZE(p->device_property_info); i++) {
if (p->device_property_info[i].procEntry == NULL) { if (p->device_property_info[i].procEntry == NULL) {
px = &(p->device_property_info[i]); px = &(p->device_property_info[i]);
break; break;
} }
} }
if (!px) { if (!px)
ERRDEVX(p->devno, "too many device properties");
return; return;
}
px->devdata = p->devdata; px->devdata = p->devdata;
px->pdriver = p->pdriver; px->pdriver = p->pdriver;
px->procEntry = proc_create_data(property_name, 0, p->procDevicexDir, px->procEntry = proc_create_data(property_name, 0, p->procDevicexDir,
&proc_fops_device_property, px); &proc_fops_device_property, px);
if (strlen(property_name)+1 > sizeof(px->property_name)) { if (strlen(property_name)+1 > sizeof(px->property_name)) {
ERRDEVX(p->devno, "device property name %s too long",
property_name);
return; return;
} }
strcpy(px->property_name, property_name); strcpy(px->property_name, property_name);
if (px->procEntry == NULL) { if (px->procEntry == NULL) {
ERRDEVX(p->devno,
"failed to register /proc/%s/device/%d/%s entry",
p->pdriver->ProcId, p->devno, property_name);
return; return;
} }
px->show_device_property_info = show_property_info; px->show_device_property_info = show_property_info;
......
...@@ -44,10 +44,9 @@ visor_memregion_create(HOSTADDRESS physaddr, ulong nbytes) ...@@ -44,10 +44,9 @@ visor_memregion_create(HOSTADDRESS physaddr, ulong nbytes)
struct memregion *memregion; struct memregion *memregion;
memregion = kzalloc(sizeof(*memregion), GFP_KERNEL | __GFP_NORETRY); memregion = kzalloc(sizeof(*memregion), GFP_KERNEL | __GFP_NORETRY);
if (memregion == NULL) { if (memregion == NULL)
ERRDRV("visor_memregion_create allocation failed");
return NULL; return NULL;
}
memregion->physaddr = physaddr; memregion->physaddr = physaddr;
memregion->nbytes = nbytes; memregion->nbytes = nbytes;
memregion->overlapped = FALSE; memregion->overlapped = FALSE;
...@@ -71,20 +70,16 @@ visor_memregion_create_overlapped(struct memregion *parent, ulong offset, ...@@ -71,20 +70,16 @@ visor_memregion_create_overlapped(struct memregion *parent, ulong offset,
{ {
struct memregion *memregion = NULL; struct memregion *memregion = NULL;
if (parent == NULL) { if (parent == NULL)
ERRDRV("%s parent is NULL", __func__);
return NULL; return NULL;
}
if (parent->mapped == NULL) { if (parent->mapped == NULL)
ERRDRV("%s parent is not mapped!", __func__);
return NULL; return NULL;
}
if ((offset >= parent->nbytes) || if ((offset >= parent->nbytes) ||
((offset + nbytes) >= parent->nbytes)) { ((offset + nbytes) >= parent->nbytes))
ERRDRV("%s range (%lu,%lu) out of parent range",
__func__, offset, nbytes);
return NULL; return NULL;
}
memregion = kzalloc(sizeof(*memregion), GFP_KERNEL|__GFP_NORETRY); memregion = kzalloc(sizeof(*memregion), GFP_KERNEL|__GFP_NORETRY);
if (memregion == NULL) if (memregion == NULL)
return NULL; return NULL;
...@@ -105,17 +100,11 @@ mapit(struct memregion *memregion) ...@@ -105,17 +100,11 @@ mapit(struct memregion *memregion)
ulong nbytes = memregion->nbytes; ulong nbytes = memregion->nbytes;
memregion->requested = FALSE; memregion->requested = FALSE;
if (!request_mem_region(physaddr, nbytes, MYDRVNAME)) if (request_mem_region(physaddr, nbytes, MYDRVNAME))
ERRDRV("cannot reserve channel memory @0x%lx for 0x%lx-- no big deal",
physaddr, nbytes);
else
memregion->requested = TRUE; memregion->requested = TRUE;
memregion->mapped = ioremap_cache(physaddr, nbytes); memregion->mapped = ioremap_cache(physaddr, nbytes);
if (memregion->mapped == NULL) { if (!memregion->mapped)
ERRDRV("cannot ioremap_cache channel memory @0x%lx for 0x%lx",
physaddr, nbytes);
return FALSE; return FALSE;
}
return TRUE; return TRUE;
} }
...@@ -179,10 +168,9 @@ memregion_readwrite(BOOL is_write, ...@@ -179,10 +168,9 @@ memregion_readwrite(BOOL is_write,
struct memregion *memregion, ulong offset, struct memregion *memregion, ulong offset,
void *local, ulong nbytes) void *local, ulong nbytes)
{ {
if (offset + nbytes > memregion->nbytes) { if (offset + nbytes > memregion->nbytes)
ERRDRV("memregion_readwrite offset out of range!!");
return -EIO; return -EIO;
}
if (is_write) if (is_write)
memcpy_toio(memregion->mapped + offset, local, nbytes); memcpy_toio(memregion->mapped + offset, local, nbytes);
else else
......
...@@ -90,7 +90,6 @@ BOOL visor_periodic_work_nextperiod(struct periodic_work *pw) ...@@ -90,7 +90,6 @@ BOOL visor_periodic_work_nextperiod(struct periodic_work *pw)
goto unlock; goto unlock;
} else if (queue_delayed_work(pw->workqueue, &pw->work, } else if (queue_delayed_work(pw->workqueue, &pw->work,
pw->jiffy_interval) < 0) { pw->jiffy_interval) < 0) {
ERRDEV(pw->devnam, "queue_delayed_work failed!");
pw->is_scheduled = FALSE; pw->is_scheduled = FALSE;
rc = FALSE; rc = FALSE;
goto unlock; goto unlock;
...@@ -116,15 +115,12 @@ BOOL visor_periodic_work_start(struct periodic_work *pw) ...@@ -116,15 +115,12 @@ BOOL visor_periodic_work_start(struct periodic_work *pw)
goto unlock; goto unlock;
} }
if (pw->want_to_stop) { if (pw->want_to_stop) {
ERRDEV(pw->devnam,
"dev_start_periodic_work failed!");
rc = FALSE; rc = FALSE;
goto unlock; goto unlock;
} }
INIT_DELAYED_WORK(&pw->work, &periodic_work_func); INIT_DELAYED_WORK(&pw->work, &periodic_work_func);
if (queue_delayed_work(pw->workqueue, &pw->work, if (queue_delayed_work(pw->workqueue, &pw->work,
pw->jiffy_interval) < 0) { pw->jiffy_interval) < 0) {
ERRDEV(pw->devnam, "%s queue_delayed_work failed!", __func__);
rc = FALSE; rc = FALSE;
goto unlock; goto unlock;
} }
......
...@@ -96,8 +96,6 @@ createProcDir(const char *name, struct proc_dir_entry *parent) ...@@ -96,8 +96,6 @@ createProcDir(const char *name, struct proc_dir_entry *parent)
{ {
struct proc_dir_entry *p = proc_mkdir_mode(name, S_IFDIR, parent); struct proc_dir_entry *p = proc_mkdir_mode(name, S_IFDIR, parent);
if (p == NULL)
ERRDRV("failed to create /proc directory %s", name);
return p; return p;
} }
...@@ -107,8 +105,6 @@ createProcFile(const char *name, struct proc_dir_entry *parent, ...@@ -107,8 +105,6 @@ createProcFile(const char *name, struct proc_dir_entry *parent,
{ {
struct proc_dir_entry *p = proc_create_data(name, 0, parent, struct proc_dir_entry *p = proc_create_data(name, 0, parent,
fops, data); fops, data);
if (p == NULL)
ERRDRV("failed to create /proc file %s", name);
return p; return p;
} }
...@@ -137,17 +133,16 @@ MYPROCTYPE *visor_proc_CreateType(struct proc_dir_entry *procDirRoot, ...@@ -137,17 +133,16 @@ MYPROCTYPE *visor_proc_CreateType(struct proc_dir_entry *procDirRoot,
MYPROCTYPE *rc = NULL, *type = NULL; MYPROCTYPE *rc = NULL, *type = NULL;
struct proc_dir_entry *parent = NULL; struct proc_dir_entry *parent = NULL;
if (procDirRoot == NULL) { if (procDirRoot == NULL)
ERRDRV("procDirRoot cannot be NULL!\n");
goto Away; goto Away;
}
if (name == NULL || name[0] == NULL) { if (name == NULL || name[0] == NULL)
ERRDRV("name must contain at least 1 node name!\n");
goto Away; goto Away;
}
type = kzalloc(sizeof(MYPROCTYPE), GFP_KERNEL | __GFP_NORETRY); type = kzalloc(sizeof(MYPROCTYPE), GFP_KERNEL | __GFP_NORETRY);
if (type == NULL) if (type == NULL)
goto Away; goto Away;
type->name = name; type->name = name;
type->propertyNames = propertyNames; type->propertyNames = propertyNames;
type->nProperties = 0; type->nProperties = 0;
...@@ -222,13 +217,13 @@ MYPROCOBJECT *visor_proc_CreateObject(MYPROCTYPE *type, ...@@ -222,13 +217,13 @@ MYPROCOBJECT *visor_proc_CreateObject(MYPROCTYPE *type,
MYPROCOBJECT *obj = NULL, *rc = NULL; MYPROCOBJECT *obj = NULL, *rc = NULL;
int i = 0; int i = 0;
if (type == NULL) { if (type == NULL)
ERRDRV("type cannot be NULL\n");
goto Away; goto Away;
}
obj = kzalloc(sizeof(MYPROCOBJECT), GFP_KERNEL | __GFP_NORETRY); obj = kzalloc(sizeof(MYPROCOBJECT), GFP_KERNEL | __GFP_NORETRY);
if (obj == NULL) if (obj == NULL)
goto Away; goto Away;
obj->type = type; obj->type = type;
obj->context = context; obj->context = context;
if (name == NULL) { if (name == NULL) {
...@@ -332,10 +327,8 @@ static int seq_show(struct seq_file *seq, void *offset) ...@@ -332,10 +327,8 @@ static int seq_show(struct seq_file *seq, void *offset)
{ {
struct proc_dir_entry_context *ctx = seq->private; struct proc_dir_entry_context *ctx = seq->private;
if (ctx == NULL) { if (ctx == NULL)
ERRDRV("I don't have a freakin' clue...");
return 0; return 0;
}
(*ctx->show_property)(seq, ctx->procObject->context, (*ctx->show_property)(seq, ctx->procObject->context,
ctx->propertyIndex); ctx->propertyIndex);
return 0; return 0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment