scsi: hisi_sas: Add hisi_sas_debugfs_alloc() to centralise allocation
We extract the code of memory allocate and construct an new function for it. We think it's convenient for subsequent optimization. Link: https://lore.kernel.org/r/1567774537-20003-12-git-send-email-john.garry@huawei.com Signed-off-by: Luo Jiaxing <luojiaxing@huawei.com> Signed-off-by: John Garry <john.garry@huawei.com> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
This commit is contained in:
parent
4bc058097a
commit
7ec7082c57
|
@ -3306,27 +3306,44 @@ void hisi_sas_debugfs_work_handler(struct work_struct *work)
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(hisi_sas_debugfs_work_handler);
|
EXPORT_SYMBOL_GPL(hisi_sas_debugfs_work_handler);
|
||||||
|
|
||||||
void hisi_sas_debugfs_init(struct hisi_hba *hisi_hba)
|
void hisi_sas_debugfs_release(struct hisi_hba *hisi_hba)
|
||||||
|
{
|
||||||
|
struct device *dev = hisi_hba->dev;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
devm_kfree(dev, hisi_hba->debugfs_iost_cache);
|
||||||
|
devm_kfree(dev, hisi_hba->debugfs_itct_cache);
|
||||||
|
devm_kfree(dev, hisi_hba->debugfs_iost);
|
||||||
|
|
||||||
|
for (i = 0; i < hisi_hba->queue_count; i++)
|
||||||
|
devm_kfree(dev, hisi_hba->debugfs_cmd_hdr[i]);
|
||||||
|
|
||||||
|
for (i = 0; i < hisi_hba->queue_count; i++)
|
||||||
|
devm_kfree(dev, hisi_hba->debugfs_complete_hdr[i]);
|
||||||
|
|
||||||
|
for (i = 0; i < DEBUGFS_REGS_NUM; i++)
|
||||||
|
devm_kfree(dev, hisi_hba->debugfs_regs[i]);
|
||||||
|
|
||||||
|
for (i = 0; i < hisi_hba->n_phy; i++)
|
||||||
|
devm_kfree(dev, hisi_hba->debugfs_port_reg[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
int hisi_sas_debugfs_alloc(struct hisi_hba *hisi_hba)
|
||||||
{
|
{
|
||||||
int max_command_entries = HISI_SAS_MAX_COMMANDS;
|
|
||||||
const struct hisi_sas_hw *hw = hisi_hba->hw;
|
const struct hisi_sas_hw *hw = hisi_hba->hw;
|
||||||
struct device *dev = hisi_hba->dev;
|
struct device *dev = hisi_hba->dev;
|
||||||
int p, i, c, d;
|
int p, c, d;
|
||||||
size_t sz;
|
size_t sz;
|
||||||
|
|
||||||
hisi_hba->debugfs_dir = debugfs_create_dir(dev_name(dev),
|
hisi_hba->debugfs_dump_dentry =
|
||||||
hisi_sas_debugfs_dir);
|
debugfs_create_dir("dump", hisi_hba->debugfs_dir);
|
||||||
debugfs_create_file("trigger_dump", 0600,
|
|
||||||
hisi_hba->debugfs_dir,
|
|
||||||
hisi_hba,
|
|
||||||
&hisi_sas_debugfs_trigger_dump_fops);
|
|
||||||
|
|
||||||
sz = hw->debugfs_reg_array[DEBUGFS_GLOBAL]->count * 4;
|
sz = hw->debugfs_reg_array[DEBUGFS_GLOBAL]->count * 4;
|
||||||
hisi_hba->debugfs_regs[DEBUGFS_GLOBAL] =
|
hisi_hba->debugfs_regs[DEBUGFS_GLOBAL] =
|
||||||
devm_kmalloc(dev, sz, GFP_KERNEL);
|
devm_kmalloc(dev, sz, GFP_KERNEL);
|
||||||
|
|
||||||
if (!hisi_hba->debugfs_regs[DEBUGFS_GLOBAL])
|
if (!hisi_hba->debugfs_regs[DEBUGFS_GLOBAL])
|
||||||
goto fail_global;
|
goto fail;
|
||||||
|
|
||||||
sz = hw->debugfs_reg_port->count * 4;
|
sz = hw->debugfs_reg_port->count * 4;
|
||||||
for (p = 0; p < hisi_hba->n_phy; p++) {
|
for (p = 0; p < hisi_hba->n_phy; p++) {
|
||||||
|
@ -3334,7 +3351,7 @@ void hisi_sas_debugfs_init(struct hisi_hba *hisi_hba)
|
||||||
devm_kmalloc(dev, sz, GFP_KERNEL);
|
devm_kmalloc(dev, sz, GFP_KERNEL);
|
||||||
|
|
||||||
if (!hisi_hba->debugfs_port_reg[p])
|
if (!hisi_hba->debugfs_port_reg[p])
|
||||||
goto fail_port;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
sz = hw->debugfs_reg_array[DEBUGFS_AXI]->count * 4;
|
sz = hw->debugfs_reg_array[DEBUGFS_AXI]->count * 4;
|
||||||
|
@ -3342,14 +3359,14 @@ void hisi_sas_debugfs_init(struct hisi_hba *hisi_hba)
|
||||||
devm_kmalloc(dev, sz, GFP_KERNEL);
|
devm_kmalloc(dev, sz, GFP_KERNEL);
|
||||||
|
|
||||||
if (!hisi_hba->debugfs_regs[DEBUGFS_AXI])
|
if (!hisi_hba->debugfs_regs[DEBUGFS_AXI])
|
||||||
goto fail_axi;
|
goto fail;
|
||||||
|
|
||||||
sz = hw->debugfs_reg_array[DEBUGFS_RAS]->count * 4;
|
sz = hw->debugfs_reg_array[DEBUGFS_RAS]->count * 4;
|
||||||
hisi_hba->debugfs_regs[DEBUGFS_RAS] =
|
hisi_hba->debugfs_regs[DEBUGFS_RAS] =
|
||||||
devm_kmalloc(dev, sz, GFP_KERNEL);
|
devm_kmalloc(dev, sz, GFP_KERNEL);
|
||||||
|
|
||||||
if (!hisi_hba->debugfs_regs[DEBUGFS_RAS])
|
if (!hisi_hba->debugfs_regs[DEBUGFS_RAS])
|
||||||
goto fail_ras;
|
goto fail;
|
||||||
|
|
||||||
sz = hw->complete_hdr_size * HISI_SAS_QUEUE_SLOTS;
|
sz = hw->complete_hdr_size * HISI_SAS_QUEUE_SLOTS;
|
||||||
for (c = 0; c < hisi_hba->queue_count; c++) {
|
for (c = 0; c < hisi_hba->queue_count; c++) {
|
||||||
|
@ -3357,7 +3374,7 @@ void hisi_sas_debugfs_init(struct hisi_hba *hisi_hba)
|
||||||
devm_kmalloc(dev, sz, GFP_KERNEL);
|
devm_kmalloc(dev, sz, GFP_KERNEL);
|
||||||
|
|
||||||
if (!hisi_hba->debugfs_complete_hdr[c])
|
if (!hisi_hba->debugfs_complete_hdr[c])
|
||||||
goto fail_cq;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
sz = sizeof(struct hisi_sas_cmd_hdr) * HISI_SAS_QUEUE_SLOTS;
|
sz = sizeof(struct hisi_sas_cmd_hdr) * HISI_SAS_QUEUE_SLOTS;
|
||||||
|
@ -3366,60 +3383,57 @@ void hisi_sas_debugfs_init(struct hisi_hba *hisi_hba)
|
||||||
devm_kmalloc(dev, sz, GFP_KERNEL);
|
devm_kmalloc(dev, sz, GFP_KERNEL);
|
||||||
|
|
||||||
if (!hisi_hba->debugfs_cmd_hdr[d])
|
if (!hisi_hba->debugfs_cmd_hdr[d])
|
||||||
goto fail_iost_dq;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
sz = max_command_entries * sizeof(struct hisi_sas_iost);
|
sz = HISI_SAS_MAX_COMMANDS * sizeof(struct hisi_sas_iost);
|
||||||
|
|
||||||
hisi_hba->debugfs_iost = devm_kmalloc(dev, sz, GFP_KERNEL);
|
hisi_hba->debugfs_iost = devm_kmalloc(dev, sz, GFP_KERNEL);
|
||||||
if (!hisi_hba->debugfs_iost)
|
if (!hisi_hba->debugfs_iost)
|
||||||
goto fail_iost_dq;
|
goto fail;
|
||||||
|
|
||||||
sz = HISI_SAS_IOST_ITCT_CACHE_NUM *
|
sz = HISI_SAS_IOST_ITCT_CACHE_NUM *
|
||||||
sizeof(struct hisi_sas_iost_itct_cache);
|
sizeof(struct hisi_sas_iost_itct_cache);
|
||||||
|
|
||||||
hisi_hba->debugfs_iost_cache = devm_kmalloc(dev, sz, GFP_KERNEL);
|
hisi_hba->debugfs_iost_cache = devm_kmalloc(dev, sz, GFP_KERNEL);
|
||||||
if (!hisi_hba->debugfs_iost_cache)
|
if (!hisi_hba->debugfs_iost_cache)
|
||||||
goto fail_iost_cache;
|
goto fail;
|
||||||
|
|
||||||
sz = HISI_SAS_IOST_ITCT_CACHE_NUM *
|
sz = HISI_SAS_IOST_ITCT_CACHE_NUM *
|
||||||
sizeof(struct hisi_sas_iost_itct_cache);
|
sizeof(struct hisi_sas_iost_itct_cache);
|
||||||
|
|
||||||
hisi_hba->debugfs_itct_cache = devm_kmalloc(dev, sz, GFP_KERNEL);
|
hisi_hba->debugfs_itct_cache = devm_kmalloc(dev, sz, GFP_KERNEL);
|
||||||
if (!hisi_hba->debugfs_itct_cache)
|
if (!hisi_hba->debugfs_itct_cache)
|
||||||
goto fail_itct_cache;
|
goto fail;
|
||||||
|
|
||||||
/* New memory allocation must be locate before itct */
|
/* New memory allocation must be locate before itct */
|
||||||
sz = HISI_SAS_MAX_ITCT_ENTRIES * sizeof(struct hisi_sas_itct);
|
sz = HISI_SAS_MAX_ITCT_ENTRIES * sizeof(struct hisi_sas_itct);
|
||||||
|
|
||||||
hisi_hba->debugfs_itct = devm_kmalloc(dev, sz, GFP_KERNEL);
|
hisi_hba->debugfs_itct = devm_kmalloc(dev, sz, GFP_KERNEL);
|
||||||
if (!hisi_hba->debugfs_itct)
|
if (!hisi_hba->debugfs_itct)
|
||||||
goto fail_itct;
|
goto fail;
|
||||||
|
|
||||||
return;
|
return 0;
|
||||||
fail_itct:
|
fail:
|
||||||
devm_kfree(dev, hisi_hba->debugfs_iost_cache);
|
hisi_sas_debugfs_release(hisi_hba);
|
||||||
fail_itct_cache:
|
return -ENOMEM;
|
||||||
devm_kfree(dev, hisi_hba->debugfs_iost_cache);
|
}
|
||||||
fail_iost_cache:
|
|
||||||
devm_kfree(dev, hisi_hba->debugfs_iost);
|
void hisi_sas_debugfs_init(struct hisi_hba *hisi_hba)
|
||||||
fail_iost_dq:
|
{
|
||||||
for (i = 0; i < d; i++)
|
struct device *dev = hisi_hba->dev;
|
||||||
devm_kfree(dev, hisi_hba->debugfs_cmd_hdr[i]);
|
|
||||||
fail_cq:
|
hisi_hba->debugfs_dir = debugfs_create_dir(dev_name(dev),
|
||||||
for (i = 0; i < c; i++)
|
hisi_sas_debugfs_dir);
|
||||||
devm_kfree(dev, hisi_hba->debugfs_complete_hdr[i]);
|
debugfs_create_file("trigger_dump", 0600,
|
||||||
devm_kfree(dev, hisi_hba->debugfs_regs[DEBUGFS_RAS]);
|
hisi_hba->debugfs_dir,
|
||||||
fail_ras:
|
hisi_hba,
|
||||||
devm_kfree(dev, hisi_hba->debugfs_regs[DEBUGFS_AXI]);
|
&hisi_sas_debugfs_trigger_dump_fops);
|
||||||
fail_axi:
|
|
||||||
fail_port:
|
if (hisi_sas_debugfs_alloc(hisi_hba)) {
|
||||||
for (i = 0; i < p; i++)
|
debugfs_remove_recursive(hisi_hba->debugfs_dir);
|
||||||
devm_kfree(dev, hisi_hba->debugfs_port_reg[i]);
|
dev_dbg(dev, "failed to init debugfs!\n");
|
||||||
devm_kfree(dev, hisi_hba->debugfs_regs[DEBUGFS_GLOBAL]);
|
}
|
||||||
fail_global:
|
|
||||||
debugfs_remove_recursive(hisi_hba->debugfs_dir);
|
|
||||||
dev_dbg(dev, "failed to init debugfs!\n");
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(hisi_sas_debugfs_init);
|
EXPORT_SYMBOL_GPL(hisi_sas_debugfs_init);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue