Lines Matching refs:accel_dev

88 static void adf_cleanup_pci_dev(struct adf_accel_dev *accel_dev)  in adf_cleanup_pci_dev()  argument
90 pci_release_regions(accel_dev->accel_pci_dev.pci_dev); in adf_cleanup_pci_dev()
91 pci_disable_device(accel_dev->accel_pci_dev.pci_dev); in adf_cleanup_pci_dev()
94 static void adf_cleanup_accel(struct adf_accel_dev *accel_dev) in adf_cleanup_accel() argument
96 struct adf_accel_pci *accel_pci_dev = &accel_dev->accel_pci_dev; in adf_cleanup_accel()
107 if (accel_dev->hw_device) { in adf_cleanup_accel()
110 adf_clean_hw_data_dh895xcciov(accel_dev->hw_device); in adf_cleanup_accel()
115 kfree(accel_dev->hw_device); in adf_cleanup_accel()
116 accel_dev->hw_device = NULL; in adf_cleanup_accel()
118 adf_cfg_dev_remove(accel_dev); in adf_cleanup_accel()
119 debugfs_remove(accel_dev->debugfs_dir); in adf_cleanup_accel()
121 adf_devmgr_rm_dev(accel_dev, pf); in adf_cleanup_accel()
124 static int adf_dev_configure(struct adf_accel_dev *accel_dev) in adf_dev_configure() argument
129 if (adf_cfg_section_add(accel_dev, ADF_KERNEL_SEC)) in adf_dev_configure()
131 if (adf_cfg_section_add(accel_dev, "Accelerator0")) in adf_dev_configure()
135 if (adf_cfg_add_key_value_param(accel_dev, ADF_KERNEL_SEC, key, in adf_dev_configure()
141 if (adf_cfg_add_key_value_param(accel_dev, ADF_KERNEL_SEC, key, in adf_dev_configure()
148 if (adf_cfg_add_key_value_param(accel_dev, ADF_KERNEL_SEC, key, in adf_dev_configure()
154 if (adf_cfg_add_key_value_param(accel_dev, ADF_KERNEL_SEC, in adf_dev_configure()
160 if (adf_cfg_add_key_value_param(accel_dev, ADF_KERNEL_SEC, in adf_dev_configure()
166 if (adf_cfg_add_key_value_param(accel_dev, ADF_KERNEL_SEC, in adf_dev_configure()
172 if (adf_cfg_add_key_value_param(accel_dev, ADF_KERNEL_SEC, in adf_dev_configure()
178 if (adf_cfg_add_key_value_param(accel_dev, ADF_KERNEL_SEC, in adf_dev_configure()
185 if (adf_cfg_add_key_value_param(accel_dev, "Accelerator0", in adf_dev_configure()
190 if (adf_cfg_add_key_value_param(accel_dev, ADF_KERNEL_SEC, in adf_dev_configure()
194 set_bit(ADF_STATUS_CONFIGURED, &accel_dev->status); in adf_dev_configure()
197 dev_err(&GET_DEV(accel_dev), "Failed to configure QAT accel dev\n"); in adf_dev_configure()
203 struct adf_accel_dev *accel_dev; in adf_probe() local
219 accel_dev = kzalloc_node(sizeof(*accel_dev), GFP_KERNEL, in adf_probe()
221 if (!accel_dev) in adf_probe()
224 accel_dev->is_vf = true; in adf_probe()
226 accel_pci_dev = &accel_dev->accel_pci_dev; in adf_probe()
230 if (adf_devmgr_add_dev(accel_dev, pf)) { in adf_probe()
232 kfree(accel_dev); in adf_probe()
235 INIT_LIST_HEAD(&accel_dev->crypto_list); in adf_probe()
237 accel_dev->owner = THIS_MODULE; in adf_probe()
245 accel_dev->hw_device = hw_data; in adf_probe()
248 adf_init_hw_data_dh895xcciov(accel_dev->hw_device); in adf_probe()
266 accel_dev->debugfs_dir = debugfs_create_dir(name, NULL); in adf_probe()
267 if (!accel_dev->debugfs_dir) { in adf_probe()
274 ret = adf_cfg_dev_add(accel_dev); in adf_probe()
323 init_completion(&accel_dev->vf.iov_msg_completion); in adf_probe()
325 ret = adf_dev_configure(accel_dev); in adf_probe()
329 ret = adf_dev_init(accel_dev); in adf_probe()
333 ret = adf_dev_start(accel_dev); in adf_probe()
340 adf_dev_stop(accel_dev); in adf_probe()
342 adf_dev_shutdown(accel_dev); in adf_probe()
348 adf_cleanup_accel(accel_dev); in adf_probe()
349 kfree(accel_dev); in adf_probe()
355 struct adf_accel_dev *accel_dev = adf_devmgr_pci_to_accel_dev(pdev); in adf_remove() local
357 if (!accel_dev) { in adf_remove()
361 if (adf_dev_stop(accel_dev)) in adf_remove()
362 dev_err(&GET_DEV(accel_dev), "Failed to stop QAT accel dev\n"); in adf_remove()
364 adf_dev_shutdown(accel_dev); in adf_remove()
365 adf_cleanup_accel(accel_dev); in adf_remove()
366 adf_cleanup_pci_dev(accel_dev); in adf_remove()
367 kfree(accel_dev); in adf_remove()