Commit 9ccfc756 authored by James Bottomley's avatar James Bottomley Committed by James Bottomley

[SCSI] move the mid-layer printk's over to shost/starget/sdev_printk

This should eliminate (at least in the mid layer) to make numeric
assumptions about any of the enumeration variables.  As a side effect,
it will also make all the messages consistent and line us up nicely for
the error logging strategy (if it ever shows itself again).
Signed-off-by: default avatarJames Bottomley <James.Bottomley@SteelEye.com>
parent 9a41a62b
...@@ -1389,10 +1389,7 @@ EXPORT_SYMBOL(scsi_print_msg); ...@@ -1389,10 +1389,7 @@ EXPORT_SYMBOL(scsi_print_msg);
void scsi_print_command(struct scsi_cmnd *cmd) void scsi_print_command(struct scsi_cmnd *cmd)
{ {
/* Assume appended output (i.e. not at start of line) */ /* Assume appended output (i.e. not at start of line) */
printk("scsi%d : destination target %d, lun %d\n", sdev_printk("", cmd->device, "\n");
cmd->device->host->host_no,
cmd->device->id,
cmd->device->lun);
printk(KERN_INFO " command: "); printk(KERN_INFO " command: ");
scsi_print_cdb(cmd->cmnd, cmd->cmd_len, 0); scsi_print_cdb(cmd->cmnd, cmd->cmd_len, 0);
} }
......
...@@ -139,11 +139,11 @@ int scsi_host_set_state(struct Scsi_Host *shost, enum scsi_host_state state) ...@@ -139,11 +139,11 @@ int scsi_host_set_state(struct Scsi_Host *shost, enum scsi_host_state state)
illegal: illegal:
SCSI_LOG_ERROR_RECOVERY(1, SCSI_LOG_ERROR_RECOVERY(1,
dev_printk(KERN_ERR, &shost->shost_gendev, shost_printk(KERN_ERR, shost,
"Illegal host state transition" "Illegal host state transition"
"%s->%s\n", "%s->%s\n",
scsi_host_state_name(oldstate), scsi_host_state_name(oldstate),
scsi_host_state_name(state))); scsi_host_state_name(state)));
return -EINVAL; return -EINVAL;
} }
EXPORT_SYMBOL(scsi_host_set_state); EXPORT_SYMBOL(scsi_host_set_state);
......
...@@ -5819,9 +5819,9 @@ static int osst_probe(struct device *dev) ...@@ -5819,9 +5819,9 @@ static int osst_probe(struct device *dev)
} }
drive->number = devfs_register_tape(SDp->devfs_name); drive->number = devfs_register_tape(SDp->devfs_name);
printk(KERN_INFO dev_printk(KERN_INFO, &SDp->sdev_gendev,
"osst :I: Attached OnStream %.5s tape at scsi%d, channel %d, id %d, lun %d as %s\n", "osst :I: Attached OnStream %.5s tape as %s\n",
SDp->model, SDp->host->host_no, SDp->channel, SDp->id, SDp->lun, tape_name(tpnt)); SDp->model, tape_name(tpnt));
return 0; return 0;
......
...@@ -410,9 +410,7 @@ void scsi_log_send(struct scsi_cmnd *cmd) ...@@ -410,9 +410,7 @@ void scsi_log_send(struct scsi_cmnd *cmd)
SCSI_LOG_MLQUEUE_BITS); SCSI_LOG_MLQUEUE_BITS);
if (level > 1) { if (level > 1) {
sdev = cmd->device; sdev = cmd->device;
printk(KERN_INFO "scsi <%d:%d:%d:%d> send ", sdev_printk(KERN_INFO, sdev, "send ");
sdev->host->host_no, sdev->channel, sdev->id,
sdev->lun);
if (level > 2) if (level > 2)
printk("0x%p ", cmd); printk("0x%p ", cmd);
/* /*
...@@ -456,9 +454,7 @@ void scsi_log_completion(struct scsi_cmnd *cmd, int disposition) ...@@ -456,9 +454,7 @@ void scsi_log_completion(struct scsi_cmnd *cmd, int disposition)
if (((level > 0) && (cmd->result || disposition != SUCCESS)) || if (((level > 0) && (cmd->result || disposition != SUCCESS)) ||
(level > 1)) { (level > 1)) {
sdev = cmd->device; sdev = cmd->device;
printk(KERN_INFO "scsi <%d:%d:%d:%d> done ", sdev_printk(KERN_INFO, sdev, "done ");
sdev->host->host_no, sdev->channel, sdev->id,
sdev->lun);
if (level > 2) if (level > 2)
printk("0x%p ", cmd); printk("0x%p ", cmd);
/* /*
...@@ -810,9 +806,9 @@ static void scsi_softirq(struct softirq_action *h) ...@@ -810,9 +806,9 @@ static void scsi_softirq(struct softirq_action *h)
disposition = scsi_decide_disposition(cmd); disposition = scsi_decide_disposition(cmd);
if (disposition != SUCCESS && if (disposition != SUCCESS &&
time_before(cmd->jiffies_at_alloc + wait_for, jiffies)) { time_before(cmd->jiffies_at_alloc + wait_for, jiffies)) {
dev_printk(KERN_ERR, &cmd->device->sdev_gendev, sdev_printk(KERN_ERR, cmd->device,
"timing out command, waited %lus\n", "timing out command, waited %lus\n",
wait_for/HZ); wait_for/HZ);
disposition = SUCCESS; disposition = SUCCESS;
} }
...@@ -970,10 +966,9 @@ void scsi_adjust_queue_depth(struct scsi_device *sdev, int tagged, int tags) ...@@ -970,10 +966,9 @@ void scsi_adjust_queue_depth(struct scsi_device *sdev, int tagged, int tags)
sdev->simple_tags = 1; sdev->simple_tags = 1;
break; break;
default: default:
printk(KERN_WARNING "(scsi%d:%d:%d:%d) " sdev_printk(KERN_WARNING, sdev,
"scsi_adjust_queue_depth, bad queue type, " "scsi_adjust_queue_depth, bad queue type, "
"disabled\n", sdev->host->host_no, "disabled\n");
sdev->channel, sdev->id, sdev->lun);
case 0: case 0:
sdev->ordered_tags = sdev->simple_tags = 0; sdev->ordered_tags = sdev->simple_tags = 0;
sdev->queue_depth = tags; sdev->queue_depth = tags;
......
...@@ -241,11 +241,10 @@ static inline void scsi_eh_prt_fail_stats(struct Scsi_Host *shost, ...@@ -241,11 +241,10 @@ static inline void scsi_eh_prt_fail_stats(struct Scsi_Host *shost,
if (cmd_cancel || cmd_failed) { if (cmd_cancel || cmd_failed) {
SCSI_LOG_ERROR_RECOVERY(3, SCSI_LOG_ERROR_RECOVERY(3,
printk("%s: %d:%d:%d:%d cmds failed: %d," sdev_printk(KERN_INFO, sdev,
" cancel: %d\n", "%s: cmds failed: %d, cancel: %d\n",
__FUNCTION__, shost->host_no, __FUNCTION__, cmd_failed,
sdev->channel, sdev->id, sdev->lun, cmd_cancel));
cmd_failed, cmd_cancel));
cmd_cancel = 0; cmd_cancel = 0;
cmd_failed = 0; cmd_failed = 0;
++devices_failed; ++devices_failed;
...@@ -1174,13 +1173,9 @@ static void scsi_eh_offline_sdevs(struct list_head *work_q, ...@@ -1174,13 +1173,9 @@ static void scsi_eh_offline_sdevs(struct list_head *work_q,
struct scsi_cmnd *scmd, *next; struct scsi_cmnd *scmd, *next;
list_for_each_entry_safe(scmd, next, work_q, eh_entry) { list_for_each_entry_safe(scmd, next, work_q, eh_entry) {
printk(KERN_INFO "scsi: Device offlined - not" sdev_printk(KERN_INFO, scmd->device,
" ready after error recovery: host" "scsi: Device offlined - not"
" %d channel %d id %d lun %d\n", " ready after error recovery\n");
scmd->device->host->host_no,
scmd->device->channel,
scmd->device->id,
scmd->device->lun);
scsi_device_set_state(scmd->device, SDEV_OFFLINE); scsi_device_set_state(scmd->device, SDEV_OFFLINE);
if (scmd->eh_eflags & SCSI_EH_CANCEL_CMD) { if (scmd->eh_eflags & SCSI_EH_CANCEL_CMD) {
/* /*
...@@ -1342,10 +1337,8 @@ int scsi_decide_disposition(struct scsi_cmnd *scmd) ...@@ -1342,10 +1337,8 @@ int scsi_decide_disposition(struct scsi_cmnd *scmd)
return SUCCESS; return SUCCESS;
case RESERVATION_CONFLICT: case RESERVATION_CONFLICT:
printk(KERN_INFO "scsi: reservation conflict: host" sdev_printk(KERN_INFO, scmd->device,
" %d channel %d id %d lun %d\n", "reservation conflict\n");
scmd->device->host->host_no, scmd->device->channel,
scmd->device->id, scmd->device->lun);
return SUCCESS; /* causes immediate i/o error */ return SUCCESS; /* causes immediate i/o error */
default: default:
return FAILED; return FAILED;
......
...@@ -122,13 +122,9 @@ static int ioctl_internal_command(struct scsi_device *sdev, char *cmd, ...@@ -122,13 +122,9 @@ static int ioctl_internal_command(struct scsi_device *sdev, char *cmd,
break; break;
} }
default: /* Fall through for non-removable media */ default: /* Fall through for non-removable media */
printk(KERN_INFO "ioctl_internal_command: <%d %d %d " sdev_printk(KERN_INFO, sdev,
"%d> return code = %x\n", "ioctl_internal_command return code = %x\n",
sdev->host->host_no, result);
sdev->channel,
sdev->id,
sdev->lun,
result);
scsi_print_sense_hdr(" ", &sshdr); scsi_print_sense_hdr(" ", &sshdr);
break; break;
} }
......
...@@ -951,16 +951,16 @@ void scsi_io_completion(struct scsi_cmnd *cmd, unsigned int good_bytes, ...@@ -951,16 +951,16 @@ void scsi_io_completion(struct scsi_cmnd *cmd, unsigned int good_bytes,
return; return;
} }
if (!(req->flags & REQ_QUIET)) if (!(req->flags & REQ_QUIET))
dev_printk(KERN_INFO, sdev_printk(KERN_INFO,
&cmd->device->sdev_gendev, cmd->device,
"Device not ready.\n"); "Device not ready.\n");
scsi_end_request(cmd, 0, this_count, 1); scsi_end_request(cmd, 0, this_count, 1);
return; return;
case VOLUME_OVERFLOW: case VOLUME_OVERFLOW:
if (!(req->flags & REQ_QUIET)) { if (!(req->flags & REQ_QUIET)) {
dev_printk(KERN_INFO, sdev_printk(KERN_INFO,
&cmd->device->sdev_gendev, cmd->device,
"Volume overflow, CDB: "); "Volume overflow, CDB: ");
__scsi_print_command(cmd->data_cmnd); __scsi_print_command(cmd->data_cmnd);
scsi_print_sense("", cmd); scsi_print_sense("", cmd);
} }
...@@ -981,8 +981,9 @@ void scsi_io_completion(struct scsi_cmnd *cmd, unsigned int good_bytes, ...@@ -981,8 +981,9 @@ void scsi_io_completion(struct scsi_cmnd *cmd, unsigned int good_bytes,
} }
if (result) { if (result) {
if (!(req->flags & REQ_QUIET)) { if (!(req->flags & REQ_QUIET)) {
dev_printk(KERN_INFO, &cmd->device->sdev_gendev, sdev_printk(KERN_INFO, cmd->device,
"SCSI error: return code = 0x%x\n", result); "SCSI error: return code = 0x%x\n",
result);
if (driver_byte(result) & DRIVER_SENSE) if (driver_byte(result) & DRIVER_SENSE)
scsi_print_sense("", cmd); scsi_print_sense("", cmd);
...@@ -1141,8 +1142,8 @@ static int scsi_prep_fn(struct request_queue *q, struct request *req) ...@@ -1141,8 +1142,8 @@ static int scsi_prep_fn(struct request_queue *q, struct request *req)
* online before trying any recovery commands * online before trying any recovery commands
*/ */
if (unlikely(!scsi_device_online(sdev))) { if (unlikely(!scsi_device_online(sdev))) {
printk(KERN_ERR "scsi%d (%d:%d): rejecting I/O to offline device\n", sdev_printk(KERN_ERR, sdev,
sdev->host->host_no, sdev->id, sdev->lun); "rejecting I/O to offline device\n");
goto kill; goto kill;
} }
if (unlikely(sdev->sdev_state != SDEV_RUNNING)) { if (unlikely(sdev->sdev_state != SDEV_RUNNING)) {
...@@ -1151,8 +1152,8 @@ static int scsi_prep_fn(struct request_queue *q, struct request *req) ...@@ -1151,8 +1152,8 @@ static int scsi_prep_fn(struct request_queue *q, struct request *req)
if (sdev->sdev_state == SDEV_DEL) { if (sdev->sdev_state == SDEV_DEL) {
/* Device is fully deleted, no commands /* Device is fully deleted, no commands
* at all allowed down */ * at all allowed down */
printk(KERN_ERR "scsi%d (%d:%d): rejecting I/O to dead device\n", sdev_printk(KERN_ERR, sdev,
sdev->host->host_no, sdev->id, sdev->lun); "rejecting I/O to dead device\n");
goto kill; goto kill;
} }
/* OK, we only allow special commands (i.e. not /* OK, we only allow special commands (i.e. not
...@@ -1187,8 +1188,8 @@ static int scsi_prep_fn(struct request_queue *q, struct request *req) ...@@ -1187,8 +1188,8 @@ static int scsi_prep_fn(struct request_queue *q, struct request *req)
specials_only == SDEV_BLOCK) specials_only == SDEV_BLOCK)
goto defer; goto defer;
printk(KERN_ERR "scsi%d (%d:%d): rejecting I/O to device being removed\n", sdev_printk(KERN_ERR, sdev,
sdev->host->host_no, sdev->id, sdev->lun); "rejecting I/O to device being removed\n");
goto kill; goto kill;
} }
...@@ -1315,9 +1316,8 @@ static inline int scsi_dev_queue_ready(struct request_queue *q, ...@@ -1315,9 +1316,8 @@ static inline int scsi_dev_queue_ready(struct request_queue *q,
*/ */
if (--sdev->device_blocked == 0) { if (--sdev->device_blocked == 0) {
SCSI_LOG_MLQUEUE(3, SCSI_LOG_MLQUEUE(3,
printk("scsi%d (%d:%d) unblocking device at" sdev_printk(KERN_INFO, sdev,
" zero depth\n", sdev->host->host_no, "unblocking device at zero depth\n"));
sdev->id, sdev->lun));
} else { } else {
blk_plug_device(q); blk_plug_device(q);
return 0; return 0;
...@@ -1436,8 +1436,8 @@ static void scsi_request_fn(struct request_queue *q) ...@@ -1436,8 +1436,8 @@ static void scsi_request_fn(struct request_queue *q)
break; break;
if (unlikely(!scsi_device_online(sdev))) { if (unlikely(!scsi_device_online(sdev))) {
printk(KERN_ERR "scsi%d (%d:%d): rejecting I/O to offline device\n", sdev_printk(KERN_ERR, sdev,
sdev->host->host_no, sdev->id, sdev->lun); "rejecting I/O to offline device\n");
scsi_kill_request(req, q); scsi_kill_request(req, q);
continue; continue;
} }
...@@ -1893,10 +1893,10 @@ scsi_device_set_state(struct scsi_device *sdev, enum scsi_device_state state) ...@@ -1893,10 +1893,10 @@ scsi_device_set_state(struct scsi_device *sdev, enum scsi_device_state state)
illegal: illegal:
SCSI_LOG_ERROR_RECOVERY(1, SCSI_LOG_ERROR_RECOVERY(1,
dev_printk(KERN_ERR, &sdev->sdev_gendev, sdev_printk(KERN_ERR, sdev,
"Illegal state transition %s->%s\n", "Illegal state transition %s->%s\n",
scsi_device_state_name(oldstate), scsi_device_state_name(oldstate),
scsi_device_state_name(state)) scsi_device_state_name(state))
); );
return -EINVAL; return -EINVAL;
} }
......
...@@ -462,10 +462,9 @@ static int scsi_probe_lun(struct scsi_device *sdev, char *inq_result, ...@@ -462,10 +462,9 @@ static int scsi_probe_lun(struct scsi_device *sdev, char *inq_result,
pass = 1; pass = 1;
next_pass: next_pass:
SCSI_LOG_SCAN_BUS(3, printk(KERN_INFO "scsi scan: INQUIRY pass %d " SCSI_LOG_SCAN_BUS(3, sdev_printk(KERN_INFO, sdev,
"to host %d channel %d id %d lun %d, length %d\n", "scsi scan: INQUIRY pass %d length %d\n",
pass, sdev->host->host_no, sdev->channel, pass, try_inquiry_len));
sdev->id, sdev->lun, try_inquiry_len));
/* Each pass gets up to three chances to ignore Unit Attention */ /* Each pass gets up to three chances to ignore Unit Attention */
for (count = 0; count < 3; ++count) { for (count = 0; count < 3; ++count) {
......
...@@ -32,8 +32,6 @@ ...@@ -32,8 +32,6 @@
#include <scsi/scsi_transport_fc.h> #include <scsi/scsi_transport_fc.h>
#include "scsi_priv.h" #include "scsi_priv.h"
#define FC_PRINTK(x, l, f, a...) printk(l "scsi(%d:%d:%d:%d): " f, (x)->host->host_no, (x)->channel, (x)->id, (x)->lun , ##a)
/* /*
* Redefine so that we can have same named attributes in the * Redefine so that we can have same named attributes in the
* sdev/starget/host objects. * sdev/starget/host objects.
......
...@@ -33,8 +33,6 @@ ...@@ -33,8 +33,6 @@
#include <scsi/scsi_transport.h> #include <scsi/scsi_transport.h>
#include <scsi/scsi_transport_spi.h> #include <scsi/scsi_transport_spi.h>
#define SPI_PRINTK(x, l, f, a...) dev_printk(l, &(x)->dev, f , ##a)
#define SPI_NUM_ATTRS 14 /* increase this if you add attributes */ #define SPI_NUM_ATTRS 14 /* increase this if you add attributes */
#define SPI_OTHER_ATTRS 1 /* Increase this if you add "always #define SPI_OTHER_ATTRS 1 /* Increase this if you add "always
* on" attributes */ * on" attributes */
...@@ -618,7 +616,7 @@ spi_dv_device_echo_buffer(struct scsi_device *sdev, u8 *buffer, ...@@ -618,7 +616,7 @@ spi_dv_device_echo_buffer(struct scsi_device *sdev, u8 *buffer,
return SPI_COMPARE_SKIP_TEST; return SPI_COMPARE_SKIP_TEST;
SPI_PRINTK(sdev->sdev_target, KERN_ERR, "Write Buffer failure %x\n", result); sdev_printk(KERN_ERR, sdev, "Write Buffer failure %x\n", result);
return SPI_COMPARE_FAILURE; return SPI_COMPARE_FAILURE;
} }
...@@ -702,10 +700,10 @@ spi_dv_retrain(struct scsi_device *sdev, u8 *buffer, u8 *ptr, ...@@ -702,10 +700,10 @@ spi_dv_retrain(struct scsi_device *sdev, u8 *buffer, u8 *ptr,
* IU, then QAS (if we can control them), then finally * IU, then QAS (if we can control them), then finally
* fall down the periods */ * fall down the periods */
if (i->f->set_iu && spi_iu(starget)) { if (i->f->set_iu && spi_iu(starget)) {
SPI_PRINTK(starget, KERN_ERR, "Domain Validation Disabing Information Units\n"); starget_printk(KERN_ERR, starget, "Domain Validation Disabing Information Units\n");
DV_SET(iu, 0); DV_SET(iu, 0);
} else if (i->f->set_qas && spi_qas(starget)) { } else if (i->f->set_qas && spi_qas(starget)) {
SPI_PRINTK(starget, KERN_ERR, "Domain Validation Disabing Quick Arbitration and Selection\n"); starget_printk(KERN_ERR, starget, "Domain Validation Disabing Quick Arbitration and Selection\n");
DV_SET(qas, 0); DV_SET(qas, 0);
} else { } else {
newperiod = spi_period(starget); newperiod = spi_period(starget);
...@@ -717,11 +715,11 @@ spi_dv_retrain(struct scsi_device *sdev, u8 *buffer, u8 *ptr, ...@@ -717,11 +715,11 @@ spi_dv_retrain(struct scsi_device *sdev, u8 *buffer, u8 *ptr,
if (unlikely(period > 0xff || period == prevperiod)) { if (unlikely(period > 0xff || period == prevperiod)) {
/* Total failure; set to async and return */ /* Total failure; set to async and return */
SPI_PRINTK(starget, KERN_ERR, "Domain Validation Failure, dropping back to Asynchronous\n"); starget_printk(KERN_ERR, starget, "Domain Validation Failure, dropping back to Asynchronous\n");
DV_SET(offset, 0); DV_SET(offset, 0);
return SPI_COMPARE_FAILURE; return SPI_COMPARE_FAILURE;
} }
SPI_PRINTK(starget, KERN_ERR, "Domain Validation detected failure, dropping back\n"); starget_printk(KERN_ERR, starget, "Domain Validation detected failure, dropping back\n");
DV_SET(period, period); DV_SET(period, period);
prevperiod = period; prevperiod = period;
} }
...@@ -788,7 +786,7 @@ spi_dv_device_internal(struct scsi_device *sdev, u8 *buffer) ...@@ -788,7 +786,7 @@ spi_dv_device_internal(struct scsi_device *sdev, u8 *buffer)
if (spi_dv_device_compare_inquiry(sdev, buffer, buffer, DV_LOOPS) if (spi_dv_device_compare_inquiry(sdev, buffer, buffer, DV_LOOPS)
!= SPI_COMPARE_SUCCESS) { != SPI_COMPARE_SUCCESS) {
SPI_PRINTK(starget, KERN_ERR, "Domain Validation Initial Inquiry Failed\n"); starget_printk(KERN_ERR, starget, "Domain Validation Initial Inquiry Failed\n");
/* FIXME: should probably offline the device here? */ /* FIXME: should probably offline the device here? */
return; return;
} }
...@@ -802,7 +800,7 @@ spi_dv_device_internal(struct scsi_device *sdev, u8 *buffer) ...@@ -802,7 +800,7 @@ spi_dv_device_internal(struct scsi_device *sdev, u8 *buffer)
buffer + len, buffer + len,
DV_LOOPS) DV_LOOPS)
!= SPI_COMPARE_SUCCESS) { != SPI_COMPARE_SUCCESS) {
SPI_PRINTK(starget, KERN_ERR, "Wide Transfers Fail\n"); starget_printk(KERN_ERR, starget, "Wide Transfers Fail\n");
i->f->set_width(starget, 0); i->f->set_width(starget, 0);
} }
} }
...@@ -844,14 +842,14 @@ spi_dv_device_internal(struct scsi_device *sdev, u8 *buffer) ...@@ -844,14 +842,14 @@ spi_dv_device_internal(struct scsi_device *sdev, u8 *buffer)
} }
if (len == 0) { if (len == 0) {
SPI_PRINTK(starget, KERN_INFO, "Domain Validation skipping write tests\n"); starget_printk(KERN_INFO, starget, "Domain Validation skipping write tests\n");
spi_dv_retrain(sdev, buffer, buffer + len, spi_dv_retrain(sdev, buffer, buffer + len,
spi_dv_device_compare_inquiry); spi_dv_device_compare_inquiry);
return; return;
} }
if (len > SPI_MAX_ECHO_BUFFER_SIZE) { if (len > SPI_MAX_ECHO_BUFFER_SIZE) {
SPI_PRINTK(starget, KERN_WARNING, "Echo buffer size %d is too big, trimming to %d\n", len, SPI_MAX_ECHO_BUFFER_SIZE); starget_printk(KERN_WARNING, starget, "Echo buffer size %d is too big, trimming to %d\n", len, SPI_MAX_ECHO_BUFFER_SIZE);
len = SPI_MAX_ECHO_BUFFER_SIZE; len = SPI_MAX_ECHO_BUFFER_SIZE;
} }
...@@ -902,11 +900,11 @@ spi_dv_device(struct scsi_device *sdev) ...@@ -902,11 +900,11 @@ spi_dv_device(struct scsi_device *sdev)
spi_dv_pending(starget) = 1; spi_dv_pending(starget) = 1;
down(&spi_dv_sem(starget)); down(&spi_dv_sem(starget));
SPI_PRINTK(starget, KERN_INFO, "Beginning Domain Validation\n"); starget_printk(KERN_INFO, starget, "Beginning Domain Validation\n");
spi_dv_device_internal(sdev, buffer); spi_dv_device_internal(sdev, buffer);
SPI_PRINTK(starget, KERN_INFO, "Ending Domain Validation\n"); starget_printk(KERN_INFO, starget, "Ending Domain Validation\n");
up(&spi_dv_sem(starget)); up(&spi_dv_sem(starget));
spi_dv_pending(starget) = 0; spi_dv_pending(starget) = 0;
......
...@@ -1534,8 +1534,8 @@ static int sd_probe(struct device *dev) ...@@ -1534,8 +1534,8 @@ static int sd_probe(struct device *dev)
if (sdp->type != TYPE_DISK && sdp->type != TYPE_MOD && sdp->type != TYPE_RBC) if (sdp->type != TYPE_DISK && sdp->type != TYPE_MOD && sdp->type != TYPE_RBC)
goto out; goto out;
SCSI_LOG_HLQUEUE(3, printk("sd_attach: scsi device: <%d,%d,%d,%d>\n", SCSI_LOG_HLQUEUE(3, sdev_printk(KERN_INFO, sdp,
sdp->host->host_no, sdp->channel, sdp->id, sdp->lun)); "sd_attach\n"));
error = -ENOMEM; error = -ENOMEM;
sdkp = kmalloc(sizeof(*sdkp), GFP_KERNEL); sdkp = kmalloc(sizeof(*sdkp), GFP_KERNEL);
...@@ -1607,10 +1607,8 @@ static int sd_probe(struct device *dev) ...@@ -1607,10 +1607,8 @@ static int sd_probe(struct device *dev)
dev_set_drvdata(dev, sdkp); dev_set_drvdata(dev, sdkp);
add_disk(gd); add_disk(gd);
printk(KERN_NOTICE "Attached scsi %sdisk %s at scsi%d, channel %d, " sdev_printk(KERN_NOTICE, sdp, "Attached scsi %sdisk %s\n",
"id %d, lun %d\n", sdp->removable ? "removable " : "", sdp->removable ? "removable " : "", gd->disk_name);
gd->disk_name, sdp->host->host_no, sdp->channel,
sdp->id, sdp->lun);
return 0; return 0;
......
...@@ -1497,10 +1497,9 @@ static int sg_alloc(struct gendisk *disk, struct scsi_device *scsidp) ...@@ -1497,10 +1497,9 @@ static int sg_alloc(struct gendisk *disk, struct scsi_device *scsidp)
overflow: overflow:
write_unlock_irqrestore(&sg_dev_arr_lock, iflags); write_unlock_irqrestore(&sg_dev_arr_lock, iflags);
printk(KERN_WARNING sdev_printk(KERN_WARNING, scsidp,
"Unable to attach sg device <%d, %d, %d, %d> type=%d, minor " "Unable to attach sg device type=%d, minor "
"number exceeds %d\n", scsidp->host->host_no, scsidp->channel, "number exceeds %d\n", scsidp->type, SG_MAX_DEVS - 1);
scsidp->id, scsidp->lun, scsidp->type, SG_MAX_DEVS - 1);
error = -ENODEV; error = -ENODEV;
goto out; goto out;
} }
...@@ -1566,11 +1565,8 @@ sg_add(struct class_device *cl_dev) ...@@ -1566,11 +1565,8 @@ sg_add(struct class_device *cl_dev)
} else } else
printk(KERN_WARNING "sg_add: sg_sys INvalid\n"); printk(KERN_WARNING "sg_add: sg_sys INvalid\n");
printk(KERN_NOTICE sdev_printk(KERN_NOTICE, scsidp,
"Attached scsi generic sg%d at scsi%d, channel" "Attached scsi generic sg%d type %d\n", k,scsidp->type);
" %d, id %d, lun %d, type %d\n", k,
scsidp->host->host_no, scsidp->channel, scsidp->id,
scsidp->lun, scsidp->type);
return 0; return 0;
......
...@@ -360,7 +360,7 @@ static int sr_init_command(struct scsi_cmnd * SCpnt) ...@@ -360,7 +360,7 @@ static int sr_init_command(struct scsi_cmnd * SCpnt)
} }
if (s_size != 512 && s_size != 1024 && s_size != 2048) { if (s_size != 512 && s_size != 1024 && s_size != 2048) {
printk("sr: bad sector size %d\n", s_size); sdev_printk(KERN_ERR, SCpnt->device, "bad sector size %d\n", s_size);
return 0; return 0;
} }
...@@ -385,8 +385,9 @@ static int sr_init_command(struct scsi_cmnd * SCpnt) ...@@ -385,8 +385,9 @@ static int sr_init_command(struct scsi_cmnd * SCpnt)
size += sg[i].length; size += sg[i].length;
if (size != SCpnt->request_bufflen && SCpnt->use_sg) { if (size != SCpnt->request_bufflen && SCpnt->use_sg) {
printk(KERN_ERR "sr: mismatch count %d, bytes %d\n", sdev_printk(KERN_ERR, SCpnt->device,
size, SCpnt->request_bufflen); "mismatch count %d, bytes %d\n",
size, SCpnt->request_bufflen);
if (SCpnt->request_bufflen > size) if (SCpnt->request_bufflen > size)
SCpnt->request_bufflen = SCpnt->bufflen = size; SCpnt->request_bufflen = SCpnt->bufflen = size;
} }
...@@ -397,7 +398,7 @@ static int sr_init_command(struct scsi_cmnd * SCpnt) ...@@ -397,7 +398,7 @@ static int sr_init_command(struct scsi_cmnd * SCpnt)
*/ */
if (((unsigned int)SCpnt->request->sector % (s_size >> 9)) || if (((unsigned int)SCpnt->request->sector % (s_size >> 9)) ||
(SCpnt->request_bufflen % s_size)) { (SCpnt->request_bufflen % s_size)) {
printk("sr: unaligned transfer\n"); sdev_printk(KERN_NOTICE, SCpnt->device, "unaligned transfer\n");
return 0; return 0;
} }
...@@ -622,10 +623,8 @@ static int sr_probe(struct device *dev) ...@@ -622,10 +623,8 @@ static int sr_probe(struct device *dev)
disk->flags |= GENHD_FL_REMOVABLE; disk->flags |= GENHD_FL_REMOVABLE;
add_disk(disk); add_disk(disk);
printk(KERN_DEBUG sdev_printk(KERN_DEBUG, sdev,
"Attached scsi CD-ROM %s at scsi%d, channel %d, id %d, lun %d\n", "Attached scsi CD-ROM %s\n", cd->cdi.name);
cd->cdi.name, sdev->host->host_no, sdev->channel,
sdev->id, sdev->lun);
return 0; return 0;
fail_put: fail_put:
......
...@@ -3887,9 +3887,8 @@ static int st_probe(struct device *dev) ...@@ -3887,9 +3887,8 @@ static int st_probe(struct device *dev)
if (SDp->type != TYPE_TAPE) if (SDp->type != TYPE_TAPE)
return -ENODEV; return -ENODEV;
if ((stp = st_incompatible(SDp))) { if ((stp = st_incompatible(SDp))) {
printk(KERN_INFO sdev_printk(KERN_INFO, SDp,
"st: Found incompatible tape at scsi%d, channel %d, id %d, lun %d\n", "Found incompatible tape\n");
SDp->host->host_no, SDp->channel, SDp->id, SDp->lun);
printk(KERN_INFO "st: The suggested driver is %s.\n", stp); printk(KERN_INFO "st: The suggested driver is %s.\n", stp);
return -ENODEV; return -ENODEV;
} }
...@@ -4077,9 +4076,8 @@ static int st_probe(struct device *dev) ...@@ -4077,9 +4076,8 @@ static int st_probe(struct device *dev)
} }
disk->number = devfs_register_tape(SDp->devfs_name); disk->number = devfs_register_tape(SDp->devfs_name);
printk(KERN_WARNING sdev_printk(KERN_WARNING, SDp,
"Attached scsi tape %s at scsi%d, channel %d, id %d, lun %d\n", "Attached scsi tape %s", tape_name(tpnt));
tape_name(tpnt), SDp->host->host_no, SDp->channel, SDp->id, SDp->lun);
printk(KERN_WARNING "%s: try direct i/o: %s (alignment %d B), max page reachable by HBA %lu\n", printk(KERN_WARNING "%s: try direct i/o: %s (alignment %d B), max page reachable by HBA %lu\n",
tape_name(tpnt), tpnt->try_dio ? "yes" : "no", tape_name(tpnt), tpnt->try_dio ? "yes" : "no",
queue_dma_alignment(SDp->request_queue) + 1, tpnt->max_pfn); queue_dma_alignment(SDp->request_queue) + 1, tpnt->max_pfn);
......
...@@ -148,6 +148,9 @@ struct scsi_device { ...@@ -148,6 +148,9 @@ struct scsi_device {
#define transport_class_to_sdev(class_dev) \ #define transport_class_to_sdev(class_dev) \
to_scsi_device(class_dev->dev) to_scsi_device(class_dev->dev)
#define sdev_printk(prefix, sdev, fmt, a...) \
dev_printk(prefix, &(sdev)->sdev_gendev, fmt, ##a)
/* /*
* scsi_target: representation of a scsi target, for now, this is only * scsi_target: representation of a scsi target, for now, this is only
* used for single_lun devices. If no one has active IO to the target, * used for single_lun devices. If no one has active IO to the target,
...@@ -177,6 +180,9 @@ static inline struct scsi_target *scsi_target(struct scsi_device *sdev) ...@@ -177,6 +180,9 @@ static inline struct scsi_target *scsi_target(struct scsi_device *sdev)
#define transport_class_to_starget(class_dev) \ #define transport_class_to_starget(class_dev) \
to_scsi_target(class_dev->dev) to_scsi_target(class_dev->dev)
#define starget_printk(prefix, starget, fmt, a...) \
dev_printk(prefix, &(starget)->dev, fmt, ##a)
extern struct scsi_device *__scsi_add_device(struct Scsi_Host *, extern struct scsi_device *__scsi_add_device(struct Scsi_Host *,
uint, uint, uint, void *hostdata); uint, uint, uint, void *hostdata);
extern int scsi_add_device(struct Scsi_Host *host, uint channel, extern int scsi_add_device(struct Scsi_Host *host, uint channel,
......
...@@ -609,6 +609,10 @@ struct Scsi_Host { ...@@ -609,6 +609,10 @@ struct Scsi_Host {
#define class_to_shost(d) \ #define class_to_shost(d) \
container_of(d, struct Scsi_Host, shost_classdev) container_of(d, struct Scsi_Host, shost_classdev)
#define shost_printk(prefix, shost, fmt, a...) \
dev_printk(prefix, &(shost)->shost_gendev, fmt, ##a)
int scsi_is_host_device(const struct device *); int scsi_is_host_device(const struct device *);
static inline struct Scsi_Host *dev_to_shost(struct device *dev) static inline struct Scsi_Host *dev_to_shost(struct device *dev)
......
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