1*266b0663SKrzysztof Zdziarski /* SPDX-License-Identifier: BSD-3-Clause */ 2*266b0663SKrzysztof Zdziarski /* Copyright(c) 2007-2022 Intel Corporation */ 3*266b0663SKrzysztof Zdziarski #ifndef ADF_PFVF_UTILS_H 4*266b0663SKrzysztof Zdziarski #define ADF_PFVF_UTILS_H 5*266b0663SKrzysztof Zdziarski 6*266b0663SKrzysztof Zdziarski #include <linux/types.h> 7*266b0663SKrzysztof Zdziarski #include "adf_pfvf_msg.h" 8*266b0663SKrzysztof Zdziarski 9*266b0663SKrzysztof Zdziarski /* How long to wait for far side to acknowledge receipt */ 10*266b0663SKrzysztof Zdziarski #define ADF_PFVF_MSG_ACK_DELAY_US 4 11*266b0663SKrzysztof Zdziarski #define ADF_PFVF_MSG_ACK_MAX_DELAY_US (1 * USEC_PER_SEC) 12*266b0663SKrzysztof Zdziarski 13*266b0663SKrzysztof Zdziarski u8 adf_pfvf_calc_blkmsg_crc(u8 const *buf, u8 buf_len); 14*266b0663SKrzysztof Zdziarski 15*266b0663SKrzysztof Zdziarski struct pfvf_field_format { 16*266b0663SKrzysztof Zdziarski u8 offset; 17*266b0663SKrzysztof Zdziarski u32 mask; 18*266b0663SKrzysztof Zdziarski }; 19*266b0663SKrzysztof Zdziarski 20*266b0663SKrzysztof Zdziarski struct pfvf_csr_format { 21*266b0663SKrzysztof Zdziarski struct pfvf_field_format type; 22*266b0663SKrzysztof Zdziarski struct pfvf_field_format data; 23*266b0663SKrzysztof Zdziarski }; 24*266b0663SKrzysztof Zdziarski 25*266b0663SKrzysztof Zdziarski u32 adf_pfvf_csr_msg_of(struct adf_accel_dev *accel_dev, 26*266b0663SKrzysztof Zdziarski struct pfvf_message msg, 27*266b0663SKrzysztof Zdziarski const struct pfvf_csr_format *fmt); 28*266b0663SKrzysztof Zdziarski struct pfvf_message adf_pfvf_message_of(struct adf_accel_dev *accel_dev, 29*266b0663SKrzysztof Zdziarski u32 raw_msg, 30*266b0663SKrzysztof Zdziarski const struct pfvf_csr_format *fmt); 31*266b0663SKrzysztof Zdziarski 32*266b0663SKrzysztof Zdziarski static inline struct resource * adf_get_pmisc_base(struct adf_accel_dev * accel_dev)33*266b0663SKrzysztof Zdziarskiadf_get_pmisc_base(struct adf_accel_dev *accel_dev) 34*266b0663SKrzysztof Zdziarski { 35*266b0663SKrzysztof Zdziarski struct adf_hw_device_data *hw_data = accel_dev->hw_device; 36*266b0663SKrzysztof Zdziarski struct adf_bar *pmisc; 37*266b0663SKrzysztof Zdziarski 38*266b0663SKrzysztof Zdziarski pmisc = &GET_BARS(accel_dev)[hw_data->get_misc_bar_id(hw_data)]; 39*266b0663SKrzysztof Zdziarski 40*266b0663SKrzysztof Zdziarski return pmisc->virt_addr; 41*266b0663SKrzysztof Zdziarski } 42*266b0663SKrzysztof Zdziarski 43*266b0663SKrzysztof Zdziarski #endif /* ADF_PFVF_UTILS_H */ 44