diff options
author | Joe Eykholt <jeykholt@cisco.com> | 2011-01-28 19:04:08 -0500 |
---|---|---|
committer | James Bottomley <James.Bottomley@suse.de> | 2011-02-12 12:01:21 -0500 |
commit | 1a5c2d7e5c8ef239804cb08b68363e0cd2f74a3d (patch) | |
tree | 1131440f3cb543911c0df18fb64e476b27866559 /drivers/scsi/libfc/fc_exch.c | |
parent | 96ad846445ae33dcae1805b68752e3d5c840e3ed (diff) |
[SCSI] libfc: add method for setting handler for incoming exchange
Add a method for setting handler for incoming exchange.
For multi-sequence exchanges, this allows the target driver
to add a response handler for handling subsequent sequences,
and exchange manager resets.
The new function is called fc_seq_set_resp().
Signed-off-by: Joe Eykholt <jeykholt@cisco.com>
Signed-off-by: Robert Love <robert.w.love@intel.com>
Signed-off-by: James Bottomley <James.Bottomley@suse.de>
Diffstat (limited to 'drivers/scsi/libfc/fc_exch.c')
-rw-r--r-- | drivers/scsi/libfc/fc_exch.c | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/drivers/scsi/libfc/fc_exch.c b/drivers/scsi/libfc/fc_exch.c index e0b5b15c355b..1f124c0351b4 100644 --- a/drivers/scsi/libfc/fc_exch.c +++ b/drivers/scsi/libfc/fc_exch.c | |||
@@ -558,6 +558,22 @@ static struct fc_seq *fc_seq_start_next(struct fc_seq *sp) | |||
558 | return sp; | 558 | return sp; |
559 | } | 559 | } |
560 | 560 | ||
561 | /* | ||
562 | * Set the response handler for the exchange associated with a sequence. | ||
563 | */ | ||
564 | static void fc_seq_set_resp(struct fc_seq *sp, | ||
565 | void (*resp)(struct fc_seq *, struct fc_frame *, | ||
566 | void *), | ||
567 | void *arg) | ||
568 | { | ||
569 | struct fc_exch *ep = fc_seq_exch(sp); | ||
570 | |||
571 | spin_lock_bh(&ep->ex_lock); | ||
572 | ep->resp = resp; | ||
573 | ep->arg = arg; | ||
574 | spin_unlock_bh(&ep->ex_lock); | ||
575 | } | ||
576 | |||
561 | /** | 577 | /** |
562 | * fc_seq_exch_abort() - Abort an exchange and sequence | 578 | * fc_seq_exch_abort() - Abort an exchange and sequence |
563 | * @req_sp: The sequence to be aborted | 579 | * @req_sp: The sequence to be aborted |
@@ -2329,6 +2345,9 @@ int fc_exch_init(struct fc_lport *lport) | |||
2329 | if (!lport->tt.seq_start_next) | 2345 | if (!lport->tt.seq_start_next) |
2330 | lport->tt.seq_start_next = fc_seq_start_next; | 2346 | lport->tt.seq_start_next = fc_seq_start_next; |
2331 | 2347 | ||
2348 | if (!lport->tt.seq_set_resp) | ||
2349 | lport->tt.seq_set_resp = fc_seq_set_resp; | ||
2350 | |||
2332 | if (!lport->tt.exch_seq_send) | 2351 | if (!lport->tt.exch_seq_send) |
2333 | lport->tt.exch_seq_send = fc_exch_seq_send; | 2352 | lport->tt.exch_seq_send = fc_exch_seq_send; |
2334 | 2353 | ||