diff options
author | Andrew Vasquez <andrew.vasquez@qlogic.com> | 2009-03-24 12:08:15 -0400 |
---|---|---|
committer | James Bottomley <James.Bottomley@HansenPartnership.com> | 2009-04-03 10:22:52 -0400 |
commit | d743de66754a662399bd9fe7da7a34e189f71876 (patch) | |
tree | db205f7c01d0c2db4114a7aa6d574e18d36d83b1 /drivers/scsi/qla2xxx/qla_init.c | |
parent | 3d79038f92841052aced9aec43c9d9aa864d28ab (diff) |
[SCSI] qla2xxx: Reduce request queue-size overhead with recent ISPs.
The original code to 'resize request-queues' based on iocb-counts
and employed during early ISP23xx testing was too
overly-pessimistic with regards to latencies in the firmware
pulling requests. Recent ISPs can easily keep up processing a
stream of commands from an abbreviated (effectively, half the
original size) queue.
Signed-off-by: Andrew Vasquez <andrew.vasquez@qlogic.com>
Signed-off-by: James Bottomley <James.Bottomley@HansenPartnership.com>
Diffstat (limited to 'drivers/scsi/qla2xxx/qla_init.c')
-rw-r--r-- | drivers/scsi/qla2xxx/qla_init.c | 67 |
1 files changed, 5 insertions, 62 deletions
diff --git a/drivers/scsi/qla2xxx/qla_init.c b/drivers/scsi/qla2xxx/qla_init.c index 997c83b07e8a..f90fd3774f19 100644 --- a/drivers/scsi/qla2xxx/qla_init.c +++ b/drivers/scsi/qla2xxx/qla_init.c | |||
@@ -20,7 +20,6 @@ | |||
20 | * QLogic ISP2x00 Hardware Support Function Prototypes. | 20 | * QLogic ISP2x00 Hardware Support Function Prototypes. |
21 | */ | 21 | */ |
22 | static int qla2x00_isp_firmware(scsi_qla_host_t *); | 22 | static int qla2x00_isp_firmware(scsi_qla_host_t *); |
23 | static void qla2x00_resize_request_q(scsi_qla_host_t *); | ||
24 | static int qla2x00_setup_chip(scsi_qla_host_t *); | 23 | static int qla2x00_setup_chip(scsi_qla_host_t *); |
25 | static int qla2x00_init_rings(scsi_qla_host_t *); | 24 | static int qla2x00_init_rings(scsi_qla_host_t *); |
26 | static int qla2x00_fw_ready(scsi_qla_host_t *); | 25 | static int qla2x00_fw_ready(scsi_qla_host_t *); |
@@ -893,62 +892,6 @@ cont_alloc: | |||
893 | } | 892 | } |
894 | 893 | ||
895 | /** | 894 | /** |
896 | * qla2x00_resize_request_q() - Resize request queue given available ISP memory. | ||
897 | * @ha: HA context | ||
898 | * | ||
899 | * Returns 0 on success. | ||
900 | */ | ||
901 | static void | ||
902 | qla2x00_resize_request_q(scsi_qla_host_t *vha) | ||
903 | { | ||
904 | int rval; | ||
905 | uint16_t fw_iocb_cnt = 0; | ||
906 | uint16_t request_q_length = REQUEST_ENTRY_CNT_2XXX_EXT_MEM; | ||
907 | dma_addr_t request_dma; | ||
908 | request_t *request_ring; | ||
909 | struct qla_hw_data *ha = vha->hw; | ||
910 | struct req_que *req = ha->req_q_map[0]; | ||
911 | |||
912 | /* Valid only on recent ISPs. */ | ||
913 | if (IS_QLA2100(ha) || IS_QLA2200(ha)) | ||
914 | return; | ||
915 | |||
916 | /* Retrieve IOCB counts available to the firmware. */ | ||
917 | rval = qla2x00_get_resource_cnts(vha, NULL, NULL, NULL, &fw_iocb_cnt, | ||
918 | &ha->max_npiv_vports); | ||
919 | if (rval) | ||
920 | return; | ||
921 | /* No point in continuing if current settings are sufficient. */ | ||
922 | if (fw_iocb_cnt < 1024) | ||
923 | return; | ||
924 | if (req->length >= request_q_length) | ||
925 | return; | ||
926 | |||
927 | /* Attempt to claim larger area for request queue. */ | ||
928 | request_ring = dma_alloc_coherent(&ha->pdev->dev, | ||
929 | (request_q_length + 1) * sizeof(request_t), &request_dma, | ||
930 | GFP_KERNEL); | ||
931 | if (request_ring == NULL) | ||
932 | return; | ||
933 | |||
934 | /* Resize successful, report extensions. */ | ||
935 | qla_printk(KERN_INFO, ha, "Extended memory detected (%d KB)...\n", | ||
936 | (ha->fw_memory_size + 1) / 1024); | ||
937 | qla_printk(KERN_INFO, ha, "Resizing request queue depth " | ||
938 | "(%d -> %d)...\n", req->length, request_q_length); | ||
939 | |||
940 | /* Clear old allocations. */ | ||
941 | dma_free_coherent(&ha->pdev->dev, | ||
942 | (req->length + 1) * sizeof(request_t), req->ring, | ||
943 | req->dma); | ||
944 | |||
945 | /* Begin using larger queue. */ | ||
946 | req->length = request_q_length; | ||
947 | req->ring = request_ring; | ||
948 | req->dma = request_dma; | ||
949 | } | ||
950 | |||
951 | /** | ||
952 | * qla2x00_setup_chip() - Load and start RISC firmware. | 895 | * qla2x00_setup_chip() - Load and start RISC firmware. |
953 | * @ha: HA context | 896 | * @ha: HA context |
954 | * | 897 | * |
@@ -1005,11 +948,11 @@ qla2x00_setup_chip(scsi_qla_host_t *vha) | |||
1005 | ha->max_npiv_vports = | 948 | ha->max_npiv_vports = |
1006 | MIN_MULTI_ID_FABRIC - 1; | 949 | MIN_MULTI_ID_FABRIC - 1; |
1007 | } | 950 | } |
1008 | if (!fw_major_version) { | 951 | qla2x00_get_resource_cnts(vha, NULL, NULL, |
1009 | qla2x00_resize_request_q(vha); | 952 | NULL, NULL, &ha->max_npiv_vports); |
1010 | if (ql2xallocfwdump) | 953 | |
1011 | qla2x00_alloc_fw_dump(vha); | 954 | if (!fw_major_version && ql2xallocfwdump) |
1012 | } | 955 | qla2x00_alloc_fw_dump(vha); |
1013 | } | 956 | } |
1014 | } else { | 957 | } else { |
1015 | DEBUG2(printk(KERN_INFO | 958 | DEBUG2(printk(KERN_INFO |