aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/scsi/cxgb3i/cxgb3i_ddp.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/scsi/cxgb3i/cxgb3i_ddp.c')
-rw-r--r--drivers/scsi/cxgb3i/cxgb3i_ddp.c63
1 files changed, 11 insertions, 52 deletions
diff --git a/drivers/scsi/cxgb3i/cxgb3i_ddp.c b/drivers/scsi/cxgb3i/cxgb3i_ddp.c
index bb1eebf654cf..275d2da443be 100644
--- a/drivers/scsi/cxgb3i/cxgb3i_ddp.c
+++ b/drivers/scsi/cxgb3i/cxgb3i_ddp.c
@@ -23,19 +23,6 @@
23 23
24#include "cxgb3i_ddp.h" 24#include "cxgb3i_ddp.h"
25 25
26#define DRV_MODULE_NAME "cxgb3i_ddp"
27#define DRV_MODULE_VERSION "1.0.0"
28#define DRV_MODULE_RELDATE "Dec. 1, 2008"
29
30static char version[] =
31 "Chelsio S3xx iSCSI DDP " DRV_MODULE_NAME
32 " v" DRV_MODULE_VERSION " (" DRV_MODULE_RELDATE ")\n";
33
34MODULE_AUTHOR("Karen Xie <kxie@chelsio.com>");
35MODULE_DESCRIPTION("cxgb3i ddp pagepod manager");
36MODULE_LICENSE("GPL");
37MODULE_VERSION(DRV_MODULE_VERSION);
38
39#define ddp_log_error(fmt...) printk(KERN_ERR "cxgb3i_ddp: ERR! " fmt) 26#define ddp_log_error(fmt...) printk(KERN_ERR "cxgb3i_ddp: ERR! " fmt)
40#define ddp_log_warn(fmt...) printk(KERN_WARNING "cxgb3i_ddp: WARN! " fmt) 27#define ddp_log_warn(fmt...) printk(KERN_WARNING "cxgb3i_ddp: WARN! " fmt)
41#define ddp_log_info(fmt...) printk(KERN_INFO "cxgb3i_ddp: " fmt) 28#define ddp_log_info(fmt...) printk(KERN_INFO "cxgb3i_ddp: " fmt)
@@ -212,7 +199,6 @@ int cxgb3i_ddp_find_page_index(unsigned long pgsz)
212 ddp_log_debug("ddp page size 0x%lx not supported.\n", pgsz); 199 ddp_log_debug("ddp page size 0x%lx not supported.\n", pgsz);
213 return DDP_PGIDX_MAX; 200 return DDP_PGIDX_MAX;
214} 201}
215EXPORT_SYMBOL_GPL(cxgb3i_ddp_find_page_index);
216 202
217static inline void ddp_gl_unmap(struct pci_dev *pdev, 203static inline void ddp_gl_unmap(struct pci_dev *pdev,
218 struct cxgb3i_gather_list *gl) 204 struct cxgb3i_gather_list *gl)
@@ -335,7 +321,6 @@ error_out:
335 kfree(gl); 321 kfree(gl);
336 return NULL; 322 return NULL;
337} 323}
338EXPORT_SYMBOL_GPL(cxgb3i_ddp_make_gl);
339 324
340/** 325/**
341 * cxgb3i_ddp_release_gl - release a page buffer list 326 * cxgb3i_ddp_release_gl - release a page buffer list
@@ -349,7 +334,6 @@ void cxgb3i_ddp_release_gl(struct cxgb3i_gather_list *gl,
349 ddp_gl_unmap(pdev, gl); 334 ddp_gl_unmap(pdev, gl);
350 kfree(gl); 335 kfree(gl);
351} 336}
352EXPORT_SYMBOL_GPL(cxgb3i_ddp_release_gl);
353 337
354/** 338/**
355 * cxgb3i_ddp_tag_reserve - set up ddp for a data transfer 339 * cxgb3i_ddp_tag_reserve - set up ddp for a data transfer
@@ -431,7 +415,6 @@ unmark_entries:
431 ddp_unmark_entries(ddp, idx, npods); 415 ddp_unmark_entries(ddp, idx, npods);
432 return err; 416 return err;
433} 417}
434EXPORT_SYMBOL_GPL(cxgb3i_ddp_tag_reserve);
435 418
436/** 419/**
437 * cxgb3i_ddp_tag_release - release a ddp tag 420 * cxgb3i_ddp_tag_release - release a ddp tag
@@ -469,7 +452,6 @@ void cxgb3i_ddp_tag_release(struct t3cdev *tdev, u32 tag)
469 ddp_log_error("ddp tag 0x%x, idx 0x%x > max 0x%x.\n", 452 ddp_log_error("ddp tag 0x%x, idx 0x%x > max 0x%x.\n",
470 tag, idx, ddp->nppods); 453 tag, idx, ddp->nppods);
471} 454}
472EXPORT_SYMBOL_GPL(cxgb3i_ddp_tag_release);
473 455
474static int setup_conn_pgidx(struct t3cdev *tdev, unsigned int tid, int pg_idx, 456static int setup_conn_pgidx(struct t3cdev *tdev, unsigned int tid, int pg_idx,
475 int reply) 457 int reply)
@@ -510,7 +492,6 @@ int cxgb3i_setup_conn_host_pagesize(struct t3cdev *tdev, unsigned int tid,
510{ 492{
511 return setup_conn_pgidx(tdev, tid, page_idx, reply); 493 return setup_conn_pgidx(tdev, tid, page_idx, reply);
512} 494}
513EXPORT_SYMBOL_GPL(cxgb3i_setup_conn_host_pagesize);
514 495
515/** 496/**
516 * cxgb3i_setup_conn_pagesize - setup the conn.'s ddp page size 497 * cxgb3i_setup_conn_pagesize - setup the conn.'s ddp page size
@@ -527,7 +508,6 @@ int cxgb3i_setup_conn_pagesize(struct t3cdev *tdev, unsigned int tid,
527 508
528 return setup_conn_pgidx(tdev, tid, pgidx, reply); 509 return setup_conn_pgidx(tdev, tid, pgidx, reply);
529} 510}
530EXPORT_SYMBOL_GPL(cxgb3i_setup_conn_pagesize);
531 511
532/** 512/**
533 * cxgb3i_setup_conn_digest - setup conn. digest setting 513 * cxgb3i_setup_conn_digest - setup conn. digest setting
@@ -563,7 +543,6 @@ int cxgb3i_setup_conn_digest(struct t3cdev *tdev, unsigned int tid,
563 cxgb3_ofld_send(tdev, skb); 543 cxgb3_ofld_send(tdev, skb);
564 return 0; 544 return 0;
565} 545}
566EXPORT_SYMBOL_GPL(cxgb3i_setup_conn_digest);
567 546
568 547
569/** 548/**
@@ -606,7 +585,6 @@ int cxgb3i_adapter_ddp_info(struct t3cdev *tdev,
606 *txsz, ddp->max_txsz, *rxsz, ddp->max_rxsz); 585 *txsz, ddp->max_txsz, *rxsz, ddp->max_rxsz);
607 return 0; 586 return 0;
608} 587}
609EXPORT_SYMBOL_GPL(cxgb3i_adapter_ddp_info);
610 588
611/** 589/**
612 * ddp_release - release the cxgb3 adapter's ddp resource 590 * ddp_release - release the cxgb3 adapter's ddp resource
@@ -651,7 +629,6 @@ static void ddp_init(struct t3cdev *tdev)
651 struct ulp_iscsi_info uinfo; 629 struct ulp_iscsi_info uinfo;
652 unsigned int ppmax, bits; 630 unsigned int ppmax, bits;
653 int i, err; 631 int i, err;
654 static int vers_printed;
655 632
656 if (tdev->ulp_iscsi) { 633 if (tdev->ulp_iscsi) {
657 ddp_log_warn("t3dev 0x%p, ddp 0x%p already set up.\n", 634 ddp_log_warn("t3dev 0x%p, ddp 0x%p already set up.\n",
@@ -659,11 +636,6 @@ static void ddp_init(struct t3cdev *tdev)
659 return; 636 return;
660 } 637 }
661 638
662 if (!vers_printed) {
663 printk(KERN_INFO "%s", version);
664 vers_printed = 1;
665 }
666
667 err = tdev->ctl(tdev, ULP_ISCSI_GET_PARAMS, &uinfo); 639 err = tdev->ctl(tdev, ULP_ISCSI_GET_PARAMS, &uinfo);
668 if (err < 0) { 640 if (err < 0) {
669 ddp_log_error("%s, failed to get iscsi param err=%d.\n", 641 ddp_log_error("%s, failed to get iscsi param err=%d.\n",
@@ -730,36 +702,23 @@ free_ddp_map:
730 cxgb3i_free_big_mem(ddp); 702 cxgb3i_free_big_mem(ddp);
731} 703}
732 704
733static struct cxgb3_client t3c_ddp_client = {
734 .name = "iscsiddp_cxgb3",
735 .add = ddp_init,
736 .remove = ddp_release,
737};
738
739/** 705/**
740 * cxgb3i_ddp_init_module - module init entry point 706 * cxgb3i_ddp_init - initialize ddp functions
741 * initialize any driver wide global data structures and register with the
742 * cxgb3 module
743 */ 707 */
744static int __init cxgb3i_ddp_init_module(void) 708void cxgb3i_ddp_init(struct t3cdev *tdev)
745{ 709{
746 page_idx = cxgb3i_ddp_find_page_index(PAGE_SIZE); 710 if (page_idx == DDP_PGIDX_MAX) {
747 ddp_log_info("system PAGE_SIZE %lu, ddp idx %u.\n", 711 page_idx = cxgb3i_ddp_find_page_index(PAGE_SIZE);
748 PAGE_SIZE, page_idx); 712 ddp_log_info("system PAGE_SIZE %lu, ddp idx %u.\n",
749 713 PAGE_SIZE, page_idx);
750 cxgb3_register_client(&t3c_ddp_client); 714 }
751 return 0; 715 ddp_init(tdev);
752} 716}
753 717
754/** 718/**
755 * cxgb3i_ddp_exit_module - module cleanup/exit entry point 719 * cxgb3i_ddp_cleaup - clean up ddp function
756 * go through the ddp list, unregister with the cxgb3 module and release
757 * any resource held.
758 */ 720 */
759static void __exit cxgb3i_ddp_exit_module(void) 721void cxgb3i_ddp_cleanup(struct t3cdev *tdev)
760{ 722{
761 cxgb3_unregister_client(&t3c_ddp_client); 723 ddp_release(tdev);
762} 724}
763
764module_init(cxgb3i_ddp_init_module);
765module_exit(cxgb3i_ddp_exit_module);