162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */
262306a36Sopenharmony_ci/* Copyright(c) 2013 - 2018 Intel Corporation. */
362306a36Sopenharmony_ci
462306a36Sopenharmony_ci#ifndef _I40E_OSDEP_H_
562306a36Sopenharmony_ci#define _I40E_OSDEP_H_
662306a36Sopenharmony_ci
762306a36Sopenharmony_ci#include <linux/types.h>
862306a36Sopenharmony_ci#include <linux/if_ether.h>
962306a36Sopenharmony_ci#include <linux/if_vlan.h>
1062306a36Sopenharmony_ci#include <linux/tcp.h>
1162306a36Sopenharmony_ci#include <linux/pci.h>
1262306a36Sopenharmony_ci#include <linux/highuid.h>
1362306a36Sopenharmony_ci
1462306a36Sopenharmony_ci/* get readq/writeq support for 32 bit kernels, use the low-first version */
1562306a36Sopenharmony_ci#include <linux/io-64-nonatomic-lo-hi.h>
1662306a36Sopenharmony_ci
1762306a36Sopenharmony_ci/* File to be the magic between shared code and
1862306a36Sopenharmony_ci * actual OS primitives
1962306a36Sopenharmony_ci */
2062306a36Sopenharmony_ci
2162306a36Sopenharmony_ci#define hw_dbg(hw, S, A...)							\
2262306a36Sopenharmony_cido {										\
2362306a36Sopenharmony_ci	dev_dbg(&((struct i40e_pf *)hw->back)->pdev->dev, S, ##A);		\
2462306a36Sopenharmony_ci} while (0)
2562306a36Sopenharmony_ci
2662306a36Sopenharmony_ci#define wr32(a, reg, value)	writel((value), ((a)->hw_addr + (reg)))
2762306a36Sopenharmony_ci#define rd32(a, reg)		readl((a)->hw_addr + (reg))
2862306a36Sopenharmony_ci
2962306a36Sopenharmony_ci#define rd64(a, reg)		readq((a)->hw_addr + (reg))
3062306a36Sopenharmony_ci#define i40e_flush(a)		readl((a)->hw_addr + I40E_GLGEN_STAT)
3162306a36Sopenharmony_ci
3262306a36Sopenharmony_ci/* memory allocation tracking */
3362306a36Sopenharmony_cistruct i40e_dma_mem {
3462306a36Sopenharmony_ci	void *va;
3562306a36Sopenharmony_ci	dma_addr_t pa;
3662306a36Sopenharmony_ci	u32 size;
3762306a36Sopenharmony_ci};
3862306a36Sopenharmony_ci
3962306a36Sopenharmony_ci#define i40e_allocate_dma_mem(h, m, unused, s, a) \
4062306a36Sopenharmony_ci			i40e_allocate_dma_mem_d(h, m, s, a)
4162306a36Sopenharmony_ci#define i40e_free_dma_mem(h, m) i40e_free_dma_mem_d(h, m)
4262306a36Sopenharmony_ci
4362306a36Sopenharmony_cistruct i40e_virt_mem {
4462306a36Sopenharmony_ci	void *va;
4562306a36Sopenharmony_ci	u32 size;
4662306a36Sopenharmony_ci};
4762306a36Sopenharmony_ci
4862306a36Sopenharmony_ci#define i40e_allocate_virt_mem(h, m, s) i40e_allocate_virt_mem_d(h, m, s)
4962306a36Sopenharmony_ci#define i40e_free_virt_mem(h, m) i40e_free_virt_mem_d(h, m)
5062306a36Sopenharmony_ci
5162306a36Sopenharmony_ci#define i40e_debug(h, m, s, ...)				\
5262306a36Sopenharmony_cido {								\
5362306a36Sopenharmony_ci	if (((m) & (h)->debug_mask))				\
5462306a36Sopenharmony_ci		pr_info("i40e %02x:%02x.%x " s,			\
5562306a36Sopenharmony_ci			(h)->bus.bus_id, (h)->bus.device,	\
5662306a36Sopenharmony_ci			(h)->bus.func, ##__VA_ARGS__);		\
5762306a36Sopenharmony_ci} while (0)
5862306a36Sopenharmony_ci
5962306a36Sopenharmony_ci#endif /* _I40E_OSDEP_H_ */
60