>> If you are convinced that dropping the null tests is a good idea, then you >> can submit the patch that makes the change to the relevant maintainers and >> mailing lists. I resent the request once more because another "Triple-X" software development adventure might follow ...? Regards, Markus >From ff44962f88ac2dae9324e30819629da4fb33f0ff Mon Sep 17 00:00:00 2001 From: Markus Elfring <elfring@xxxxxxxxxxxxxxxxxxxxx> Date: Wed, 22 Oct 2014 20:40:31 +0200 Subject: [PATCH] SCSI-QLA2XXX: Deletion of unnecessary checks before the function call "vfree" A semantic patch approach was proposed with the subject "[PATCH with Coccinelle?] Deletion of unnecessary checks before specific function calls" on 2014-03-05. https://lkml.org/lkml/2014/3/5/344 http://article.gmane.org/gmane.comp.version-control.coccinelle/3513/ This patch pattern application was repeated with the help of the software "Coccinelle 1.0.0-rc22" on the source files for Linux 3.17.1. An extract of the automatically generated update suggestions is shown here. It was determined that the affected source code places call functions which perform input parameter validation already. It is therefore not needed that a similar safety check is repeated at the call site. Signed-off-by: Markus Elfring <elfring@xxxxxxxxxxxxxxxxxxxxx> --- drivers/scsi/qla2xxx/qla_attr.c | 6 ++---- drivers/scsi/qla2xxx/qla_init.c | 18 ++++++------------ drivers/scsi/qla2xxx/qla_os.c | 6 ++---- 3 files changed, 10 insertions(+), 20 deletions(-) diff --git a/drivers/scsi/qla2xxx/qla_attr.c b/drivers/scsi/qla2xxx/qla_attr.c index 82b92c4..95c4c09 100644 --- a/drivers/scsi/qla2xxx/qla_attr.c +++ b/drivers/scsi/qla2xxx/qla_attr.c @@ -175,10 +175,8 @@ qla2x00_sysfs_write_fw_dump_template(struct file *filp, struct kobject *kobj, uint32_t size; if (off == 0) { - if (ha->fw_dump) - vfree(ha->fw_dump); - if (ha->fw_dump_template) - vfree(ha->fw_dump_template); + vfree(ha->fw_dump); + vfree(ha->fw_dump_template); ha->fw_dump = NULL; ha->fw_dump_len = 0; diff --git a/drivers/scsi/qla2xxx/qla_init.c b/drivers/scsi/qla2xxx/qla_init.c index a4dde7e..8da3d4f 100644 --- a/drivers/scsi/qla2xxx/qla_init.c +++ b/drivers/scsi/qla2xxx/qla_init.c @@ -5256,8 +5256,7 @@ qla24xx_load_risc_flash(scsi_qla_host_t *vha, uint32_t *srisc_addr, if (!IS_QLA27XX(ha)) return rval; - if (ha->fw_dump_template) - vfree(ha->fw_dump_template); + vfree(ha->fw_dump_template); ha->fw_dump_template = NULL; ha->fw_dump_template_len = 0; @@ -5307,8 +5306,7 @@ qla24xx_load_risc_flash(scsi_qla_host_t *vha, uint32_t *srisc_addr, default_template: ql_log(ql_log_warn, vha, 0x0168, "Using default fwdump template\n"); - if (ha->fw_dump_template) - vfree(ha->fw_dump_template); + vfree(ha->fw_dump_template); ha->fw_dump_template = NULL; ha->fw_dump_template_len = 0; @@ -5342,8 +5340,7 @@ default_template: failed_template: ql_log(ql_log_warn, vha, 0x016d, "Failed default fwdump template\n"); - if (ha->fw_dump_template) - vfree(ha->fw_dump_template); + vfree(ha->fw_dump_template); ha->fw_dump_template = NULL; ha->fw_dump_template_len = 0; return rval; @@ -5559,8 +5556,7 @@ qla24xx_load_risc_blob(scsi_qla_host_t *vha, uint32_t *srisc_addr) if (!IS_QLA27XX(ha)) return rval; - if (ha->fw_dump_template) - vfree(ha->fw_dump_template); + vfree(ha->fw_dump_template); ha->fw_dump_template = NULL; ha->fw_dump_template_len = 0; @@ -5609,8 +5605,7 @@ qla24xx_load_risc_blob(scsi_qla_host_t *vha, uint32_t *srisc_addr) default_template: ql_log(ql_log_warn, vha, 0x0178, "Using default fwdump template\n"); - if (ha->fw_dump_template) - vfree(ha->fw_dump_template); + vfree(ha->fw_dump_template); ha->fw_dump_template = NULL; ha->fw_dump_template_len = 0; @@ -5644,8 +5639,7 @@ default_template: failed_template: ql_log(ql_log_warn, vha, 0x017d, "Failed default fwdump template\n"); - if (ha->fw_dump_template) - vfree(ha->fw_dump_template); + vfree(ha->fw_dump_template); ha->fw_dump_template = NULL; ha->fw_dump_template_len = 0; return rval; diff --git a/drivers/scsi/qla2xxx/qla_os.c b/drivers/scsi/qla2xxx/qla_os.c index db3dbd9..0f9c378 100644 --- a/drivers/scsi/qla2xxx/qla_os.c +++ b/drivers/scsi/qla2xxx/qla_os.c @@ -3676,10 +3676,8 @@ qla2x00_free_fw_dump(struct qla_hw_data *ha) dma_free_coherent(&ha->pdev->dev, EFT_SIZE, ha->eft, ha->eft_dma); - if (ha->fw_dump) - vfree(ha->fw_dump); - if (ha->fw_dump_template) - vfree(ha->fw_dump_template); + vfree(ha->fw_dump); + vfree(ha->fw_dump_template); ha->fce = NULL; ha->fce_dma = 0; -- 2.1.2 -- To unsubscribe from this list: send the line "unsubscribe kernel-janitors" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html