xref: /freebsd/sys/dev/qat/include/common/adf_pfvf_utils.h (revision 71625ec9ad2a9bc8c09784fbd23b759830e0ee5f)
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 Zdziarski adf_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