4 * Debug traces for zfcp.
6 * Copyright IBM Corporation 2002, 2010
9 #define KMSG_COMPONENT "zfcp"
10 #define pr_fmt(fmt) KMSG_COMPONENT ": " fmt
12 #include <linux/module.h>
13 #include <linux/ctype.h>
14 #include <linux/slab.h>
15 #include <asm/debug.h>
20 static u32 dbfsize
= 4;
22 module_param(dbfsize
, uint
, 0400);
23 MODULE_PARM_DESC(dbfsize
,
24 "number of pages for each debug feature area (default 4)");
26 static inline unsigned int zfcp_dbf_plen(unsigned int offset
)
28 return sizeof(struct zfcp_dbf_pay
) + offset
- ZFCP_DBF_PAY_MAX_REC
;
32 void zfcp_dbf_pl_write(struct zfcp_dbf
*dbf
, void *data
, u16 length
, char *area
,
35 struct zfcp_dbf_pay
*pl
= &dbf
->pay_buf
;
36 u16 offset
= 0, rec_length
;
38 spin_lock(&dbf
->pay_lock
);
39 memset(pl
, 0, sizeof(*pl
));
40 pl
->fsf_req_id
= req_id
;
41 memcpy(pl
->area
, area
, ZFCP_DBF_TAG_LEN
);
43 while (offset
< length
) {
44 rec_length
= min((u16
) ZFCP_DBF_PAY_MAX_REC
,
45 (u16
) (length
- offset
));
46 memcpy(pl
->data
, data
+ offset
, rec_length
);
47 debug_event(dbf
->pay
, 1, pl
, zfcp_dbf_plen(rec_length
));
53 spin_unlock(&dbf
->pay_lock
);
57 * zfcp_dbf_hba_fsf_res - trace event for fsf responses
58 * @tag: tag indicating which kind of unsolicited status has been received
59 * @req: request for which a response was received
61 void zfcp_dbf_hba_fsf_res(char *tag
, struct zfcp_fsf_req
*req
)
63 struct zfcp_dbf
*dbf
= req
->adapter
->dbf
;
64 struct fsf_qtcb_prefix
*q_pref
= &req
->qtcb
->prefix
;
65 struct fsf_qtcb_header
*q_head
= &req
->qtcb
->header
;
66 struct zfcp_dbf_hba
*rec
= &dbf
->hba_buf
;
69 spin_lock_irqsave(&dbf
->hba_lock
, flags
);
70 memset(rec
, 0, sizeof(*rec
));
72 memcpy(rec
->tag
, tag
, ZFCP_DBF_TAG_LEN
);
73 rec
->id
= ZFCP_DBF_HBA_RES
;
74 rec
->fsf_req_id
= req
->req_id
;
75 rec
->fsf_req_status
= req
->status
;
76 rec
->fsf_cmd
= req
->fsf_command
;
77 rec
->fsf_seq_no
= req
->seq_no
;
78 rec
->u
.res
.req_issued
= req
->issued
;
79 rec
->u
.res
.prot_status
= q_pref
->prot_status
;
80 rec
->u
.res
.fsf_status
= q_head
->fsf_status
;
82 memcpy(rec
->u
.res
.prot_status_qual
, &q_pref
->prot_status_qual
,
83 FSF_PROT_STATUS_QUAL_SIZE
);
84 memcpy(rec
->u
.res
.fsf_status_qual
, &q_head
->fsf_status_qual
,
85 FSF_STATUS_QUALIFIER_SIZE
);
87 if (req
->fsf_command
!= FSF_QTCB_FCP_CMND
) {
88 rec
->pl_len
= q_head
->log_length
;
89 zfcp_dbf_pl_write(dbf
, (char *)q_pref
+ q_head
->log_start
,
90 rec
->pl_len
, "fsf_res", req
->req_id
);
93 debug_event(dbf
->hba
, 1, rec
, sizeof(*rec
));
94 spin_unlock_irqrestore(&dbf
->hba_lock
, flags
);
98 * zfcp_dbf_hba_fsf_uss - trace event for an unsolicited status buffer
99 * @tag: tag indicating which kind of unsolicited status has been received
100 * @req: request providing the unsolicited status
102 void zfcp_dbf_hba_fsf_uss(char *tag
, struct zfcp_fsf_req
*req
)
104 struct zfcp_dbf
*dbf
= req
->adapter
->dbf
;
105 struct fsf_status_read_buffer
*srb
= req
->data
;
106 struct zfcp_dbf_hba
*rec
= &dbf
->hba_buf
;
109 spin_lock_irqsave(&dbf
->hba_lock
, flags
);
110 memset(rec
, 0, sizeof(*rec
));
112 memcpy(rec
->tag
, tag
, ZFCP_DBF_TAG_LEN
);
113 rec
->id
= ZFCP_DBF_HBA_USS
;
114 rec
->fsf_req_id
= req
->req_id
;
115 rec
->fsf_req_status
= req
->status
;
116 rec
->fsf_cmd
= req
->fsf_command
;
121 rec
->u
.uss
.status_type
= srb
->status_type
;
122 rec
->u
.uss
.status_subtype
= srb
->status_subtype
;
123 rec
->u
.uss
.d_id
= ntoh24(srb
->d_id
);
124 rec
->u
.uss
.lun
= srb
->fcp_lun
;
125 memcpy(&rec
->u
.uss
.queue_designator
, &srb
->queue_designator
,
126 sizeof(rec
->u
.uss
.queue_designator
));
128 /* status read buffer payload length */
129 rec
->pl_len
= (!srb
->length
) ? 0 : srb
->length
-
130 offsetof(struct fsf_status_read_buffer
, payload
);
133 zfcp_dbf_pl_write(dbf
, srb
->payload
.data
, rec
->pl_len
,
134 "fsf_uss", req
->req_id
);
136 debug_event(dbf
->hba
, 2, rec
, sizeof(*rec
));
137 spin_unlock_irqrestore(&dbf
->hba_lock
, flags
);
141 * zfcp_dbf_hba_bit_err - trace event for bit error conditions
142 * @tag: tag indicating which kind of unsolicited status has been received
143 * @req: request which caused the bit_error condition
145 void zfcp_dbf_hba_bit_err(char *tag
, struct zfcp_fsf_req
*req
)
147 struct zfcp_dbf
*dbf
= req
->adapter
->dbf
;
148 struct zfcp_dbf_hba
*rec
= &dbf
->hba_buf
;
149 struct fsf_status_read_buffer
*sr_buf
= req
->data
;
152 spin_lock_irqsave(&dbf
->hba_lock
, flags
);
153 memset(rec
, 0, sizeof(*rec
));
155 memcpy(rec
->tag
, tag
, ZFCP_DBF_TAG_LEN
);
156 rec
->id
= ZFCP_DBF_HBA_BIT
;
157 rec
->fsf_req_id
= req
->req_id
;
158 rec
->fsf_req_status
= req
->status
;
159 rec
->fsf_cmd
= req
->fsf_command
;
160 memcpy(&rec
->u
.be
, &sr_buf
->payload
.bit_error
,
161 sizeof(struct fsf_bit_error_payload
));
163 debug_event(dbf
->hba
, 1, rec
, sizeof(*rec
));
164 spin_unlock_irqrestore(&dbf
->hba_lock
, flags
);
168 * zfcp_dbf_hba_def_err - trace event for deferred error messages
169 * @adapter: pointer to struct zfcp_adapter
170 * @req_id: request id which caused the deferred error message
171 * @scount: number of sbals incl. the signaling sbal
172 * @pl: array of all involved sbals
174 void zfcp_dbf_hba_def_err(struct zfcp_adapter
*adapter
, u64 req_id
, u16 scount
,
177 struct zfcp_dbf
*dbf
= adapter
->dbf
;
178 struct zfcp_dbf_pay
*payload
= &dbf
->pay_buf
;
185 spin_lock_irqsave(&dbf
->pay_lock
, flags
);
186 memset(payload
, 0, sizeof(*payload
));
188 memcpy(payload
->area
, "def_err", 7);
189 payload
->fsf_req_id
= req_id
;
190 payload
->counter
= 0;
191 length
= min((u16
)sizeof(struct qdio_buffer
),
192 (u16
)ZFCP_DBF_PAY_MAX_REC
);
194 while (payload
->counter
< scount
&& (char *)pl
[payload
->counter
]) {
195 memcpy(payload
->data
, (char *)pl
[payload
->counter
], length
);
196 debug_event(dbf
->pay
, 1, payload
, zfcp_dbf_plen(length
));
200 spin_unlock_irqrestore(&dbf
->pay_lock
, flags
);
204 * zfcp_dbf_hba_basic - trace event for basic adapter events
205 * @adapter: pointer to struct zfcp_adapter
207 void zfcp_dbf_hba_basic(char *tag
, struct zfcp_adapter
*adapter
)
209 struct zfcp_dbf
*dbf
= adapter
->dbf
;
210 struct zfcp_dbf_hba
*rec
= &dbf
->hba_buf
;
213 spin_lock_irqsave(&dbf
->hba_lock
, flags
);
214 memset(rec
, 0, sizeof(*rec
));
216 memcpy(rec
->tag
, tag
, ZFCP_DBF_TAG_LEN
);
217 rec
->id
= ZFCP_DBF_HBA_BASIC
;
219 debug_event(dbf
->hba
, 1, rec
, sizeof(*rec
));
220 spin_unlock_irqrestore(&dbf
->hba_lock
, flags
);
223 static void zfcp_dbf_set_common(struct zfcp_dbf_rec
*rec
,
224 struct zfcp_adapter
*adapter
,
225 struct zfcp_port
*port
,
226 struct scsi_device
*sdev
)
228 rec
->adapter_status
= atomic_read(&adapter
->status
);
230 rec
->port_status
= atomic_read(&port
->status
);
231 rec
->wwpn
= port
->wwpn
;
232 rec
->d_id
= port
->d_id
;
235 rec
->lun_status
= atomic_read(&sdev_to_zfcp(sdev
)->status
);
236 rec
->lun
= zfcp_scsi_dev_lun(sdev
);
241 * zfcp_dbf_rec_trig - trace event related to triggered recovery
242 * @tag: identifier for event
243 * @adapter: adapter on which the erp_action should run
244 * @port: remote port involved in the erp_action
245 * @sdev: scsi device involved in the erp_action
246 * @want: wanted erp_action
247 * @need: required erp_action
249 * The adapter->erp_lock has to be held.
251 void zfcp_dbf_rec_trig(char *tag
, struct zfcp_adapter
*adapter
,
252 struct zfcp_port
*port
, struct scsi_device
*sdev
,
255 struct zfcp_dbf
*dbf
= adapter
->dbf
;
256 struct zfcp_dbf_rec
*rec
= &dbf
->rec_buf
;
257 struct list_head
*entry
;
260 spin_lock_irqsave(&dbf
->rec_lock
, flags
);
261 memset(rec
, 0, sizeof(*rec
));
263 rec
->id
= ZFCP_DBF_REC_TRIG
;
264 memcpy(rec
->tag
, tag
, ZFCP_DBF_TAG_LEN
);
265 zfcp_dbf_set_common(rec
, adapter
, port
, sdev
);
267 list_for_each(entry
, &adapter
->erp_ready_head
)
270 list_for_each(entry
, &adapter
->erp_running_head
)
271 rec
->u
.trig
.running
++;
273 rec
->u
.trig
.want
= want
;
274 rec
->u
.trig
.need
= need
;
276 debug_event(dbf
->rec
, 1, rec
, sizeof(*rec
));
277 spin_unlock_irqrestore(&dbf
->rec_lock
, flags
);
282 * zfcp_dbf_rec_run - trace event related to running recovery
283 * @tag: identifier for event
284 * @erp: erp_action running
286 void zfcp_dbf_rec_run(char *tag
, struct zfcp_erp_action
*erp
)
288 struct zfcp_dbf
*dbf
= erp
->adapter
->dbf
;
289 struct zfcp_dbf_rec
*rec
= &dbf
->rec_buf
;
292 spin_lock_irqsave(&dbf
->rec_lock
, flags
);
293 memset(rec
, 0, sizeof(*rec
));
295 rec
->id
= ZFCP_DBF_REC_RUN
;
296 memcpy(rec
->tag
, tag
, ZFCP_DBF_TAG_LEN
);
297 zfcp_dbf_set_common(rec
, erp
->adapter
, erp
->port
, erp
->sdev
);
299 rec
->u
.run
.fsf_req_id
= erp
->fsf_req_id
;
300 rec
->u
.run
.rec_status
= erp
->status
;
301 rec
->u
.run
.rec_step
= erp
->step
;
302 rec
->u
.run
.rec_action
= erp
->action
;
305 rec
->u
.run
.rec_count
=
306 atomic_read(&sdev_to_zfcp(erp
->sdev
)->erp_counter
);
308 rec
->u
.run
.rec_count
= atomic_read(&erp
->port
->erp_counter
);
310 rec
->u
.run
.rec_count
= atomic_read(&erp
->adapter
->erp_counter
);
312 debug_event(dbf
->rec
, 1, rec
, sizeof(*rec
));
313 spin_unlock_irqrestore(&dbf
->rec_lock
, flags
);
317 void zfcp_dbf_san(char *tag
, struct zfcp_dbf
*dbf
, void *data
, u8 id
, u16 len
,
318 u64 req_id
, u32 d_id
)
320 struct zfcp_dbf_san
*rec
= &dbf
->san_buf
;
324 spin_lock_irqsave(&dbf
->san_lock
, flags
);
325 memset(rec
, 0, sizeof(*rec
));
328 rec
->fsf_req_id
= req_id
;
330 rec_len
= min(len
, (u16
)ZFCP_DBF_SAN_MAX_PAYLOAD
);
331 memcpy(rec
->payload
, data
, rec_len
);
332 memcpy(rec
->tag
, tag
, ZFCP_DBF_TAG_LEN
);
334 debug_event(dbf
->san
, 1, rec
, sizeof(*rec
));
335 spin_unlock_irqrestore(&dbf
->san_lock
, flags
);
339 * zfcp_dbf_san_req - trace event for issued SAN request
340 * @tag: indentifier for event
341 * @fsf_req: request containing issued CT data
342 * d_id: destination ID
344 void zfcp_dbf_san_req(char *tag
, struct zfcp_fsf_req
*fsf
, u32 d_id
)
346 struct zfcp_dbf
*dbf
= fsf
->adapter
->dbf
;
347 struct zfcp_fsf_ct_els
*ct_els
= fsf
->data
;
350 length
= (u16
)(ct_els
->req
->length
+ FC_CT_HDR_LEN
);
351 zfcp_dbf_san(tag
, dbf
, sg_virt(ct_els
->req
), ZFCP_DBF_SAN_REQ
, length
,
356 * zfcp_dbf_san_res - trace event for received SAN request
357 * @tag: indentifier for event
358 * @fsf_req: request containing issued CT data
360 void zfcp_dbf_san_res(char *tag
, struct zfcp_fsf_req
*fsf
)
362 struct zfcp_dbf
*dbf
= fsf
->adapter
->dbf
;
363 struct zfcp_fsf_ct_els
*ct_els
= fsf
->data
;
366 length
= (u16
)(ct_els
->resp
->length
+ FC_CT_HDR_LEN
);
367 zfcp_dbf_san(tag
, dbf
, sg_virt(ct_els
->resp
), ZFCP_DBF_SAN_RES
, length
,
372 * zfcp_dbf_san_in_els - trace event for incoming ELS
373 * @tag: indentifier for event
374 * @fsf_req: request containing issued CT data
376 void zfcp_dbf_san_in_els(char *tag
, struct zfcp_fsf_req
*fsf
)
378 struct zfcp_dbf
*dbf
= fsf
->adapter
->dbf
;
379 struct fsf_status_read_buffer
*srb
=
380 (struct fsf_status_read_buffer
*) fsf
->data
;
383 length
= (u16
)(srb
->length
-
384 offsetof(struct fsf_status_read_buffer
, payload
));
385 zfcp_dbf_san(tag
, dbf
, srb
->payload
.data
, ZFCP_DBF_SAN_ELS
, length
,
386 fsf
->req_id
, ntoh24(srb
->d_id
));
390 * zfcp_dbf_scsi - trace event for scsi commands
391 * @tag: identifier for event
392 * @sc: pointer to struct scsi_cmnd
393 * @fsf: pointer to struct zfcp_fsf_req
395 void zfcp_dbf_scsi(char *tag
, struct scsi_cmnd
*sc
, struct zfcp_fsf_req
*fsf
)
397 struct zfcp_adapter
*adapter
=
398 (struct zfcp_adapter
*) sc
->device
->host
->hostdata
[0];
399 struct zfcp_dbf
*dbf
= adapter
->dbf
;
400 struct zfcp_dbf_scsi
*rec
= &dbf
->scsi_buf
;
401 struct fcp_resp_with_ext
*fcp_rsp
;
402 struct fcp_resp_rsp_info
*fcp_rsp_info
;
405 spin_lock_irqsave(&dbf
->scsi_lock
, flags
);
406 memset(rec
, 0, sizeof(*rec
));
408 memcpy(rec
->tag
, tag
, ZFCP_DBF_TAG_LEN
);
409 rec
->id
= ZFCP_DBF_SCSI_CMND
;
410 rec
->scsi_result
= sc
->result
;
411 rec
->scsi_retries
= sc
->retries
;
412 rec
->scsi_allowed
= sc
->allowed
;
413 rec
->scsi_id
= sc
->device
->id
;
414 rec
->scsi_lun
= sc
->device
->lun
;
415 rec
->host_scribble
= (unsigned long)sc
->host_scribble
;
417 memcpy(rec
->scsi_opcode
, sc
->cmnd
,
418 min((int)sc
->cmd_len
, ZFCP_DBF_SCSI_OPCODE
));
421 rec
->fsf_req_id
= fsf
->req_id
;
422 fcp_rsp
= (struct fcp_resp_with_ext
*)
423 &(fsf
->qtcb
->bottom
.io
.fcp_rsp
);
424 memcpy(&rec
->fcp_rsp
, fcp_rsp
, FCP_RESP_WITH_EXT
);
425 if (fcp_rsp
->resp
.fr_flags
& FCP_RSP_LEN_VAL
) {
426 fcp_rsp_info
= (struct fcp_resp_rsp_info
*) &fcp_rsp
[1];
427 rec
->fcp_rsp_info
= fcp_rsp_info
->rsp_code
;
429 if (fcp_rsp
->resp
.fr_flags
& FCP_SNS_LEN_VAL
) {
430 rec
->pl_len
= min((u16
)SCSI_SENSE_BUFFERSIZE
,
431 (u16
)ZFCP_DBF_PAY_MAX_REC
);
432 zfcp_dbf_pl_write(dbf
, sc
->sense_buffer
, rec
->pl_len
,
433 "fcp_sns", fsf
->req_id
);
437 debug_event(dbf
->scsi
, 1, rec
, sizeof(*rec
));
438 spin_unlock_irqrestore(&dbf
->scsi_lock
, flags
);
441 static debug_info_t
*zfcp_dbf_reg(const char *name
, int size
, int rec_size
)
443 struct debug_info
*d
;
445 d
= debug_register(name
, size
, 1, rec_size
);
449 debug_register_view(d
, &debug_hex_ascii_view
);
450 debug_set_level(d
, 3);
455 static void zfcp_dbf_unregister(struct zfcp_dbf
*dbf
)
460 debug_unregister(dbf
->scsi
);
461 debug_unregister(dbf
->san
);
462 debug_unregister(dbf
->hba
);
463 debug_unregister(dbf
->pay
);
464 debug_unregister(dbf
->rec
);
469 * zfcp_adapter_debug_register - registers debug feature for an adapter
470 * @adapter: pointer to adapter for which debug features should be registered
471 * return: -ENOMEM on error, 0 otherwise
473 int zfcp_dbf_adapter_register(struct zfcp_adapter
*adapter
)
475 char name
[DEBUG_MAX_NAME_LEN
];
476 struct zfcp_dbf
*dbf
;
478 dbf
= kzalloc(sizeof(struct zfcp_dbf
), GFP_KERNEL
);
482 spin_lock_init(&dbf
->pay_lock
);
483 spin_lock_init(&dbf
->hba_lock
);
484 spin_lock_init(&dbf
->san_lock
);
485 spin_lock_init(&dbf
->scsi_lock
);
486 spin_lock_init(&dbf
->rec_lock
);
488 /* debug feature area which records recovery activity */
489 sprintf(name
, "zfcp_%s_rec", dev_name(&adapter
->ccw_device
->dev
));
490 dbf
->rec
= zfcp_dbf_reg(name
, dbfsize
, sizeof(struct zfcp_dbf_rec
));
494 /* debug feature area which records HBA (FSF and QDIO) conditions */
495 sprintf(name
, "zfcp_%s_hba", dev_name(&adapter
->ccw_device
->dev
));
496 dbf
->hba
= zfcp_dbf_reg(name
, dbfsize
, sizeof(struct zfcp_dbf_hba
));
500 /* debug feature area which records payload info */
501 sprintf(name
, "zfcp_%s_pay", dev_name(&adapter
->ccw_device
->dev
));
502 dbf
->pay
= zfcp_dbf_reg(name
, dbfsize
* 2, sizeof(struct zfcp_dbf_pay
));
506 /* debug feature area which records SAN command failures and recovery */
507 sprintf(name
, "zfcp_%s_san", dev_name(&adapter
->ccw_device
->dev
));
508 dbf
->san
= zfcp_dbf_reg(name
, dbfsize
, sizeof(struct zfcp_dbf_san
));
512 /* debug feature area which records SCSI command failures and recovery */
513 sprintf(name
, "zfcp_%s_scsi", dev_name(&adapter
->ccw_device
->dev
));
514 dbf
->scsi
= zfcp_dbf_reg(name
, dbfsize
, sizeof(struct zfcp_dbf_scsi
));
522 zfcp_dbf_unregister(dbf
);
527 * zfcp_adapter_debug_unregister - unregisters debug feature for an adapter
528 * @adapter: pointer to adapter for which debug features should be unregistered
530 void zfcp_dbf_adapter_unregister(struct zfcp_adapter
*adapter
)
532 struct zfcp_dbf
*dbf
= adapter
->dbf
;
535 zfcp_dbf_unregister(dbf
);