xref: /freebsd/sys/dev/qat/include/common/adf_cfg.h (revision 71625ec9ad2a9bc8c09784fbd23b759830e0ee5f)
178ee8d1cSJulian Grajkowski /* SPDX-License-Identifier: BSD-3-Clause */
278ee8d1cSJulian Grajkowski /* Copyright(c) 2007-2022 Intel Corporation */
378ee8d1cSJulian Grajkowski #ifndef ADF_CFG_H_
478ee8d1cSJulian Grajkowski #define ADF_CFG_H_
578ee8d1cSJulian Grajkowski 
678ee8d1cSJulian Grajkowski #include <linux/rwsem.h>
778ee8d1cSJulian Grajkowski #include "adf_accel_devices.h"
878ee8d1cSJulian Grajkowski #include "adf_cfg_common.h"
978ee8d1cSJulian Grajkowski #include "adf_cfg_strings.h"
1078ee8d1cSJulian Grajkowski 
11*266b0663SKrzysztof Zdziarski #define ADF_CFG_MAX_VAL 16
12*266b0663SKrzysztof Zdziarski 
1378ee8d1cSJulian Grajkowski struct adf_cfg_key_val {
1478ee8d1cSJulian Grajkowski 	char key[ADF_CFG_MAX_KEY_LEN_IN_BYTES];
1578ee8d1cSJulian Grajkowski 	char val[ADF_CFG_MAX_VAL_LEN_IN_BYTES];
1678ee8d1cSJulian Grajkowski 	enum adf_cfg_val_type type;
1778ee8d1cSJulian Grajkowski 	struct list_head list;
1878ee8d1cSJulian Grajkowski };
1978ee8d1cSJulian Grajkowski 
2078ee8d1cSJulian Grajkowski struct adf_cfg_section {
2178ee8d1cSJulian Grajkowski 	char name[ADF_CFG_MAX_SECTION_LEN_IN_BYTES];
2278ee8d1cSJulian Grajkowski 	bool processed;
2378ee8d1cSJulian Grajkowski 	bool is_derived;
2478ee8d1cSJulian Grajkowski 	struct list_head list;
2578ee8d1cSJulian Grajkowski 	struct list_head param_head;
2678ee8d1cSJulian Grajkowski };
2778ee8d1cSJulian Grajkowski 
2878ee8d1cSJulian Grajkowski struct adf_cfg_device_data {
2978ee8d1cSJulian Grajkowski 	struct adf_cfg_device *dev;
3078ee8d1cSJulian Grajkowski 	struct list_head sec_list;
3178ee8d1cSJulian Grajkowski 	struct sysctl_oid *debug;
3278ee8d1cSJulian Grajkowski 	struct sx lock;
33*266b0663SKrzysztof Zdziarski 	char cfg_services[ADF_CFG_MAX_VAL];
34*266b0663SKrzysztof Zdziarski 	char cfg_mode[ADF_CFG_MAX_VAL];
35*266b0663SKrzysztof Zdziarski 	u16 num_user_processes;
3678ee8d1cSJulian Grajkowski };
3778ee8d1cSJulian Grajkowski 
3878ee8d1cSJulian Grajkowski struct adf_cfg_depot_list {
3978ee8d1cSJulian Grajkowski 	struct list_head sec_list;
4078ee8d1cSJulian Grajkowski };
4178ee8d1cSJulian Grajkowski 
4278ee8d1cSJulian Grajkowski int adf_cfg_dev_add(struct adf_accel_dev *accel_dev);
4378ee8d1cSJulian Grajkowski void adf_cfg_dev_remove(struct adf_accel_dev *accel_dev);
4478ee8d1cSJulian Grajkowski int adf_cfg_depot_restore_all(struct adf_accel_dev *accel_dev,
4578ee8d1cSJulian Grajkowski 			      struct adf_cfg_depot_list *dev_hp_cfg);
4678ee8d1cSJulian Grajkowski int adf_cfg_section_add(struct adf_accel_dev *accel_dev, const char *name);
4778ee8d1cSJulian Grajkowski void adf_cfg_del_all(struct adf_accel_dev *accel_dev);
4878ee8d1cSJulian Grajkowski void adf_cfg_depot_del_all(struct list_head *head);
4978ee8d1cSJulian Grajkowski int adf_cfg_add_key_value_param(struct adf_accel_dev *accel_dev,
5078ee8d1cSJulian Grajkowski 				const char *section_name,
5178ee8d1cSJulian Grajkowski 				const char *key,
5278ee8d1cSJulian Grajkowski 				const void *val,
5378ee8d1cSJulian Grajkowski 				enum adf_cfg_val_type type);
5478ee8d1cSJulian Grajkowski int adf_cfg_get_param_value(struct adf_accel_dev *accel_dev,
5578ee8d1cSJulian Grajkowski 			    const char *section,
5678ee8d1cSJulian Grajkowski 			    const char *name,
5778ee8d1cSJulian Grajkowski 			    char *value);
5878ee8d1cSJulian Grajkowski int adf_cfg_save_section(struct adf_accel_dev *accel_dev,
5978ee8d1cSJulian Grajkowski 			 const char *name,
6078ee8d1cSJulian Grajkowski 			 struct adf_cfg_section *section);
6178ee8d1cSJulian Grajkowski int adf_cfg_depot_save_all(struct adf_accel_dev *accel_dev,
6278ee8d1cSJulian Grajkowski 			   struct adf_cfg_depot_list *dev_hp_cfg);
6378ee8d1cSJulian Grajkowski struct adf_cfg_section *adf_cfg_sec_find(struct adf_accel_dev *accel_dev,
6478ee8d1cSJulian Grajkowski 					 const char *sec_name);
6578ee8d1cSJulian Grajkowski int adf_cfg_derived_section_add(struct adf_accel_dev *accel_dev,
6678ee8d1cSJulian Grajkowski 				const char *name);
6778ee8d1cSJulian Grajkowski int adf_cfg_remove_key_param(struct adf_accel_dev *accel_dev,
6878ee8d1cSJulian Grajkowski 			     const char *section_name,
6978ee8d1cSJulian Grajkowski 			     const char *key);
7078ee8d1cSJulian Grajkowski int adf_cfg_setup_irq(struct adf_accel_dev *accel_dev);
7178ee8d1cSJulian Grajkowski void adf_cfg_set_asym_rings_mask(struct adf_accel_dev *accel_dev);
7278ee8d1cSJulian Grajkowski void adf_cfg_gen_dispatch_arbiter(struct adf_accel_dev *accel_dev,
7378ee8d1cSJulian Grajkowski 				  const u32 *thrd_to_arb_map,
7478ee8d1cSJulian Grajkowski 				  u32 *thrd_to_arb_map_gen,
7578ee8d1cSJulian Grajkowski 				  u32 total_engines);
7678ee8d1cSJulian Grajkowski int adf_cfg_get_fw_image_type(struct adf_accel_dev *accel_dev,
7778ee8d1cSJulian Grajkowski 			      enum adf_cfg_fw_image_type *fw_image_type);
7878ee8d1cSJulian Grajkowski int adf_cfg_get_services_enabled(struct adf_accel_dev *accel_dev,
7978ee8d1cSJulian Grajkowski 				 u16 *ring_to_svc_map);
8078ee8d1cSJulian Grajkowski int adf_cfg_restore_section(struct adf_accel_dev *accel_dev,
8178ee8d1cSJulian Grajkowski 			    struct adf_cfg_section *section);
8278ee8d1cSJulian Grajkowski void adf_cfg_keyval_del_all(struct list_head *head);
83a977168cSMichal Gulbicki 
84a977168cSMichal Gulbicki static inline int
adf_cy_inst_cross_banks(struct adf_accel_dev * accel_dev)85a977168cSMichal Gulbicki adf_cy_inst_cross_banks(struct adf_accel_dev *accel_dev)
86a977168cSMichal Gulbicki {
87a977168cSMichal Gulbicki 	if (accel_dev->hw_device->num_rings_per_bank == 2)
88a977168cSMichal Gulbicki 		return 1;
89a977168cSMichal Gulbicki 	else
90a977168cSMichal Gulbicki 		return 0;
91a977168cSMichal Gulbicki }
92a977168cSMichal Gulbicki 
9378ee8d1cSJulian Grajkowski #endif
94