aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/scsi/fcoe
diff options
context:
space:
mode:
authorYi Zou <yi.zou@intel.com>2009-07-29 20:03:55 -0400
committerJames Bottomley <James.Bottomley@suse.de>2009-08-22 18:52:02 -0400
commit5a84baeaf7b8bb4188219140cb326a3e859b2312 (patch)
treeb584fcb403ed3332be39b85faef2bc0cd25633d7 /drivers/scsi/fcoe
parent7a7f0c7f7a0cbda062d1ff2ff1d3f99d0e41d2af (diff)
[SCSI] libfcoe: Set fip_flags according to fcf and lport's capability of SPMA support
When encap the els for FIP, set the fip_flags according to the FCF and lport's capability of supporting SPMA or FPMA or both. Signed-off-by: Yi Zou <yi.zou@intel.com> Signed-off-by: Robert Love <robert.w.love@intel.com> Signed-off-by: James Bottomley <James.Bottomley@HansenPartnership.com> Signed-off-by: James Bottomley <James.Bottomley@suse.de>
Diffstat (limited to 'drivers/scsi/fcoe')
-rw-r--r--drivers/scsi/fcoe/libfcoe.c12
1 files changed, 9 insertions, 3 deletions
diff --git a/drivers/scsi/fcoe/libfcoe.c b/drivers/scsi/fcoe/libfcoe.c
index d6ed3f8255ad..78caa6be1130 100644
--- a/drivers/scsi/fcoe/libfcoe.c
+++ b/drivers/scsi/fcoe/libfcoe.c
@@ -413,10 +413,18 @@ static int fcoe_ctlr_encaps(struct fcoe_ctlr *fip,
413 struct fip_mac_desc *mac; 413 struct fip_mac_desc *mac;
414 struct fcoe_fcf *fcf; 414 struct fcoe_fcf *fcf;
415 size_t dlen; 415 size_t dlen;
416 u16 fip_flags;
416 417
417 fcf = fip->sel_fcf; 418 fcf = fip->sel_fcf;
418 if (!fcf) 419 if (!fcf)
419 return -ENODEV; 420 return -ENODEV;
421
422 /* set flags according to both FCF and lport's capability on SPMA */
423 fip_flags = fcf->flags;
424 fip_flags &= fip->spma ? FIP_FL_SPMA | FIP_FL_FPMA : FIP_FL_FPMA;
425 if (!fip_flags)
426 return -ENODEV;
427
420 dlen = sizeof(struct fip_encaps) + skb->len; /* len before push */ 428 dlen = sizeof(struct fip_encaps) + skb->len; /* len before push */
421 cap = (struct fip_encaps_head *)skb_push(skb, sizeof(*cap)); 429 cap = (struct fip_encaps_head *)skb_push(skb, sizeof(*cap));
422 430
@@ -429,9 +437,7 @@ static int fcoe_ctlr_encaps(struct fcoe_ctlr *fip,
429 cap->fip.fip_op = htons(FIP_OP_LS); 437 cap->fip.fip_op = htons(FIP_OP_LS);
430 cap->fip.fip_subcode = FIP_SC_REQ; 438 cap->fip.fip_subcode = FIP_SC_REQ;
431 cap->fip.fip_dl_len = htons((dlen + sizeof(*mac)) / FIP_BPW); 439 cap->fip.fip_dl_len = htons((dlen + sizeof(*mac)) / FIP_BPW);
432 cap->fip.fip_flags = htons(FIP_FL_FPMA); 440 cap->fip.fip_flags = htons(fip_flags);
433 if (fip->spma)
434 cap->fip.fip_flags |= htons(FIP_FL_SPMA);
435 441
436 cap->encaps.fd_desc.fip_dtype = dtype; 442 cap->encaps.fd_desc.fip_dtype = dtype;
437 cap->encaps.fd_desc.fip_dlen = dlen / FIP_BPW; 443 cap->encaps.fd_desc.fip_dlen = dlen / FIP_BPW;