diff options
Diffstat (limited to 'drivers/s390/scsi/zfcp_dbf.c')
-rw-r--r-- | drivers/s390/scsi/zfcp_dbf.c | 408 |
1 files changed, 192 insertions, 216 deletions
diff --git a/drivers/s390/scsi/zfcp_dbf.c b/drivers/s390/scsi/zfcp_dbf.c index 3179b08bda6..c066428b287 100644 --- a/drivers/s390/scsi/zfcp_dbf.c +++ b/drivers/s390/scsi/zfcp_dbf.c | |||
@@ -120,9 +120,9 @@ static int zfcp_dbf_view_header(debug_info_t *id, struct debug_view *view, | |||
120 | return p - out_buf; | 120 | return p - out_buf; |
121 | } | 121 | } |
122 | 122 | ||
123 | void _zfcp_hba_dbf_event_fsf_response(const char *tag2, int level, | 123 | void _zfcp_dbf_hba_fsf_response(const char *tag2, int level, |
124 | struct zfcp_fsf_req *fsf_req, | 124 | struct zfcp_fsf_req *fsf_req, |
125 | struct zfcp_dbf *dbf) | 125 | struct zfcp_dbf *dbf) |
126 | { | 126 | { |
127 | struct fsf_qtcb *qtcb = fsf_req->qtcb; | 127 | struct fsf_qtcb *qtcb = fsf_req->qtcb; |
128 | union fsf_prot_status_qual *prot_status_qual = | 128 | union fsf_prot_status_qual *prot_status_qual = |
@@ -132,11 +132,11 @@ void _zfcp_hba_dbf_event_fsf_response(const char *tag2, int level, | |||
132 | struct zfcp_port *port; | 132 | struct zfcp_port *port; |
133 | struct zfcp_unit *unit; | 133 | struct zfcp_unit *unit; |
134 | struct zfcp_send_els *send_els; | 134 | struct zfcp_send_els *send_els; |
135 | struct zfcp_hba_dbf_record *rec = &dbf->hba_dbf_buf; | 135 | struct zfcp_dbf_hba_record *rec = &dbf->hba_buf; |
136 | struct zfcp_hba_dbf_record_response *response = &rec->u.response; | 136 | struct zfcp_dbf_hba_record_response *response = &rec->u.response; |
137 | unsigned long flags; | 137 | unsigned long flags; |
138 | 138 | ||
139 | spin_lock_irqsave(&dbf->hba_dbf_lock, flags); | 139 | spin_lock_irqsave(&dbf->hba_lock, flags); |
140 | memset(rec, 0, sizeof(*rec)); | 140 | memset(rec, 0, sizeof(*rec)); |
141 | strncpy(rec->tag, "resp", ZFCP_DBF_TAG_SIZE); | 141 | strncpy(rec->tag, "resp", ZFCP_DBF_TAG_SIZE); |
142 | strncpy(rec->tag2, tag2, ZFCP_DBF_TAG_SIZE); | 142 | strncpy(rec->tag2, tag2, ZFCP_DBF_TAG_SIZE); |
@@ -203,7 +203,7 @@ void _zfcp_hba_dbf_event_fsf_response(const char *tag2, int level, | |||
203 | break; | 203 | break; |
204 | } | 204 | } |
205 | 205 | ||
206 | debug_event(dbf->hba_dbf, level, rec, sizeof(*rec)); | 206 | debug_event(dbf->hba, level, rec, sizeof(*rec)); |
207 | 207 | ||
208 | /* have fcp channel microcode fixed to use as little as possible */ | 208 | /* have fcp channel microcode fixed to use as little as possible */ |
209 | if (fsf_req->fsf_command != FSF_QTCB_FCP_CMND) { | 209 | if (fsf_req->fsf_command != FSF_QTCB_FCP_CMND) { |
@@ -211,27 +211,25 @@ void _zfcp_hba_dbf_event_fsf_response(const char *tag2, int level, | |||
211 | char *buf = (char *)qtcb + qtcb->header.log_start; | 211 | char *buf = (char *)qtcb + qtcb->header.log_start; |
212 | int len = qtcb->header.log_length; | 212 | int len = qtcb->header.log_length; |
213 | for (; len && !buf[len - 1]; len--); | 213 | for (; len && !buf[len - 1]; len--); |
214 | zfcp_dbf_hexdump(dbf->hba_dbf, rec, sizeof(*rec), level, buf, | 214 | zfcp_dbf_hexdump(dbf->hba, rec, sizeof(*rec), level, buf, |
215 | len); | 215 | len); |
216 | } | 216 | } |
217 | 217 | ||
218 | spin_unlock_irqrestore(&dbf->hba_dbf_lock, flags); | 218 | spin_unlock_irqrestore(&dbf->hba_lock, flags); |
219 | } | 219 | } |
220 | 220 | ||
221 | void _zfcp_hba_dbf_event_fsf_unsol(const char *tag, int level, | 221 | void _zfcp_dbf_hba_fsf_unsol(const char *tag, int level, struct zfcp_dbf *dbf, |
222 | struct zfcp_adapter *adapter, | 222 | struct fsf_status_read_buffer *status_buffer) |
223 | struct fsf_status_read_buffer *status_buffer) | ||
224 | { | 223 | { |
225 | struct zfcp_dbf *dbf = adapter->dbf; | 224 | struct zfcp_dbf_hba_record *rec = &dbf->hba_buf; |
226 | struct zfcp_hba_dbf_record *rec = &dbf->hba_dbf_buf; | ||
227 | unsigned long flags; | 225 | unsigned long flags; |
228 | 226 | ||
229 | spin_lock_irqsave(&dbf->hba_dbf_lock, flags); | 227 | spin_lock_irqsave(&dbf->hba_lock, flags); |
230 | memset(rec, 0, sizeof(*rec)); | 228 | memset(rec, 0, sizeof(*rec)); |
231 | strncpy(rec->tag, "stat", ZFCP_DBF_TAG_SIZE); | 229 | strncpy(rec->tag, "stat", ZFCP_DBF_TAG_SIZE); |
232 | strncpy(rec->tag2, tag, ZFCP_DBF_TAG_SIZE); | 230 | strncpy(rec->tag2, tag, ZFCP_DBF_TAG_SIZE); |
233 | 231 | ||
234 | rec->u.status.failed = atomic_read(&adapter->stat_miss); | 232 | rec->u.status.failed = atomic_read(&dbf->adapter->stat_miss); |
235 | if (status_buffer != NULL) { | 233 | if (status_buffer != NULL) { |
236 | rec->u.status.status_type = status_buffer->status_type; | 234 | rec->u.status.status_type = status_buffer->status_type; |
237 | rec->u.status.status_subtype = status_buffer->status_subtype; | 235 | rec->u.status.status_subtype = status_buffer->status_subtype; |
@@ -268,58 +266,54 @@ void _zfcp_hba_dbf_event_fsf_unsol(const char *tag, int level, | |||
268 | &status_buffer->payload, rec->u.status.payload_size); | 266 | &status_buffer->payload, rec->u.status.payload_size); |
269 | } | 267 | } |
270 | 268 | ||
271 | debug_event(dbf->hba_dbf, level, rec, sizeof(*rec)); | 269 | debug_event(dbf->hba, level, rec, sizeof(*rec)); |
272 | spin_unlock_irqrestore(&dbf->hba_dbf_lock, flags); | 270 | spin_unlock_irqrestore(&dbf->hba_lock, flags); |
273 | } | 271 | } |
274 | 272 | ||
275 | /** | 273 | /** |
276 | * zfcp_hba_dbf_event_qdio - trace event for QDIO related failure | 274 | * zfcp_dbf_hba_qdio - trace event for QDIO related failure |
277 | * @qdio: qdio structure affected by this QDIO related event | 275 | * @qdio: qdio structure affected by this QDIO related event |
278 | * @qdio_error: as passed by qdio module | 276 | * @qdio_error: as passed by qdio module |
279 | * @sbal_index: first buffer with error condition, as passed by qdio module | 277 | * @sbal_index: first buffer with error condition, as passed by qdio module |
280 | * @sbal_count: number of buffers affected, as passed by qdio module | 278 | * @sbal_count: number of buffers affected, as passed by qdio module |
281 | */ | 279 | */ |
282 | void zfcp_hba_dbf_event_qdio(struct zfcp_qdio *qdio, | 280 | void zfcp_dbf_hba_qdio(struct zfcp_dbf *dbf, unsigned int qdio_error, |
283 | unsigned int qdio_error, int sbal_index, | 281 | int sbal_index, int sbal_count) |
284 | int sbal_count) | ||
285 | { | 282 | { |
286 | struct zfcp_dbf *dbf = qdio->adapter->dbf; | 283 | struct zfcp_dbf_hba_record *r = &dbf->hba_buf; |
287 | struct zfcp_hba_dbf_record *r = &dbf->hba_dbf_buf; | ||
288 | unsigned long flags; | 284 | unsigned long flags; |
289 | 285 | ||
290 | spin_lock_irqsave(&dbf->hba_dbf_lock, flags); | 286 | spin_lock_irqsave(&dbf->hba_lock, flags); |
291 | memset(r, 0, sizeof(*r)); | 287 | memset(r, 0, sizeof(*r)); |
292 | strncpy(r->tag, "qdio", ZFCP_DBF_TAG_SIZE); | 288 | strncpy(r->tag, "qdio", ZFCP_DBF_TAG_SIZE); |
293 | r->u.qdio.qdio_error = qdio_error; | 289 | r->u.qdio.qdio_error = qdio_error; |
294 | r->u.qdio.sbal_index = sbal_index; | 290 | r->u.qdio.sbal_index = sbal_index; |
295 | r->u.qdio.sbal_count = sbal_count; | 291 | r->u.qdio.sbal_count = sbal_count; |
296 | debug_event(dbf->hba_dbf, 0, r, sizeof(*r)); | 292 | debug_event(dbf->hba, 0, r, sizeof(*r)); |
297 | spin_unlock_irqrestore(&dbf->hba_dbf_lock, flags); | 293 | spin_unlock_irqrestore(&dbf->hba_lock, flags); |
298 | } | 294 | } |
299 | 295 | ||
300 | /** | 296 | /** |
301 | * zfcp_hba_dbf_event_berr - trace event for bit error threshold | 297 | * zfcp_dbf_hba_berr - trace event for bit error threshold |
302 | * @adapter: adapter affected by this QDIO related event | 298 | * @dbf: dbf structure affected by this QDIO related event |
303 | * @req: fsf request | 299 | * @req: fsf request |
304 | */ | 300 | */ |
305 | void zfcp_hba_dbf_event_berr(struct zfcp_adapter *adapter, | 301 | void zfcp_dbf_hba_berr(struct zfcp_dbf *dbf, struct zfcp_fsf_req *req) |
306 | struct zfcp_fsf_req *req) | ||
307 | { | 302 | { |
308 | struct zfcp_dbf *dbf = adapter->dbf; | 303 | struct zfcp_dbf_hba_record *r = &dbf->hba_buf; |
309 | struct zfcp_hba_dbf_record *r = &dbf->hba_dbf_buf; | ||
310 | struct fsf_status_read_buffer *sr_buf = req->data; | 304 | struct fsf_status_read_buffer *sr_buf = req->data; |
311 | struct fsf_bit_error_payload *err = &sr_buf->payload.bit_error; | 305 | struct fsf_bit_error_payload *err = &sr_buf->payload.bit_error; |
312 | unsigned long flags; | 306 | unsigned long flags; |
313 | 307 | ||
314 | spin_lock_irqsave(&dbf->hba_dbf_lock, flags); | 308 | spin_lock_irqsave(&dbf->hba_lock, flags); |
315 | memset(r, 0, sizeof(*r)); | 309 | memset(r, 0, sizeof(*r)); |
316 | strncpy(r->tag, "berr", ZFCP_DBF_TAG_SIZE); | 310 | strncpy(r->tag, "berr", ZFCP_DBF_TAG_SIZE); |
317 | memcpy(&r->u.berr, err, sizeof(struct fsf_bit_error_payload)); | 311 | memcpy(&r->u.berr, err, sizeof(struct fsf_bit_error_payload)); |
318 | debug_event(dbf->hba_dbf, 0, r, sizeof(*r)); | 312 | debug_event(dbf->hba, 0, r, sizeof(*r)); |
319 | spin_unlock_irqrestore(&dbf->hba_dbf_lock, flags); | 313 | spin_unlock_irqrestore(&dbf->hba_lock, flags); |
320 | } | 314 | } |
321 | static void zfcp_hba_dbf_view_response(char **p, | 315 | static void zfcp_dbf_hba_view_response(char **p, |
322 | struct zfcp_hba_dbf_record_response *r) | 316 | struct zfcp_dbf_hba_record_response *r) |
323 | { | 317 | { |
324 | struct timespec t; | 318 | struct timespec t; |
325 | 319 | ||
@@ -380,8 +374,8 @@ static void zfcp_hba_dbf_view_response(char **p, | |||
380 | } | 374 | } |
381 | } | 375 | } |
382 | 376 | ||
383 | static void zfcp_hba_dbf_view_status(char **p, | 377 | static void zfcp_dbf_hba_view_status(char **p, |
384 | struct zfcp_hba_dbf_record_status *r) | 378 | struct zfcp_dbf_hba_record_status *r) |
385 | { | 379 | { |
386 | zfcp_dbf_out(p, "failed", "0x%02x", r->failed); | 380 | zfcp_dbf_out(p, "failed", "0x%02x", r->failed); |
387 | zfcp_dbf_out(p, "status_type", "0x%08x", r->status_type); | 381 | zfcp_dbf_out(p, "status_type", "0x%08x", r->status_type); |
@@ -393,14 +387,14 @@ static void zfcp_hba_dbf_view_status(char **p, | |||
393 | r->payload_size); | 387 | r->payload_size); |
394 | } | 388 | } |
395 | 389 | ||
396 | static void zfcp_hba_dbf_view_qdio(char **p, struct zfcp_hba_dbf_record_qdio *r) | 390 | static void zfcp_dbf_hba_view_qdio(char **p, struct zfcp_dbf_hba_record_qdio *r) |
397 | { | 391 | { |
398 | zfcp_dbf_out(p, "qdio_error", "0x%08x", r->qdio_error); | 392 | zfcp_dbf_out(p, "qdio_error", "0x%08x", r->qdio_error); |
399 | zfcp_dbf_out(p, "sbal_index", "0x%02x", r->sbal_index); | 393 | zfcp_dbf_out(p, "sbal_index", "0x%02x", r->sbal_index); |
400 | zfcp_dbf_out(p, "sbal_count", "0x%02x", r->sbal_count); | 394 | zfcp_dbf_out(p, "sbal_count", "0x%02x", r->sbal_count); |
401 | } | 395 | } |
402 | 396 | ||
403 | static void zfcp_hba_dbf_view_berr(char **p, struct fsf_bit_error_payload *r) | 397 | static void zfcp_dbf_hba_view_berr(char **p, struct fsf_bit_error_payload *r) |
404 | { | 398 | { |
405 | zfcp_dbf_out(p, "link_failures", "%d", r->link_failure_error_count); | 399 | zfcp_dbf_out(p, "link_failures", "%d", r->link_failure_error_count); |
406 | zfcp_dbf_out(p, "loss_of_sync_err", "%d", r->loss_of_sync_error_count); | 400 | zfcp_dbf_out(p, "loss_of_sync_err", "%d", r->loss_of_sync_error_count); |
@@ -424,10 +418,10 @@ static void zfcp_hba_dbf_view_berr(char **p, struct fsf_bit_error_payload *r) | |||
424 | r->current_transmit_b2b_credit); | 418 | r->current_transmit_b2b_credit); |
425 | } | 419 | } |
426 | 420 | ||
427 | static int zfcp_hba_dbf_view_format(debug_info_t *id, struct debug_view *view, | 421 | static int zfcp_dbf_hba_view_format(debug_info_t *id, struct debug_view *view, |
428 | char *out_buf, const char *in_buf) | 422 | char *out_buf, const char *in_buf) |
429 | { | 423 | { |
430 | struct zfcp_hba_dbf_record *r = (struct zfcp_hba_dbf_record *)in_buf; | 424 | struct zfcp_dbf_hba_record *r = (struct zfcp_dbf_hba_record *)in_buf; |
431 | char *p = out_buf; | 425 | char *p = out_buf; |
432 | 426 | ||
433 | if (strncmp(r->tag, "dump", ZFCP_DBF_TAG_SIZE) == 0) | 427 | if (strncmp(r->tag, "dump", ZFCP_DBF_TAG_SIZE) == 0) |
@@ -438,45 +432,42 @@ static int zfcp_hba_dbf_view_format(debug_info_t *id, struct debug_view *view, | |||
438 | zfcp_dbf_tag(&p, "tag2", r->tag2); | 432 | zfcp_dbf_tag(&p, "tag2", r->tag2); |
439 | 433 | ||
440 | if (strncmp(r->tag, "resp", ZFCP_DBF_TAG_SIZE) == 0) | 434 | if (strncmp(r->tag, "resp", ZFCP_DBF_TAG_SIZE) == 0) |
441 | zfcp_hba_dbf_view_response(&p, &r->u.response); | 435 | zfcp_dbf_hba_view_response(&p, &r->u.response); |
442 | else if (strncmp(r->tag, "stat", ZFCP_DBF_TAG_SIZE) == 0) | 436 | else if (strncmp(r->tag, "stat", ZFCP_DBF_TAG_SIZE) == 0) |
443 | zfcp_hba_dbf_view_status(&p, &r->u.status); | 437 | zfcp_dbf_hba_view_status(&p, &r->u.status); |
444 | else if (strncmp(r->tag, "qdio", ZFCP_DBF_TAG_SIZE) == 0) | 438 | else if (strncmp(r->tag, "qdio", ZFCP_DBF_TAG_SIZE) == 0) |
445 | zfcp_hba_dbf_view_qdio(&p, &r->u.qdio); | 439 | zfcp_dbf_hba_view_qdio(&p, &r->u.qdio); |
446 | else if (strncmp(r->tag, "berr", ZFCP_DBF_TAG_SIZE) == 0) | 440 | else if (strncmp(r->tag, "berr", ZFCP_DBF_TAG_SIZE) == 0) |
447 | zfcp_hba_dbf_view_berr(&p, &r->u.berr); | 441 | zfcp_dbf_hba_view_berr(&p, &r->u.berr); |
448 | 442 | ||
449 | if (strncmp(r->tag, "resp", ZFCP_DBF_TAG_SIZE) != 0) | 443 | if (strncmp(r->tag, "resp", ZFCP_DBF_TAG_SIZE) != 0) |
450 | p += sprintf(p, "\n"); | 444 | p += sprintf(p, "\n"); |
451 | return p - out_buf; | 445 | return p - out_buf; |
452 | } | 446 | } |
453 | 447 | ||
454 | static struct debug_view zfcp_hba_dbf_view = { | 448 | static struct debug_view zfcp_dbf_hba_view = { |
455 | "structured", | 449 | .name = "structured", |
456 | NULL, | 450 | .header_proc = zfcp_dbf_view_header, |
457 | &zfcp_dbf_view_header, | 451 | .format_proc = zfcp_dbf_hba_view_format, |
458 | &zfcp_hba_dbf_view_format, | ||
459 | NULL, | ||
460 | NULL | ||
461 | }; | 452 | }; |
462 | 453 | ||
463 | static const char *zfcp_rec_dbf_tags[] = { | 454 | static const char *zfcp_dbf_rec_tags[] = { |
464 | [ZFCP_REC_DBF_ID_THREAD] = "thread", | 455 | [ZFCP_REC_DBF_ID_THREAD] = "thread", |
465 | [ZFCP_REC_DBF_ID_TARGET] = "target", | 456 | [ZFCP_REC_DBF_ID_TARGET] = "target", |
466 | [ZFCP_REC_DBF_ID_TRIGGER] = "trigger", | 457 | [ZFCP_REC_DBF_ID_TRIGGER] = "trigger", |
467 | [ZFCP_REC_DBF_ID_ACTION] = "action", | 458 | [ZFCP_REC_DBF_ID_ACTION] = "action", |
468 | }; | 459 | }; |
469 | 460 | ||
470 | static int zfcp_rec_dbf_view_format(debug_info_t *id, struct debug_view *view, | 461 | static int zfcp_dbf_rec_view_format(debug_info_t *id, struct debug_view *view, |
471 | char *buf, const char *_rec) | 462 | char *buf, const char *_rec) |
472 | { | 463 | { |
473 | struct zfcp_rec_dbf_record *r = (struct zfcp_rec_dbf_record *)_rec; | 464 | struct zfcp_dbf_rec_record *r = (struct zfcp_dbf_rec_record *)_rec; |
474 | char *p = buf; | 465 | char *p = buf; |
475 | char hint[ZFCP_DBF_ID_SIZE + 1]; | 466 | char hint[ZFCP_DBF_ID_SIZE + 1]; |
476 | 467 | ||
477 | memcpy(hint, r->id2, ZFCP_DBF_ID_SIZE); | 468 | memcpy(hint, r->id2, ZFCP_DBF_ID_SIZE); |
478 | hint[ZFCP_DBF_ID_SIZE] = 0; | 469 | hint[ZFCP_DBF_ID_SIZE] = 0; |
479 | zfcp_dbf_outs(&p, "tag", zfcp_rec_dbf_tags[r->id]); | 470 | zfcp_dbf_outs(&p, "tag", zfcp_dbf_rec_tags[r->id]); |
480 | zfcp_dbf_outs(&p, "hint", hint); | 471 | zfcp_dbf_outs(&p, "hint", hint); |
481 | switch (r->id) { | 472 | switch (r->id) { |
482 | case ZFCP_REC_DBF_ID_THREAD: | 473 | case ZFCP_REC_DBF_ID_THREAD: |
@@ -514,25 +505,22 @@ static int zfcp_rec_dbf_view_format(debug_info_t *id, struct debug_view *view, | |||
514 | return p - buf; | 505 | return p - buf; |
515 | } | 506 | } |
516 | 507 | ||
517 | static struct debug_view zfcp_rec_dbf_view = { | 508 | static struct debug_view zfcp_dbf_rec_view = { |
518 | "structured", | 509 | .name = "structured", |
519 | NULL, | 510 | .header_proc = zfcp_dbf_view_header, |
520 | &zfcp_dbf_view_header, | 511 | .format_proc = zfcp_dbf_rec_view_format, |
521 | &zfcp_rec_dbf_view_format, | ||
522 | NULL, | ||
523 | NULL | ||
524 | }; | 512 | }; |
525 | 513 | ||
526 | /** | 514 | /** |
527 | * zfcp_rec_dbf_event_thread - trace event related to recovery thread operation | 515 | * zfcp_dbf_rec_thread - trace event related to recovery thread operation |
528 | * @id2: identifier for event | 516 | * @id2: identifier for event |
529 | * @adapter: adapter | 517 | * @dbf: reference to dbf structure |
530 | * This function assumes that the caller is holding erp_lock. | 518 | * This function assumes that the caller is holding erp_lock. |
531 | */ | 519 | */ |
532 | void zfcp_rec_dbf_event_thread(char *id2, struct zfcp_adapter *adapter) | 520 | void zfcp_dbf_rec_thread(char *id2, struct zfcp_dbf *dbf) |
533 | { | 521 | { |
534 | struct zfcp_dbf *dbf = adapter->dbf; | 522 | struct zfcp_adapter *adapter = dbf->adapter; |
535 | struct zfcp_rec_dbf_record *r = &dbf->rec_dbf_buf; | 523 | struct zfcp_dbf_rec_record *r = &dbf->rec_buf; |
536 | unsigned long flags = 0; | 524 | unsigned long flags = 0; |
537 | struct list_head *entry; | 525 | struct list_head *entry; |
538 | unsigned ready = 0, running = 0, total; | 526 | unsigned ready = 0, running = 0, total; |
@@ -543,42 +531,41 @@ void zfcp_rec_dbf_event_thread(char *id2, struct zfcp_adapter *adapter) | |||
543 | running++; | 531 | running++; |
544 | total = adapter->erp_total_count; | 532 | total = adapter->erp_total_count; |
545 | 533 | ||
546 | spin_lock_irqsave(&dbf->rec_dbf_lock, flags); | 534 | spin_lock_irqsave(&dbf->rec_lock, flags); |
547 | memset(r, 0, sizeof(*r)); | 535 | memset(r, 0, sizeof(*r)); |
548 | r->id = ZFCP_REC_DBF_ID_THREAD; | 536 | r->id = ZFCP_REC_DBF_ID_THREAD; |
549 | memcpy(r->id2, id2, ZFCP_DBF_ID_SIZE); | 537 | memcpy(r->id2, id2, ZFCP_DBF_ID_SIZE); |
550 | r->u.thread.total = total; | 538 | r->u.thread.total = total; |
551 | r->u.thread.ready = ready; | 539 | r->u.thread.ready = ready; |
552 | r->u.thread.running = running; | 540 | r->u.thread.running = running; |
553 | debug_event(dbf->rec_dbf, 6, r, sizeof(*r)); | 541 | debug_event(dbf->rec, 6, r, sizeof(*r)); |
554 | spin_unlock_irqrestore(&dbf->rec_dbf_lock, flags); | 542 | spin_unlock_irqrestore(&dbf->rec_lock, flags); |
555 | } | 543 | } |
556 | 544 | ||
557 | /** | 545 | /** |
558 | * zfcp_rec_dbf_event_thread - trace event related to recovery thread operation | 546 | * zfcp_dbf_rec_thread - trace event related to recovery thread operation |
559 | * @id2: identifier for event | 547 | * @id2: identifier for event |
560 | * @adapter: adapter | 548 | * @adapter: adapter |
561 | * This function assumes that the caller does not hold erp_lock. | 549 | * This function assumes that the caller does not hold erp_lock. |
562 | */ | 550 | */ |
563 | void zfcp_rec_dbf_event_thread_lock(char *id2, struct zfcp_adapter *adapter) | 551 | void zfcp_dbf_rec_thread_lock(char *id2, struct zfcp_dbf *dbf) |
564 | { | 552 | { |
553 | struct zfcp_adapter *adapter = dbf->adapter; | ||
565 | unsigned long flags; | 554 | unsigned long flags; |
566 | 555 | ||
567 | read_lock_irqsave(&adapter->erp_lock, flags); | 556 | read_lock_irqsave(&adapter->erp_lock, flags); |
568 | zfcp_rec_dbf_event_thread(id2, adapter); | 557 | zfcp_dbf_rec_thread(id2, dbf); |
569 | read_unlock_irqrestore(&adapter->erp_lock, flags); | 558 | read_unlock_irqrestore(&adapter->erp_lock, flags); |
570 | } | 559 | } |
571 | 560 | ||
572 | static void zfcp_rec_dbf_event_target(char *id2, void *ref, | 561 | static void zfcp_dbf_rec_target(char *id2, void *ref, struct zfcp_dbf *dbf, |
573 | struct zfcp_adapter *adapter, | 562 | atomic_t *status, atomic_t *erp_count, u64 wwpn, |
574 | atomic_t *status, atomic_t *erp_count, | 563 | u32 d_id, u64 fcp_lun) |
575 | u64 wwpn, u32 d_id, u64 fcp_lun) | ||
576 | { | 564 | { |
577 | struct zfcp_dbf *dbf = adapter->dbf; | 565 | struct zfcp_dbf_rec_record *r = &dbf->rec_buf; |
578 | struct zfcp_rec_dbf_record *r = &dbf->rec_dbf_buf; | ||
579 | unsigned long flags; | 566 | unsigned long flags; |
580 | 567 | ||
581 | spin_lock_irqsave(&dbf->rec_dbf_lock, flags); | 568 | spin_lock_irqsave(&dbf->rec_lock, flags); |
582 | memset(r, 0, sizeof(*r)); | 569 | memset(r, 0, sizeof(*r)); |
583 | r->id = ZFCP_REC_DBF_ID_TARGET; | 570 | r->id = ZFCP_REC_DBF_ID_TARGET; |
584 | memcpy(r->id2, id2, ZFCP_DBF_ID_SIZE); | 571 | memcpy(r->id2, id2, ZFCP_DBF_ID_SIZE); |
@@ -588,56 +575,57 @@ static void zfcp_rec_dbf_event_target(char *id2, void *ref, | |||
588 | r->u.target.d_id = d_id; | 575 | r->u.target.d_id = d_id; |
589 | r->u.target.fcp_lun = fcp_lun; | 576 | r->u.target.fcp_lun = fcp_lun; |
590 | r->u.target.erp_count = atomic_read(erp_count); | 577 | r->u.target.erp_count = atomic_read(erp_count); |
591 | debug_event(dbf->rec_dbf, 3, r, sizeof(*r)); | 578 | debug_event(dbf->rec, 3, r, sizeof(*r)); |
592 | spin_unlock_irqrestore(&dbf->rec_dbf_lock, flags); | 579 | spin_unlock_irqrestore(&dbf->rec_lock, flags); |
593 | } | 580 | } |
594 | 581 | ||
595 | /** | 582 | /** |
596 | * zfcp_rec_dbf_event_adapter - trace event for adapter state change | 583 | * zfcp_dbf_rec_adapter - trace event for adapter state change |
597 | * @id: identifier for trigger of state change | 584 | * @id: identifier for trigger of state change |
598 | * @ref: additional reference (e.g. request) | 585 | * @ref: additional reference (e.g. request) |
599 | * @adapter: adapter | 586 | * @dbf: reference to dbf structure |
600 | */ | 587 | */ |
601 | void zfcp_rec_dbf_event_adapter(char *id, void *ref, | 588 | void zfcp_dbf_rec_adapter(char *id, void *ref, struct zfcp_dbf *dbf) |
602 | struct zfcp_adapter *adapter) | ||
603 | { | 589 | { |
604 | zfcp_rec_dbf_event_target(id, ref, adapter, &adapter->status, | 590 | struct zfcp_adapter *adapter = dbf->adapter; |
591 | |||
592 | zfcp_dbf_rec_target(id, ref, dbf, &adapter->status, | ||
605 | &adapter->erp_counter, 0, 0, 0); | 593 | &adapter->erp_counter, 0, 0, 0); |
606 | } | 594 | } |
607 | 595 | ||
608 | /** | 596 | /** |
609 | * zfcp_rec_dbf_event_port - trace event for port state change | 597 | * zfcp_dbf_rec_port - trace event for port state change |
610 | * @id: identifier for trigger of state change | 598 | * @id: identifier for trigger of state change |
611 | * @ref: additional reference (e.g. request) | 599 | * @ref: additional reference (e.g. request) |
612 | * @port: port | 600 | * @port: port |
613 | */ | 601 | */ |
614 | void zfcp_rec_dbf_event_port(char *id, void *ref, struct zfcp_port *port) | 602 | void zfcp_dbf_rec_port(char *id, void *ref, struct zfcp_port *port) |
615 | { | 603 | { |
616 | struct zfcp_adapter *adapter = port->adapter; | 604 | struct zfcp_dbf *dbf = port->adapter->dbf; |
617 | 605 | ||
618 | zfcp_rec_dbf_event_target(id, ref, adapter, &port->status, | 606 | zfcp_dbf_rec_target(id, ref, dbf, &port->status, |
619 | &port->erp_counter, port->wwpn, port->d_id, | 607 | &port->erp_counter, port->wwpn, port->d_id, |
620 | 0); | 608 | 0); |
621 | } | 609 | } |
622 | 610 | ||
623 | /** | 611 | /** |
624 | * zfcp_rec_dbf_event_unit - trace event for unit state change | 612 | * zfcp_dbf_rec_unit - trace event for unit state change |
625 | * @id: identifier for trigger of state change | 613 | * @id: identifier for trigger of state change |
626 | * @ref: additional reference (e.g. request) | 614 | * @ref: additional reference (e.g. request) |
627 | * @unit: unit | 615 | * @unit: unit |
628 | */ | 616 | */ |
629 | void zfcp_rec_dbf_event_unit(char *id, void *ref, struct zfcp_unit *unit) | 617 | void zfcp_dbf_rec_unit(char *id, void *ref, struct zfcp_unit *unit) |
630 | { | 618 | { |
631 | struct zfcp_port *port = unit->port; | 619 | struct zfcp_port *port = unit->port; |
632 | struct zfcp_adapter *adapter = port->adapter; | 620 | struct zfcp_dbf *dbf = port->adapter->dbf; |
633 | 621 | ||
634 | zfcp_rec_dbf_event_target(id, ref, adapter, &unit->status, | 622 | zfcp_dbf_rec_target(id, ref, dbf, &unit->status, |
635 | &unit->erp_counter, port->wwpn, port->d_id, | 623 | &unit->erp_counter, port->wwpn, port->d_id, |
636 | unit->fcp_lun); | 624 | unit->fcp_lun); |
637 | } | 625 | } |
638 | 626 | ||
639 | /** | 627 | /** |
640 | * zfcp_rec_dbf_event_trigger - trace event for triggered error recovery | 628 | * zfcp_dbf_rec_trigger - trace event for triggered error recovery |
641 | * @id2: identifier for error recovery trigger | 629 | * @id2: identifier for error recovery trigger |
642 | * @ref: additional reference (e.g. request) | 630 | * @ref: additional reference (e.g. request) |
643 | * @want: originally requested error recovery action | 631 | * @want: originally requested error recovery action |
@@ -647,15 +635,15 @@ void zfcp_rec_dbf_event_unit(char *id, void *ref, struct zfcp_unit *unit) | |||
647 | * @port: port | 635 | * @port: port |
648 | * @unit: unit | 636 | * @unit: unit |
649 | */ | 637 | */ |
650 | void zfcp_rec_dbf_event_trigger(char *id2, void *ref, u8 want, u8 need, | 638 | void zfcp_dbf_rec_trigger(char *id2, void *ref, u8 want, u8 need, void *action, |
651 | void *action, struct zfcp_adapter *adapter, | 639 | struct zfcp_adapter *adapter, struct zfcp_port *port, |
652 | struct zfcp_port *port, struct zfcp_unit *unit) | 640 | struct zfcp_unit *unit) |
653 | { | 641 | { |
654 | struct zfcp_dbf *dbf = adapter->dbf; | 642 | struct zfcp_dbf *dbf = adapter->dbf; |
655 | struct zfcp_rec_dbf_record *r = &dbf->rec_dbf_buf; | 643 | struct zfcp_dbf_rec_record *r = &dbf->rec_buf; |
656 | unsigned long flags; | 644 | unsigned long flags; |
657 | 645 | ||
658 | spin_lock_irqsave(&dbf->rec_dbf_lock, flags); | 646 | spin_lock_irqsave(&dbf->rec_lock, flags); |
659 | memset(r, 0, sizeof(*r)); | 647 | memset(r, 0, sizeof(*r)); |
660 | r->id = ZFCP_REC_DBF_ID_TRIGGER; | 648 | r->id = ZFCP_REC_DBF_ID_TRIGGER; |
661 | memcpy(r->id2, id2, ZFCP_DBF_ID_SIZE); | 649 | memcpy(r->id2, id2, ZFCP_DBF_ID_SIZE); |
@@ -672,23 +660,22 @@ void zfcp_rec_dbf_event_trigger(char *id2, void *ref, u8 want, u8 need, | |||
672 | r->u.trigger.us = atomic_read(&unit->status); | 660 | r->u.trigger.us = atomic_read(&unit->status); |
673 | r->u.trigger.fcp_lun = unit->fcp_lun; | 661 | r->u.trigger.fcp_lun = unit->fcp_lun; |
674 | } | 662 | } |
675 | debug_event(dbf->rec_dbf, action ? 1 : 4, r, sizeof(*r)); | 663 | debug_event(dbf->rec, action ? 1 : 4, r, sizeof(*r)); |
676 | spin_unlock_irqrestore(&dbf->rec_dbf_lock, flags); | 664 | spin_unlock_irqrestore(&dbf->rec_lock, flags); |
677 | } | 665 | } |
678 | 666 | ||
679 | /** | 667 | /** |
680 | * zfcp_rec_dbf_event_action - trace event showing progress of recovery action | 668 | * zfcp_dbf_rec_action - trace event showing progress of recovery action |
681 | * @id2: identifier | 669 | * @id2: identifier |
682 | * @erp_action: error recovery action struct pointer | 670 | * @erp_action: error recovery action struct pointer |
683 | */ | 671 | */ |
684 | void zfcp_rec_dbf_event_action(char *id2, struct zfcp_erp_action *erp_action) | 672 | void zfcp_dbf_rec_action(char *id2, struct zfcp_erp_action *erp_action) |
685 | { | 673 | { |
686 | struct zfcp_adapter *adapter = erp_action->adapter; | 674 | struct zfcp_dbf *dbf = erp_action->adapter->dbf; |
687 | struct zfcp_dbf *dbf = adapter->dbf; | 675 | struct zfcp_dbf_rec_record *r = &dbf->rec_buf; |
688 | struct zfcp_rec_dbf_record *r = &dbf->rec_dbf_buf; | ||
689 | unsigned long flags; | 676 | unsigned long flags; |
690 | 677 | ||
691 | spin_lock_irqsave(&dbf->rec_dbf_lock, flags); | 678 | spin_lock_irqsave(&dbf->rec_lock, flags); |
692 | memset(r, 0, sizeof(*r)); | 679 | memset(r, 0, sizeof(*r)); |
693 | r->id = ZFCP_REC_DBF_ID_ACTION; | 680 | r->id = ZFCP_REC_DBF_ID_ACTION; |
694 | memcpy(r->id2, id2, ZFCP_DBF_ID_SIZE); | 681 | memcpy(r->id2, id2, ZFCP_DBF_ID_SIZE); |
@@ -696,27 +683,27 @@ void zfcp_rec_dbf_event_action(char *id2, struct zfcp_erp_action *erp_action) | |||
696 | r->u.action.status = erp_action->status; | 683 | r->u.action.status = erp_action->status; |
697 | r->u.action.step = erp_action->step; | 684 | r->u.action.step = erp_action->step; |
698 | r->u.action.fsf_req = (unsigned long)erp_action->fsf_req; | 685 | r->u.action.fsf_req = (unsigned long)erp_action->fsf_req; |
699 | debug_event(dbf->rec_dbf, 5, r, sizeof(*r)); | 686 | debug_event(dbf->rec, 5, r, sizeof(*r)); |
700 | spin_unlock_irqrestore(&dbf->rec_dbf_lock, flags); | 687 | spin_unlock_irqrestore(&dbf->rec_lock, flags); |
701 | } | 688 | } |
702 | 689 | ||
703 | /** | 690 | /** |
704 | * zfcp_san_dbf_event_ct_request - trace event for issued CT request | 691 | * zfcp_dbf_san_ct_request - trace event for issued CT request |
705 | * @fsf_req: request containing issued CT data | 692 | * @fsf_req: request containing issued CT data |
706 | */ | 693 | */ |
707 | void zfcp_san_dbf_event_ct_request(struct zfcp_fsf_req *fsf_req) | 694 | void zfcp_dbf_san_ct_request(struct zfcp_fsf_req *fsf_req) |
708 | { | 695 | { |
709 | struct zfcp_send_ct *ct = (struct zfcp_send_ct *)fsf_req->data; | 696 | struct zfcp_send_ct *ct = (struct zfcp_send_ct *)fsf_req->data; |
710 | struct zfcp_wka_port *wka_port = ct->wka_port; | 697 | struct zfcp_wka_port *wka_port = ct->wka_port; |
711 | struct zfcp_adapter *adapter = wka_port->adapter; | 698 | struct zfcp_adapter *adapter = wka_port->adapter; |
712 | struct zfcp_dbf *dbf = adapter->dbf; | 699 | struct zfcp_dbf *dbf = adapter->dbf; |
713 | struct ct_hdr *hdr = sg_virt(ct->req); | 700 | struct ct_hdr *hdr = sg_virt(ct->req); |
714 | struct zfcp_san_dbf_record *r = &dbf->san_dbf_buf; | 701 | struct zfcp_dbf_san_record *r = &dbf->san_buf; |
715 | struct zfcp_san_dbf_record_ct_request *oct = &r->u.ct_req; | 702 | struct zfcp_dbf_san_record_ct_request *oct = &r->u.ct_req; |
716 | int level = 3; | 703 | int level = 3; |
717 | unsigned long flags; | 704 | unsigned long flags; |
718 | 705 | ||
719 | spin_lock_irqsave(&dbf->san_dbf_lock, flags); | 706 | spin_lock_irqsave(&dbf->san_lock, flags); |
720 | memset(r, 0, sizeof(*r)); | 707 | memset(r, 0, sizeof(*r)); |
721 | strncpy(r->tag, "octc", ZFCP_DBF_TAG_SIZE); | 708 | strncpy(r->tag, "octc", ZFCP_DBF_TAG_SIZE); |
722 | r->fsf_reqid = fsf_req->req_id; | 709 | r->fsf_reqid = fsf_req->req_id; |
@@ -731,29 +718,29 @@ void zfcp_san_dbf_event_ct_request(struct zfcp_fsf_req *fsf_req) | |||
731 | oct->max_res_size = hdr->max_res_size; | 718 | oct->max_res_size = hdr->max_res_size; |
732 | oct->len = min((int)ct->req->length - (int)sizeof(struct ct_hdr), | 719 | oct->len = min((int)ct->req->length - (int)sizeof(struct ct_hdr), |
733 | ZFCP_DBF_SAN_MAX_PAYLOAD); | 720 | ZFCP_DBF_SAN_MAX_PAYLOAD); |
734 | debug_event(dbf->san_dbf, level, r, sizeof(*r)); | 721 | debug_event(dbf->san, level, r, sizeof(*r)); |
735 | zfcp_dbf_hexdump(dbf->san_dbf, r, sizeof(*r), level, | 722 | zfcp_dbf_hexdump(dbf->san, r, sizeof(*r), level, |
736 | (void *)hdr + sizeof(struct ct_hdr), oct->len); | 723 | (void *)hdr + sizeof(struct ct_hdr), oct->len); |
737 | spin_unlock_irqrestore(&dbf->san_dbf_lock, flags); | 724 | spin_unlock_irqrestore(&dbf->san_lock, flags); |
738 | } | 725 | } |
739 | 726 | ||
740 | /** | 727 | /** |
741 | * zfcp_san_dbf_event_ct_response - trace event for completion of CT request | 728 | * zfcp_dbf_san_ct_response - trace event for completion of CT request |
742 | * @fsf_req: request containing CT response | 729 | * @fsf_req: request containing CT response |
743 | */ | 730 | */ |
744 | void zfcp_san_dbf_event_ct_response(struct zfcp_fsf_req *fsf_req) | 731 | void zfcp_dbf_san_ct_response(struct zfcp_fsf_req *fsf_req) |
745 | { | 732 | { |
746 | struct zfcp_send_ct *ct = (struct zfcp_send_ct *)fsf_req->data; | 733 | struct zfcp_send_ct *ct = (struct zfcp_send_ct *)fsf_req->data; |
747 | struct zfcp_wka_port *wka_port = ct->wka_port; | 734 | struct zfcp_wka_port *wka_port = ct->wka_port; |
748 | struct zfcp_adapter *adapter = wka_port->adapter; | 735 | struct zfcp_adapter *adapter = wka_port->adapter; |
749 | struct ct_hdr *hdr = sg_virt(ct->resp); | 736 | struct ct_hdr *hdr = sg_virt(ct->resp); |
750 | struct zfcp_dbf *dbf = adapter->dbf; | 737 | struct zfcp_dbf *dbf = adapter->dbf; |
751 | struct zfcp_san_dbf_record *r = &dbf->san_dbf_buf; | 738 | struct zfcp_dbf_san_record *r = &dbf->san_buf; |
752 | struct zfcp_san_dbf_record_ct_response *rct = &r->u.ct_resp; | 739 | struct zfcp_dbf_san_record_ct_response *rct = &r->u.ct_resp; |
753 | int level = 3; | 740 | int level = 3; |
754 | unsigned long flags; | 741 | unsigned long flags; |
755 | 742 | ||
756 | spin_lock_irqsave(&dbf->san_dbf_lock, flags); | 743 | spin_lock_irqsave(&dbf->san_lock, flags); |
757 | memset(r, 0, sizeof(*r)); | 744 | memset(r, 0, sizeof(*r)); |
758 | strncpy(r->tag, "rctc", ZFCP_DBF_TAG_SIZE); | 745 | strncpy(r->tag, "rctc", ZFCP_DBF_TAG_SIZE); |
759 | r->fsf_reqid = fsf_req->req_id; | 746 | r->fsf_reqid = fsf_req->req_id; |
@@ -768,23 +755,22 @@ void zfcp_san_dbf_event_ct_response(struct zfcp_fsf_req *fsf_req) | |||
768 | rct->max_res_size = hdr->max_res_size; | 755 | rct->max_res_size = hdr->max_res_size; |
769 | rct->len = min((int)ct->resp->length - (int)sizeof(struct ct_hdr), | 756 | rct->len = min((int)ct->resp->length - (int)sizeof(struct ct_hdr), |
770 | ZFCP_DBF_SAN_MAX_PAYLOAD); | 757 | ZFCP_DBF_SAN_MAX_PAYLOAD); |
771 | debug_event(dbf->san_dbf, level, r, sizeof(*r)); | 758 | debug_event(dbf->san, level, r, sizeof(*r)); |
772 | zfcp_dbf_hexdump(dbf->san_dbf, r, sizeof(*r), level, | 759 | zfcp_dbf_hexdump(dbf->san, r, sizeof(*r), level, |
773 | (void *)hdr + sizeof(struct ct_hdr), rct->len); | 760 | (void *)hdr + sizeof(struct ct_hdr), rct->len); |
774 | spin_unlock_irqrestore(&dbf->san_dbf_lock, flags); | 761 | spin_unlock_irqrestore(&dbf->san_lock, flags); |
775 | } | 762 | } |
776 | 763 | ||
777 | static void zfcp_san_dbf_event_els(const char *tag, int level, | 764 | static void zfcp_dbf_san_els(const char *tag, int level, |
778 | struct zfcp_fsf_req *fsf_req, u32 s_id, | 765 | struct zfcp_fsf_req *fsf_req, u32 s_id, u32 d_id, |
779 | u32 d_id, u8 ls_code, void *buffer, | 766 | u8 ls_code, void *buffer, int buflen) |
780 | int buflen) | ||
781 | { | 767 | { |
782 | struct zfcp_adapter *adapter = fsf_req->adapter; | 768 | struct zfcp_adapter *adapter = fsf_req->adapter; |
783 | struct zfcp_dbf *dbf = adapter->dbf; | 769 | struct zfcp_dbf *dbf = adapter->dbf; |
784 | struct zfcp_san_dbf_record *rec = &dbf->san_dbf_buf; | 770 | struct zfcp_dbf_san_record *rec = &dbf->san_buf; |
785 | unsigned long flags; | 771 | unsigned long flags; |
786 | 772 | ||
787 | spin_lock_irqsave(&dbf->san_dbf_lock, flags); | 773 | spin_lock_irqsave(&dbf->san_lock, flags); |
788 | memset(rec, 0, sizeof(*rec)); | 774 | memset(rec, 0, sizeof(*rec)); |
789 | strncpy(rec->tag, tag, ZFCP_DBF_TAG_SIZE); | 775 | strncpy(rec->tag, tag, ZFCP_DBF_TAG_SIZE); |
790 | rec->fsf_reqid = fsf_req->req_id; | 776 | rec->fsf_reqid = fsf_req->req_id; |
@@ -792,45 +778,45 @@ static void zfcp_san_dbf_event_els(const char *tag, int level, | |||
792 | rec->s_id = s_id; | 778 | rec->s_id = s_id; |
793 | rec->d_id = d_id; | 779 | rec->d_id = d_id; |
794 | rec->u.els.ls_code = ls_code; | 780 | rec->u.els.ls_code = ls_code; |
795 | debug_event(dbf->san_dbf, level, rec, sizeof(*rec)); | 781 | debug_event(dbf->san, level, rec, sizeof(*rec)); |
796 | zfcp_dbf_hexdump(dbf->san_dbf, rec, sizeof(*rec), level, | 782 | zfcp_dbf_hexdump(dbf->san, rec, sizeof(*rec), level, |
797 | buffer, min(buflen, ZFCP_DBF_SAN_MAX_PAYLOAD)); | 783 | buffer, min(buflen, ZFCP_DBF_SAN_MAX_PAYLOAD)); |
798 | spin_unlock_irqrestore(&dbf->san_dbf_lock, flags); | 784 | spin_unlock_irqrestore(&dbf->san_lock, flags); |
799 | } | 785 | } |
800 | 786 | ||
801 | /** | 787 | /** |
802 | * zfcp_san_dbf_event_els_request - trace event for issued ELS | 788 | * zfcp_dbf_san_els_request - trace event for issued ELS |
803 | * @fsf_req: request containing issued ELS | 789 | * @fsf_req: request containing issued ELS |
804 | */ | 790 | */ |
805 | void zfcp_san_dbf_event_els_request(struct zfcp_fsf_req *fsf_req) | 791 | void zfcp_dbf_san_els_request(struct zfcp_fsf_req *fsf_req) |
806 | { | 792 | { |
807 | struct zfcp_send_els *els = (struct zfcp_send_els *)fsf_req->data; | 793 | struct zfcp_send_els *els = (struct zfcp_send_els *)fsf_req->data; |
808 | 794 | ||
809 | zfcp_san_dbf_event_els("oels", 2, fsf_req, | 795 | zfcp_dbf_san_els("oels", 2, fsf_req, |
810 | fc_host_port_id(els->adapter->scsi_host), | 796 | fc_host_port_id(els->adapter->scsi_host), |
811 | els->d_id, *(u8 *) sg_virt(els->req), | 797 | els->d_id, *(u8 *) sg_virt(els->req), |
812 | sg_virt(els->req), els->req->length); | 798 | sg_virt(els->req), els->req->length); |
813 | } | 799 | } |
814 | 800 | ||
815 | /** | 801 | /** |
816 | * zfcp_san_dbf_event_els_response - trace event for completed ELS | 802 | * zfcp_dbf_san_els_response - trace event for completed ELS |
817 | * @fsf_req: request containing ELS response | 803 | * @fsf_req: request containing ELS response |
818 | */ | 804 | */ |
819 | void zfcp_san_dbf_event_els_response(struct zfcp_fsf_req *fsf_req) | 805 | void zfcp_dbf_san_els_response(struct zfcp_fsf_req *fsf_req) |
820 | { | 806 | { |
821 | struct zfcp_send_els *els = (struct zfcp_send_els *)fsf_req->data; | 807 | struct zfcp_send_els *els = (struct zfcp_send_els *)fsf_req->data; |
822 | 808 | ||
823 | zfcp_san_dbf_event_els("rels", 2, fsf_req, els->d_id, | 809 | zfcp_dbf_san_els("rels", 2, fsf_req, els->d_id, |
824 | fc_host_port_id(els->adapter->scsi_host), | 810 | fc_host_port_id(els->adapter->scsi_host), |
825 | *(u8 *)sg_virt(els->req), sg_virt(els->resp), | 811 | *(u8 *)sg_virt(els->req), sg_virt(els->resp), |
826 | els->resp->length); | 812 | els->resp->length); |
827 | } | 813 | } |
828 | 814 | ||
829 | /** | 815 | /** |
830 | * zfcp_san_dbf_event_incoming_els - trace event for incomig ELS | 816 | * zfcp_dbf_san_incoming_els - trace event for incomig ELS |
831 | * @fsf_req: request containing unsolicited status buffer with incoming ELS | 817 | * @fsf_req: request containing unsolicited status buffer with incoming ELS |
832 | */ | 818 | */ |
833 | void zfcp_san_dbf_event_incoming_els(struct zfcp_fsf_req *fsf_req) | 819 | void zfcp_dbf_san_incoming_els(struct zfcp_fsf_req *fsf_req) |
834 | { | 820 | { |
835 | struct zfcp_adapter *adapter = fsf_req->adapter; | 821 | struct zfcp_adapter *adapter = fsf_req->adapter; |
836 | struct fsf_status_read_buffer *buf = | 822 | struct fsf_status_read_buffer *buf = |
@@ -838,16 +824,16 @@ void zfcp_san_dbf_event_incoming_els(struct zfcp_fsf_req *fsf_req) | |||
838 | int length = (int)buf->length - | 824 | int length = (int)buf->length - |
839 | (int)((void *)&buf->payload - (void *)buf); | 825 | (int)((void *)&buf->payload - (void *)buf); |
840 | 826 | ||
841 | zfcp_san_dbf_event_els("iels", 1, fsf_req, buf->d_id, | 827 | zfcp_dbf_san_els("iels", 1, fsf_req, buf->d_id, |
842 | fc_host_port_id(adapter->scsi_host), | 828 | fc_host_port_id(adapter->scsi_host), |
843 | buf->payload.data[0], (void *)buf->payload.data, | 829 | buf->payload.data[0], (void *)buf->payload.data, |
844 | length); | 830 | length); |
845 | } | 831 | } |
846 | 832 | ||
847 | static int zfcp_san_dbf_view_format(debug_info_t *id, struct debug_view *view, | 833 | static int zfcp_dbf_san_view_format(debug_info_t *id, struct debug_view *view, |
848 | char *out_buf, const char *in_buf) | 834 | char *out_buf, const char *in_buf) |
849 | { | 835 | { |
850 | struct zfcp_san_dbf_record *r = (struct zfcp_san_dbf_record *)in_buf; | 836 | struct zfcp_dbf_san_record *r = (struct zfcp_dbf_san_record *)in_buf; |
851 | char *p = out_buf; | 837 | char *p = out_buf; |
852 | 838 | ||
853 | if (strncmp(r->tag, "dump", ZFCP_DBF_TAG_SIZE) == 0) | 839 | if (strncmp(r->tag, "dump", ZFCP_DBF_TAG_SIZE) == 0) |
@@ -860,7 +846,7 @@ static int zfcp_san_dbf_view_format(debug_info_t *id, struct debug_view *view, | |||
860 | zfcp_dbf_out(&p, "d_id", "0x%06x", r->d_id); | 846 | zfcp_dbf_out(&p, "d_id", "0x%06x", r->d_id); |
861 | 847 | ||
862 | if (strncmp(r->tag, "octc", ZFCP_DBF_TAG_SIZE) == 0) { | 848 | if (strncmp(r->tag, "octc", ZFCP_DBF_TAG_SIZE) == 0) { |
863 | struct zfcp_san_dbf_record_ct_request *ct = &r->u.ct_req; | 849 | struct zfcp_dbf_san_record_ct_request *ct = &r->u.ct_req; |
864 | zfcp_dbf_out(&p, "cmd_req_code", "0x%04x", ct->cmd_req_code); | 850 | zfcp_dbf_out(&p, "cmd_req_code", "0x%04x", ct->cmd_req_code); |
865 | zfcp_dbf_out(&p, "revision", "0x%02x", ct->revision); | 851 | zfcp_dbf_out(&p, "revision", "0x%02x", ct->revision); |
866 | zfcp_dbf_out(&p, "gs_type", "0x%02x", ct->gs_type); | 852 | zfcp_dbf_out(&p, "gs_type", "0x%02x", ct->gs_type); |
@@ -868,7 +854,7 @@ static int zfcp_san_dbf_view_format(debug_info_t *id, struct debug_view *view, | |||
868 | zfcp_dbf_out(&p, "options", "0x%02x", ct->options); | 854 | zfcp_dbf_out(&p, "options", "0x%02x", ct->options); |
869 | zfcp_dbf_out(&p, "max_res_size", "0x%04x", ct->max_res_size); | 855 | zfcp_dbf_out(&p, "max_res_size", "0x%04x", ct->max_res_size); |
870 | } else if (strncmp(r->tag, "rctc", ZFCP_DBF_TAG_SIZE) == 0) { | 856 | } else if (strncmp(r->tag, "rctc", ZFCP_DBF_TAG_SIZE) == 0) { |
871 | struct zfcp_san_dbf_record_ct_response *ct = &r->u.ct_resp; | 857 | struct zfcp_dbf_san_record_ct_response *ct = &r->u.ct_resp; |
872 | zfcp_dbf_out(&p, "cmd_rsp_code", "0x%04x", ct->cmd_rsp_code); | 858 | zfcp_dbf_out(&p, "cmd_rsp_code", "0x%04x", ct->cmd_rsp_code); |
873 | zfcp_dbf_out(&p, "revision", "0x%02x", ct->revision); | 859 | zfcp_dbf_out(&p, "revision", "0x%02x", ct->revision); |
874 | zfcp_dbf_out(&p, "reason_code", "0x%02x", ct->reason_code); | 860 | zfcp_dbf_out(&p, "reason_code", "0x%02x", ct->reason_code); |
@@ -878,34 +864,30 @@ static int zfcp_san_dbf_view_format(debug_info_t *id, struct debug_view *view, | |||
878 | } else if (strncmp(r->tag, "oels", ZFCP_DBF_TAG_SIZE) == 0 || | 864 | } else if (strncmp(r->tag, "oels", ZFCP_DBF_TAG_SIZE) == 0 || |
879 | strncmp(r->tag, "rels", ZFCP_DBF_TAG_SIZE) == 0 || | 865 | strncmp(r->tag, "rels", ZFCP_DBF_TAG_SIZE) == 0 || |
880 | strncmp(r->tag, "iels", ZFCP_DBF_TAG_SIZE) == 0) { | 866 | strncmp(r->tag, "iels", ZFCP_DBF_TAG_SIZE) == 0) { |
881 | struct zfcp_san_dbf_record_els *els = &r->u.els; | 867 | struct zfcp_dbf_san_record_els *els = &r->u.els; |
882 | zfcp_dbf_out(&p, "ls_code", "0x%02x", els->ls_code); | 868 | zfcp_dbf_out(&p, "ls_code", "0x%02x", els->ls_code); |
883 | } | 869 | } |
884 | return p - out_buf; | 870 | return p - out_buf; |
885 | } | 871 | } |
886 | 872 | ||
887 | static struct debug_view zfcp_san_dbf_view = { | 873 | static struct debug_view zfcp_dbf_san_view = { |
888 | "structured", | 874 | .name = "structured", |
889 | NULL, | 875 | .header_proc = zfcp_dbf_view_header, |
890 | &zfcp_dbf_view_header, | 876 | .format_proc = zfcp_dbf_san_view_format, |
891 | &zfcp_san_dbf_view_format, | ||
892 | NULL, | ||
893 | NULL | ||
894 | }; | 877 | }; |
895 | 878 | ||
896 | void _zfcp_scsi_dbf_event(const char *tag, const char *tag2, int level, | 879 | void _zfcp_dbf_scsi(const char *tag, const char *tag2, int level, |
897 | struct zfcp_dbf *dbf, struct scsi_cmnd *scsi_cmnd, | 880 | struct zfcp_dbf *dbf, struct scsi_cmnd *scsi_cmnd, |
898 | struct zfcp_fsf_req *fsf_req, | 881 | struct zfcp_fsf_req *fsf_req, unsigned long old_req_id) |
899 | unsigned long old_req_id) | ||
900 | { | 882 | { |
901 | struct zfcp_scsi_dbf_record *rec = &dbf->scsi_dbf_buf; | 883 | struct zfcp_dbf_scsi_record *rec = &dbf->scsi_buf; |
902 | struct zfcp_dbf_dump *dump = (struct zfcp_dbf_dump *)rec; | 884 | struct zfcp_dbf_dump *dump = (struct zfcp_dbf_dump *)rec; |
903 | unsigned long flags; | 885 | unsigned long flags; |
904 | struct fcp_rsp_iu *fcp_rsp; | 886 | struct fcp_rsp_iu *fcp_rsp; |
905 | char *fcp_rsp_info = NULL, *fcp_sns_info = NULL; | 887 | char *fcp_rsp_info = NULL, *fcp_sns_info = NULL; |
906 | int offset = 0, buflen = 0; | 888 | int offset = 0, buflen = 0; |
907 | 889 | ||
908 | spin_lock_irqsave(&dbf->scsi_dbf_lock, flags); | 890 | spin_lock_irqsave(&dbf->scsi_lock, flags); |
909 | do { | 891 | do { |
910 | memset(rec, 0, sizeof(*rec)); | 892 | memset(rec, 0, sizeof(*rec)); |
911 | if (offset == 0) { | 893 | if (offset == 0) { |
@@ -959,20 +941,20 @@ void _zfcp_scsi_dbf_event(const char *tag, const char *tag2, int level, | |||
959 | dump->offset = offset; | 941 | dump->offset = offset; |
960 | dump->size = min(buflen - offset, | 942 | dump->size = min(buflen - offset, |
961 | (int)sizeof(struct | 943 | (int)sizeof(struct |
962 | zfcp_scsi_dbf_record) - | 944 | zfcp_dbf_scsi_record) - |
963 | (int)sizeof(struct zfcp_dbf_dump)); | 945 | (int)sizeof(struct zfcp_dbf_dump)); |
964 | memcpy(dump->data, fcp_sns_info + offset, dump->size); | 946 | memcpy(dump->data, fcp_sns_info + offset, dump->size); |
965 | offset += dump->size; | 947 | offset += dump->size; |
966 | } | 948 | } |
967 | debug_event(dbf->scsi_dbf, level, rec, sizeof(*rec)); | 949 | debug_event(dbf->scsi, level, rec, sizeof(*rec)); |
968 | } while (offset < buflen); | 950 | } while (offset < buflen); |
969 | spin_unlock_irqrestore(&dbf->scsi_dbf_lock, flags); | 951 | spin_unlock_irqrestore(&dbf->scsi_lock, flags); |
970 | } | 952 | } |
971 | 953 | ||
972 | static int zfcp_scsi_dbf_view_format(debug_info_t *id, struct debug_view *view, | 954 | static int zfcp_dbf_scsi_view_format(debug_info_t *id, struct debug_view *view, |
973 | char *out_buf, const char *in_buf) | 955 | char *out_buf, const char *in_buf) |
974 | { | 956 | { |
975 | struct zfcp_scsi_dbf_record *r = (struct zfcp_scsi_dbf_record *)in_buf; | 957 | struct zfcp_dbf_scsi_record *r = (struct zfcp_dbf_scsi_record *)in_buf; |
976 | struct timespec t; | 958 | struct timespec t; |
977 | char *p = out_buf; | 959 | char *p = out_buf; |
978 | 960 | ||
@@ -1013,13 +995,10 @@ static int zfcp_scsi_dbf_view_format(debug_info_t *id, struct debug_view *view, | |||
1013 | return p - out_buf; | 995 | return p - out_buf; |
1014 | } | 996 | } |
1015 | 997 | ||
1016 | static struct debug_view zfcp_scsi_dbf_view = { | 998 | static struct debug_view zfcp_dbf_scsi_view = { |
1017 | "structured", | 999 | .name = "structured", |
1018 | NULL, | 1000 | .header_proc = zfcp_dbf_view_header, |
1019 | &zfcp_dbf_view_header, | 1001 | .format_proc = zfcp_dbf_scsi_view_format, |
1020 | &zfcp_scsi_dbf_view_format, | ||
1021 | NULL, | ||
1022 | NULL | ||
1023 | }; | 1002 | }; |
1024 | 1003 | ||
1025 | static debug_info_t *zfcp_dbf_reg(const char *name, int level, | 1004 | static debug_info_t *zfcp_dbf_reg(const char *name, int level, |
@@ -1043,7 +1022,7 @@ static debug_info_t *zfcp_dbf_reg(const char *name, int level, | |||
1043 | * @adapter: pointer to adapter for which debug features should be registered | 1022 | * @adapter: pointer to adapter for which debug features should be registered |
1044 | * return: -ENOMEM on error, 0 otherwise | 1023 | * return: -ENOMEM on error, 0 otherwise |
1045 | */ | 1024 | */ |
1046 | int zfcp_adapter_debug_register(struct zfcp_adapter *adapter) | 1025 | int zfcp_dbf_adapter_register(struct zfcp_adapter *adapter) |
1047 | { | 1026 | { |
1048 | char dbf_name[DEBUG_MAX_NAME_LEN]; | 1027 | char dbf_name[DEBUG_MAX_NAME_LEN]; |
1049 | struct zfcp_dbf *dbf; | 1028 | struct zfcp_dbf *dbf; |
@@ -1052,63 +1031,60 @@ int zfcp_adapter_debug_register(struct zfcp_adapter *adapter) | |||
1052 | if (!dbf) | 1031 | if (!dbf) |
1053 | return -ENOMEM; | 1032 | return -ENOMEM; |
1054 | 1033 | ||
1055 | spin_lock_init(&dbf->hba_dbf_lock); | 1034 | dbf->adapter = adapter; |
1056 | spin_lock_init(&dbf->san_dbf_lock); | 1035 | |
1057 | spin_lock_init(&dbf->scsi_dbf_lock); | 1036 | spin_lock_init(&dbf->hba_lock); |
1058 | spin_lock_init(&dbf->rec_dbf_lock); | 1037 | spin_lock_init(&dbf->san_lock); |
1038 | spin_lock_init(&dbf->scsi_lock); | ||
1039 | spin_lock_init(&dbf->rec_lock); | ||
1059 | 1040 | ||
1060 | /* debug feature area which records recovery activity */ | 1041 | /* debug feature area which records recovery activity */ |
1061 | sprintf(dbf_name, "zfcp_%s_rec", dev_name(&adapter->ccw_device->dev)); | 1042 | sprintf(dbf_name, "zfcp_%s_rec", dev_name(&adapter->ccw_device->dev)); |
1062 | dbf->rec_dbf = zfcp_dbf_reg(dbf_name, 3, &zfcp_rec_dbf_view, | 1043 | dbf->rec = zfcp_dbf_reg(dbf_name, 3, &zfcp_dbf_rec_view, |
1063 | sizeof(struct zfcp_rec_dbf_record)); | 1044 | sizeof(struct zfcp_dbf_rec_record)); |
1064 | if (!dbf->rec_dbf) | 1045 | if (!dbf->rec) |
1065 | goto fail_rec; | 1046 | goto err_out; |
1066 | 1047 | ||
1067 | /* debug feature area which records HBA (FSF and QDIO) conditions */ | 1048 | /* debug feature area which records HBA (FSF and QDIO) conditions */ |
1068 | sprintf(dbf_name, "zfcp_%s_hba", dev_name(&adapter->ccw_device->dev)); | 1049 | sprintf(dbf_name, "zfcp_%s_hba", dev_name(&adapter->ccw_device->dev)); |
1069 | dbf->hba_dbf = zfcp_dbf_reg(dbf_name, 3, &zfcp_hba_dbf_view, | 1050 | dbf->hba = zfcp_dbf_reg(dbf_name, 3, &zfcp_dbf_hba_view, |
1070 | sizeof(struct zfcp_hba_dbf_record)); | 1051 | sizeof(struct zfcp_dbf_hba_record)); |
1071 | if (!dbf->hba_dbf) | 1052 | if (!dbf->hba) |
1072 | goto fail_hba; | 1053 | goto err_out; |
1073 | 1054 | ||
1074 | /* debug feature area which records SAN command failures and recovery */ | 1055 | /* debug feature area which records SAN command failures and recovery */ |
1075 | sprintf(dbf_name, "zfcp_%s_san", dev_name(&adapter->ccw_device->dev)); | 1056 | sprintf(dbf_name, "zfcp_%s_san", dev_name(&adapter->ccw_device->dev)); |
1076 | dbf->san_dbf = zfcp_dbf_reg(dbf_name, 6, &zfcp_san_dbf_view, | 1057 | dbf->san = zfcp_dbf_reg(dbf_name, 6, &zfcp_dbf_san_view, |
1077 | sizeof(struct zfcp_san_dbf_record)); | 1058 | sizeof(struct zfcp_dbf_san_record)); |
1078 | if (!dbf->san_dbf) | 1059 | if (!dbf->san) |
1079 | goto fail_san; | 1060 | goto err_out; |
1080 | 1061 | ||
1081 | /* debug feature area which records SCSI command failures and recovery */ | 1062 | /* debug feature area which records SCSI command failures and recovery */ |
1082 | sprintf(dbf_name, "zfcp_%s_scsi", dev_name(&adapter->ccw_device->dev)); | 1063 | sprintf(dbf_name, "zfcp_%s_scsi", dev_name(&adapter->ccw_device->dev)); |
1083 | dbf->scsi_dbf = zfcp_dbf_reg(dbf_name, 3, &zfcp_scsi_dbf_view, | 1064 | dbf->scsi = zfcp_dbf_reg(dbf_name, 3, &zfcp_dbf_scsi_view, |
1084 | sizeof(struct zfcp_scsi_dbf_record)); | 1065 | sizeof(struct zfcp_dbf_scsi_record)); |
1085 | if (!dbf->scsi_dbf) | 1066 | if (!dbf->scsi) |
1086 | goto fail_scsi; | 1067 | goto err_out; |
1087 | 1068 | ||
1088 | adapter->dbf = dbf; | 1069 | adapter->dbf = dbf; |
1089 | return 0; | 1070 | return 0; |
1090 | 1071 | ||
1091 | fail_scsi: | 1072 | err_out: |
1092 | debug_unregister(dbf->san_dbf); | 1073 | zfcp_dbf_adapter_unregister(dbf); |
1093 | fail_san: | ||
1094 | debug_unregister(dbf->hba_dbf); | ||
1095 | fail_hba: | ||
1096 | debug_unregister(dbf->rec_dbf); | ||
1097 | fail_rec: | ||
1098 | kfree(dbf); | ||
1099 | return -ENOMEM; | 1074 | return -ENOMEM; |
1100 | } | 1075 | } |
1101 | 1076 | ||
1102 | /** | 1077 | /** |
1103 | * zfcp_adapter_debug_unregister - unregisters debug feature for an adapter | 1078 | * zfcp_adapter_debug_unregister - unregisters debug feature for an adapter |
1104 | * @adapter: pointer to adapter for which debug features should be unregistered | 1079 | * @dbf: pointer to dbf for which debug features should be unregistered |
1105 | */ | 1080 | */ |
1106 | void zfcp_adapter_debug_unregister(struct zfcp_adapter *adapter) | 1081 | void zfcp_dbf_adapter_unregister(struct zfcp_dbf *dbf) |
1107 | { | 1082 | { |
1108 | debug_unregister(adapter->dbf->scsi_dbf); | 1083 | debug_unregister(dbf->scsi); |
1109 | debug_unregister(adapter->dbf->san_dbf); | 1084 | debug_unregister(dbf->san); |
1110 | debug_unregister(adapter->dbf->hba_dbf); | 1085 | debug_unregister(dbf->hba); |
1111 | debug_unregister(adapter->dbf->rec_dbf); | 1086 | debug_unregister(dbf->rec); |
1112 | kfree(adapter->dbf); | 1087 | dbf->adapter->dbf = NULL; |
1113 | adapter->dbf = NULL; | 1088 | kfree(dbf); |
1114 | } | 1089 | } |
1090 | |||