aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/firewire
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/firewire')
-rw-r--r--drivers/firewire/fw-sbp2.c26
1 files changed, 8 insertions, 18 deletions
diff --git a/drivers/firewire/fw-sbp2.c b/drivers/firewire/fw-sbp2.c
index 994914f89b55..07e410b0ae53 100644
--- a/drivers/firewire/fw-sbp2.c
+++ b/drivers/firewire/fw-sbp2.c
@@ -452,8 +452,6 @@ sbp2_send_management_orb(struct fw_unit *unit, int node_id, int generation,
452 452
453 wait_for_completion(&orb->done); 453 wait_for_completion(&orb->done);
454 454
455 /* FIXME: Handle bus reset race here. */
456
457 retval = -EIO; 455 retval = -EIO;
458 if (orb->base.rcode != RCODE_COMPLETE) { 456 if (orb->base.rcode != RCODE_COMPLETE) {
459 fw_error("management write failed, rcode 0x%02x\n", 457 fw_error("management write failed, rcode 0x%02x\n",
@@ -496,7 +494,6 @@ complete_agent_reset_write(struct fw_card *card, int rcode,
496{ 494{
497 struct fw_transaction *t = data; 495 struct fw_transaction *t = data;
498 496
499 fw_notify("agent reset write rcode=%d\n", rcode);
500 kfree(t); 497 kfree(t);
501} 498}
502 499
@@ -542,9 +539,6 @@ static void sbp2_login(struct work_struct *work)
542 if (sbp2_send_management_orb(unit, node_id, generation, 539 if (sbp2_send_management_orb(unit, node_id, generation,
543 SBP2_LOGIN_REQUEST, lun, &response) < 0) { 540 SBP2_LOGIN_REQUEST, lun, &response) < 0) {
544 if (sd->retries++ < 5) { 541 if (sd->retries++ < 5) {
545 fw_error("login attempt %d for %s failed, "
546 "rescheduling\n",
547 sd->retries, unit->device.bus_id);
548 schedule_delayed_work(&sd->work, DIV_ROUND_UP(HZ, 5)); 542 schedule_delayed_work(&sd->work, DIV_ROUND_UP(HZ, 5));
549 } else { 543 } else {
550 fw_error("failed to login to %s\n", 544 fw_error("failed to login to %s\n",
@@ -560,16 +554,17 @@ static void sbp2_login(struct work_struct *work)
560 554
561 /* Get command block agent offset and login id. */ 555 /* Get command block agent offset and login id. */
562 sd->command_block_agent_address = 556 sd->command_block_agent_address =
563 ((u64) response.command_block_agent.high << 32) | 557 ((u64) (response.command_block_agent.high & 0xffff) << 32) |
564 response.command_block_agent.low; 558 response.command_block_agent.low;
565 sd->login_id = login_response_get_login_id(response); 559 sd->login_id = login_response_get_login_id(response);
566 560
567 fw_notify("logged in to sbp2 unit %s\n", unit->device.bus_id); 561 fw_notify("logged in to sbp2 unit %s (%d retries)\n",
568 fw_notify(" - management_agent_address: 0x%012llx\n", 562 unit->device.bus_id, sd->retries);
563 fw_notify(" - management_agent_address: 0x%012llx\n",
569 (unsigned long long) sd->management_agent_address); 564 (unsigned long long) sd->management_agent_address);
570 fw_notify(" - command_block_agent_address: 0x%012llx\n", 565 fw_notify(" - command_block_agent_address: 0x%012llx\n",
571 (unsigned long long) sd->command_block_agent_address); 566 (unsigned long long) sd->command_block_agent_address);
572 fw_notify(" - status write address: 0x%012llx\n", 567 fw_notify(" - status write address: 0x%012llx\n",
573 (unsigned long long) sd->address_handler.offset); 568 (unsigned long long) sd->address_handler.offset);
574 569
575#if 0 570#if 0
@@ -705,11 +700,7 @@ static void sbp2_reconnect(struct work_struct *work)
705 if (sbp2_send_management_orb(unit, node_id, generation, 700 if (sbp2_send_management_orb(unit, node_id, generation,
706 SBP2_RECONNECT_REQUEST, 701 SBP2_RECONNECT_REQUEST,
707 sd->login_id, NULL) < 0) { 702 sd->login_id, NULL) < 0) {
708 if (sd->retries++ < 5) { 703 if (sd->retries++ >= 5) {
709 fw_error("reconnect attempt %d for %s failed, "
710 "rescheduling\n",
711 sd->retries, unit->device.bus_id);
712 } else {
713 fw_error("failed to reconnect to %s\n", 704 fw_error("failed to reconnect to %s\n",
714 unit->device.bus_id); 705 unit->device.bus_id);
715 /* Fall back and try to log in again. */ 706 /* Fall back and try to log in again. */
@@ -724,7 +715,8 @@ static void sbp2_reconnect(struct work_struct *work)
724 sd->node_id = node_id; 715 sd->node_id = node_id;
725 sd->address_high = local_node_id << 16; 716 sd->address_high = local_node_id << 16;
726 717
727 fw_notify("reconnected to unit %s\n", unit->device.bus_id); 718 fw_notify("reconnected to unit %s (%d retries)\n",
719 unit->device.bus_id, sd->retries);
728 sbp2_agent_reset(unit); 720 sbp2_agent_reset(unit);
729 sbp2_cancel_orbs(unit); 721 sbp2_cancel_orbs(unit);
730} 722}
@@ -837,8 +829,6 @@ complete_command_orb(struct sbp2_orb *base_orb, struct sbp2_status *status)
837 /* If the orb completes with status == NULL, something 829 /* If the orb completes with status == NULL, something
838 * went wrong, typically a bus reset happened mid-orb 830 * went wrong, typically a bus reset happened mid-orb
839 * or when sending the write (less likely). */ 831 * or when sending the write (less likely). */
840 fw_notify("no command orb status, rcode=%d\n",
841 orb->base.rcode);
842 result = DID_BUS_BUSY; 832 result = DID_BUS_BUSY;
843 } 833 }
844 834