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