2020-05-27 16:21:28 +01:00
/* SPDX-License-Identifier: (BSD-3-Clause OR GPL-2.0-only) */
/* Copyright(c) 2014 - 2020 Intel Corporation */
2014-06-05 13:42:39 -07:00
# ifndef ADF_DRV_H
# define ADF_DRV_H
# include <linux/list.h>
# include <linux/pci.h>
# include "adf_accel_devices.h"
# include "icp_qat_fw_loader_handle.h"
# include "icp_qat_hal.h"
2015-05-07 17:00:42 -07:00
# define ADF_MAJOR_VERSION 0
2015-12-04 16:56:28 -08:00
# define ADF_MINOR_VERSION 6
2015-08-07 11:34:25 -07:00
# define ADF_BUILD_VERSION 0
2015-05-07 17:00:42 -07:00
# define ADF_DRV_VERSION __stringify(ADF_MAJOR_VERSION) "." \
__stringify ( ADF_MINOR_VERSION ) " . " \
__stringify ( ADF_BUILD_VERSION )
2014-06-05 13:42:39 -07:00
# define ADF_STATUS_RESTARTING 0
# define ADF_STATUS_STARTING 1
# define ADF_STATUS_CONFIGURED 2
# define ADF_STATUS_STARTED 3
# define ADF_STATUS_AE_INITIALISED 4
# define ADF_STATUS_AE_UCODE_LOADED 5
# define ADF_STATUS_AE_STARTED 6
2016-04-15 10:37:59 -07:00
# define ADF_STATUS_PF_RUNNING 7
2014-06-05 13:42:39 -07:00
# define ADF_STATUS_IRQ_ALLOCATED 8
enum adf_dev_reset_mode {
ADF_DEV_RESET_ASYNC = 0 ,
ADF_DEV_RESET_SYNC
} ;
enum adf_event {
ADF_EVENT_INIT = 0 ,
ADF_EVENT_START ,
ADF_EVENT_STOP ,
ADF_EVENT_SHUTDOWN ,
ADF_EVENT_RESTARTING ,
ADF_EVENT_RESTARTED ,
} ;
struct service_hndl {
int ( * event_hld ) ( struct adf_accel_dev * accel_dev ,
enum adf_event event ) ;
2016-12-22 15:01:02 +00:00
unsigned long init_status [ ADF_DEVS_ARRAY_SIZE ] ;
unsigned long start_status [ ADF_DEVS_ARRAY_SIZE ] ;
2014-06-05 13:42:39 -07:00
char * name ;
struct list_head list ;
} ;
2015-07-15 15:28:38 -07:00
static inline int get_current_node ( void )
{
2019-07-23 07:24:01 +00:00
return topology_physical_package_id ( raw_smp_processor_id ( ) ) ;
2015-07-15 15:28:38 -07:00
}
2014-06-05 13:42:39 -07:00
int adf_service_register ( struct service_hndl * service ) ;
int adf_service_unregister ( struct service_hndl * service ) ;
int adf_dev_init ( struct adf_accel_dev * accel_dev ) ;
int adf_dev_start ( struct adf_accel_dev * accel_dev ) ;
2016-03-29 10:21:07 -07:00
void adf_dev_stop ( struct adf_accel_dev * accel_dev ) ;
crypto: qat - fix device reset flow
When the device needs a reset, e.g. when an uncorrectable PCIe AER event
occurs, various services/data structures need to be cleaned up, the
hardware reset and the services/data structures initialized and started.
The code to perform the cleanup and initialization was not performed when
a device reset was done.
This patch moves some of the initialization code out of the .probe entry-
point into a separate function that is now called during probe as well as
after the hardware has been reset. Similarly, a new function is added for
first cleaning up these services/data structures prior to resetting. The
new functions are adf_dev_init() and adf_dev_shutdown(), respectively, for
which there are already prototypes but no actual functions just yet and are
now called when the device is reset and during probe/cleanup of the driver.
The down and up flows via ioctl calls has similarly been updated.
In addition, there are two other bugs in the reset flow - one in the logic
for determining whether to schedule a device reset upon receiving an
uncorrectable AER event which prevents the reset flow from being initiated,
and another with clearing the status bit indicating a device is configured
(when resetting the device the configuration remains across the reset so
the bit should not be cleared, otherwise, the necessary services will not
be re-started in adf_dev_start() after the reset - clear the bit only when
actually deleting the configuration).
Signed-off-by: Bruce Allan <bruce.w.allan@intel.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
2015-01-09 11:54:58 -08:00
void adf_dev_shutdown ( struct adf_accel_dev * accel_dev ) ;
2014-06-05 13:42:39 -07:00
2015-08-07 11:34:25 -07:00
int adf_iov_putmsg ( struct adf_accel_dev * accel_dev , u32 msg , u8 vf_nr ) ;
void adf_pf2vf_notify_restarting ( struct adf_accel_dev * accel_dev ) ;
int adf_enable_vf2pf_comms ( struct adf_accel_dev * accel_dev ) ;
2015-08-24 11:56:02 -07:00
void adf_vf2pf_req_hndl ( struct adf_accel_vf_info * vf_info ) ;
2015-08-07 11:34:25 -07:00
void adf_devmgr_update_class_index ( struct adf_hw_device_data * hw_data ) ;
void adf_clean_vf_map ( bool ) ;
2014-06-05 13:42:39 -07:00
int adf_ctl_dev_register ( void ) ;
void adf_ctl_dev_unregister ( void ) ;
int adf_processes_dev_register ( void ) ;
void adf_processes_dev_unregister ( void ) ;
2015-08-07 11:34:25 -07:00
int adf_devmgr_add_dev ( struct adf_accel_dev * accel_dev ,
struct adf_accel_dev * pf ) ;
void adf_devmgr_rm_dev ( struct adf_accel_dev * accel_dev ,
struct adf_accel_dev * pf ) ;
2014-06-05 13:42:39 -07:00
struct list_head * adf_devmgr_get_head ( void ) ;
2020-06-03 18:33:44 +01:00
struct adf_accel_dev * adf_devmgr_get_dev_by_id ( u32 id ) ;
2014-06-05 13:42:39 -07:00
struct adf_accel_dev * adf_devmgr_get_first ( void ) ;
struct adf_accel_dev * adf_devmgr_pci_to_accel_dev ( struct pci_dev * pci_dev ) ;
2020-06-03 18:33:44 +01:00
int adf_devmgr_verify_id ( u32 id ) ;
void adf_devmgr_get_num_dev ( u32 * num ) ;
2014-06-05 13:42:39 -07:00
int adf_devmgr_in_reset ( struct adf_accel_dev * accel_dev ) ;
int adf_dev_started ( struct adf_accel_dev * accel_dev ) ;
int adf_dev_restarting_notify ( struct adf_accel_dev * accel_dev ) ;
int adf_dev_restarted_notify ( struct adf_accel_dev * accel_dev ) ;
int adf_ae_init ( struct adf_accel_dev * accel_dev ) ;
int adf_ae_shutdown ( struct adf_accel_dev * accel_dev ) ;
int adf_ae_fw_load ( struct adf_accel_dev * accel_dev ) ;
2015-04-03 08:41:17 -07:00
void adf_ae_fw_release ( struct adf_accel_dev * accel_dev ) ;
2014-06-05 13:42:39 -07:00
int adf_ae_start ( struct adf_accel_dev * accel_dev ) ;
int adf_ae_stop ( struct adf_accel_dev * accel_dev ) ;
2020-09-30 23:22:11 +01:00
int adf_enable_aer ( struct adf_accel_dev * accel_dev ) ;
2014-06-05 13:42:39 -07:00
void adf_disable_aer ( struct adf_accel_dev * accel_dev ) ;
2016-07-04 16:26:00 +01:00
void adf_reset_sbr ( struct adf_accel_dev * accel_dev ) ;
void adf_reset_flr ( struct adf_accel_dev * accel_dev ) ;
2015-12-04 16:56:28 -08:00
void adf_dev_restore ( struct adf_accel_dev * accel_dev ) ;
2014-06-05 13:42:39 -07:00
int adf_init_aer ( void ) ;
void adf_exit_aer ( void ) ;
2015-08-07 11:34:20 -07:00
int adf_init_admin_comms ( struct adf_accel_dev * accel_dev ) ;
void adf_exit_admin_comms ( struct adf_accel_dev * accel_dev ) ;
int adf_send_admin_init ( struct adf_accel_dev * accel_dev ) ;
int adf_init_arb ( struct adf_accel_dev * accel_dev ) ;
void adf_exit_arb ( struct adf_accel_dev * accel_dev ) ;
void adf_update_ring_arb ( struct adf_etr_ring_data * ring ) ;
2014-06-05 13:42:39 -07:00
int adf_dev_get ( struct adf_accel_dev * accel_dev ) ;
void adf_dev_put ( struct adf_accel_dev * accel_dev ) ;
int adf_dev_in_use ( struct adf_accel_dev * accel_dev ) ;
int adf_init_etr_data ( struct adf_accel_dev * accel_dev ) ;
void adf_cleanup_etr_data ( struct adf_accel_dev * accel_dev ) ;
int qat_crypto_register ( void ) ;
int qat_crypto_unregister ( void ) ;
2015-12-04 16:56:28 -08:00
int qat_crypto_dev_config ( struct adf_accel_dev * accel_dev ) ;
2014-06-05 13:42:39 -07:00
struct qat_crypto_instance * qat_crypto_get_instance_node ( int node ) ;
void qat_crypto_put_instance ( struct qat_crypto_instance * inst ) ;
void qat_alg_callback ( void * resp ) ;
2015-07-15 15:28:38 -07:00
void qat_alg_asym_callback ( void * resp ) ;
2014-06-05 13:42:39 -07:00
int qat_algs_register ( void ) ;
2015-09-22 11:57:47 -07:00
void qat_algs_unregister ( void ) ;
2015-07-15 15:28:38 -07:00
int qat_asym_algs_register ( void ) ;
void qat_asym_algs_unregister ( void ) ;
2014-06-05 13:42:39 -07:00
2015-12-04 16:56:28 -08:00
int adf_isr_resource_alloc ( struct adf_accel_dev * accel_dev ) ;
void adf_isr_resource_free ( struct adf_accel_dev * accel_dev ) ;
int adf_vf_isr_resource_alloc ( struct adf_accel_dev * accel_dev ) ;
void adf_vf_isr_resource_free ( struct adf_accel_dev * accel_dev ) ;
2014-06-05 13:42:39 -07:00
int qat_hal_init ( struct adf_accel_dev * accel_dev ) ;
void qat_hal_deinit ( struct icp_qat_fw_loader_handle * handle ) ;
2020-11-06 19:27:49 +08:00
int qat_hal_start ( struct icp_qat_fw_loader_handle * handle ) ;
2014-06-05 13:42:39 -07:00
void qat_hal_stop ( struct icp_qat_fw_loader_handle * handle , unsigned char ae ,
unsigned int ctx_mask ) ;
void qat_hal_reset ( struct icp_qat_fw_loader_handle * handle ) ;
int qat_hal_clr_reset ( struct icp_qat_fw_loader_handle * handle ) ;
void qat_hal_set_live_ctx ( struct icp_qat_fw_loader_handle * handle ,
unsigned char ae , unsigned int ctx_mask ) ;
2015-12-04 16:56:23 -08:00
int qat_hal_check_ae_active ( struct icp_qat_fw_loader_handle * handle ,
unsigned int ae ) ;
2014-06-05 13:42:39 -07:00
int qat_hal_set_ae_lm_mode ( struct icp_qat_fw_loader_handle * handle ,
unsigned char ae , enum icp_qat_uof_regtype lm_type ,
unsigned char mode ) ;
int qat_hal_set_ae_ctx_mode ( struct icp_qat_fw_loader_handle * handle ,
unsigned char ae , unsigned char mode ) ;
int qat_hal_set_ae_nn_mode ( struct icp_qat_fw_loader_handle * handle ,
unsigned char ae , unsigned char mode ) ;
void qat_hal_set_pc ( struct icp_qat_fw_loader_handle * handle ,
unsigned char ae , unsigned int ctx_mask , unsigned int upc ) ;
void qat_hal_wr_uwords ( struct icp_qat_fw_loader_handle * handle ,
unsigned char ae , unsigned int uaddr ,
2020-06-03 18:33:44 +01:00
unsigned int words_num , u64 * uword ) ;
2014-06-05 13:42:39 -07:00
void qat_hal_wr_umem ( struct icp_qat_fw_loader_handle * handle , unsigned char ae ,
unsigned int uword_addr , unsigned int words_num ,
unsigned int * data ) ;
int qat_hal_get_ins_num ( void ) ;
int qat_hal_batch_wr_lm ( struct icp_qat_fw_loader_handle * handle ,
unsigned char ae ,
struct icp_qat_uof_batch_init * lm_init_header ) ;
int qat_hal_init_gpr ( struct icp_qat_fw_loader_handle * handle ,
2020-11-06 19:27:47 +08:00
unsigned char ae , unsigned long ctx_mask ,
2014-06-05 13:42:39 -07:00
enum icp_qat_uof_regtype reg_type ,
unsigned short reg_num , unsigned int regdata ) ;
int qat_hal_init_wr_xfer ( struct icp_qat_fw_loader_handle * handle ,
2020-11-06 19:27:47 +08:00
unsigned char ae , unsigned long ctx_mask ,
2014-06-05 13:42:39 -07:00
enum icp_qat_uof_regtype reg_type ,
unsigned short reg_num , unsigned int regdata ) ;
int qat_hal_init_rd_xfer ( struct icp_qat_fw_loader_handle * handle ,
2020-11-06 19:27:47 +08:00
unsigned char ae , unsigned long ctx_mask ,
2014-06-05 13:42:39 -07:00
enum icp_qat_uof_regtype reg_type ,
unsigned short reg_num , unsigned int regdata ) ;
int qat_hal_init_nn ( struct icp_qat_fw_loader_handle * handle ,
2020-11-06 19:27:47 +08:00
unsigned char ae , unsigned long ctx_mask ,
2014-06-05 13:42:39 -07:00
unsigned short reg_num , unsigned int regdata ) ;
int qat_hal_wr_lm ( struct icp_qat_fw_loader_handle * handle ,
unsigned char ae , unsigned short lm_addr , unsigned int value ) ;
2020-11-06 19:27:57 +08:00
void qat_hal_set_ae_tindex_mode ( struct icp_qat_fw_loader_handle * handle ,
unsigned char ae , unsigned char mode ) ;
2014-06-05 13:42:39 -07:00
int qat_uclo_wr_all_uimage ( struct icp_qat_fw_loader_handle * handle ) ;
2020-11-06 19:27:45 +08:00
void qat_uclo_del_obj ( struct icp_qat_fw_loader_handle * handle ) ;
2015-12-04 16:56:23 -08:00
int qat_uclo_wr_mimage ( struct icp_qat_fw_loader_handle * handle , void * addr_ptr ,
int mem_size ) ;
int qat_uclo_map_obj ( struct icp_qat_fw_loader_handle * handle ,
2020-11-06 19:27:39 +08:00
void * addr_ptr , u32 mem_size , char * obj_name ) ;
2020-11-06 19:28:07 +08:00
int qat_uclo_set_cfg_ae_mask ( struct icp_qat_fw_loader_handle * handle ,
unsigned int cfg_ae_mask ) ;
2015-08-07 11:34:25 -07:00
# if defined(CONFIG_PCI_IOV)
int adf_sriov_configure ( struct pci_dev * pdev , int numvfs ) ;
void adf_disable_sriov ( struct adf_accel_dev * accel_dev ) ;
void adf_disable_vf2pf_interrupts ( struct adf_accel_dev * accel_dev ,
2020-06-03 18:33:44 +01:00
u32 vf_mask ) ;
2015-08-07 11:34:25 -07:00
void adf_enable_vf2pf_interrupts ( struct adf_accel_dev * accel_dev ,
2020-06-03 18:33:44 +01:00
u32 vf_mask ) ;
2015-12-23 06:49:58 -08:00
void adf_enable_pf2vf_interrupts ( struct adf_accel_dev * accel_dev ) ;
void adf_disable_pf2vf_interrupts ( struct adf_accel_dev * accel_dev ) ;
2016-04-15 10:37:58 -07:00
int adf_vf2pf_init ( struct adf_accel_dev * accel_dev ) ;
void adf_vf2pf_shutdown ( struct adf_accel_dev * accel_dev ) ;
2016-04-29 10:43:40 -07:00
int adf_init_pf_wq ( void ) ;
void adf_exit_pf_wq ( void ) ;
2016-04-29 11:00:00 -07:00
int adf_init_vf_wq ( void ) ;
void adf_exit_vf_wq ( void ) ;
2015-08-07 11:34:25 -07:00
# else
static inline int adf_sriov_configure ( struct pci_dev * pdev , int numvfs )
{
return 0 ;
}
static inline void adf_disable_sriov ( struct adf_accel_dev * accel_dev )
{
}
2015-12-23 06:49:58 -08:00
static inline void adf_enable_pf2vf_interrupts ( struct adf_accel_dev * accel_dev )
{
}
static inline void adf_disable_pf2vf_interrupts ( struct adf_accel_dev * accel_dev )
{
}
2016-04-15 10:37:58 -07:00
static inline int adf_vf2pf_init ( struct adf_accel_dev * accel_dev )
{
return 0 ;
}
static inline void adf_vf2pf_shutdown ( struct adf_accel_dev * accel_dev )
{
}
2016-05-03 16:01:52 +08:00
2016-04-29 10:43:40 -07:00
static inline int adf_init_pf_wq ( void )
{
return 0 ;
}
static inline void adf_exit_pf_wq ( void )
{
}
2016-04-29 11:00:00 -07:00
static inline int adf_init_vf_wq ( void )
{
return 0 ;
}
static inline void adf_exit_vf_wq ( void )
{
}
2015-08-07 11:34:25 -07:00
# endif
2014-06-05 13:42:39 -07:00
# endif