hc
2024-08-14 865dc85cff0c170305dc18e865d2cb0b537a47ec
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/* SPDX-License-Identifier: GPL-2.0 */
/* Copyright (c) 2018, Intel Corporation. */
 
#ifndef _ICE_OSDEP_H_
#define _ICE_OSDEP_H_
 
#include <linux/types.h>
#include <linux/io.h>
#ifndef CONFIG_64BIT
#include <linux/io-64-nonatomic-lo-hi.h>
#endif
 
#define wr32(a, reg, value)    writel((value), ((a)->hw_addr + (reg)))
#define rd32(a, reg)        readl((a)->hw_addr + (reg))
#define wr64(a, reg, value)    writeq((value), ((a)->hw_addr + (reg)))
#define rd64(a, reg)        readq((a)->hw_addr + (reg))
 
#define ice_flush(a)        rd32((a), GLGEN_STAT)
#define ICE_M(m, s)        ((m) << (s))
 
struct ice_dma_mem {
   void *va;
   dma_addr_t pa;
   size_t size;
};
 
#define ice_hw_to_dev(ptr)    \
   (&(container_of((ptr), struct ice_pf, hw))->pdev->dev)
 
#ifdef CONFIG_DYNAMIC_DEBUG
#define ice_debug(hw, type, fmt, args...) \
   dev_dbg(ice_hw_to_dev(hw), fmt, ##args)
 
#define ice_debug_array(hw, type, rowsize, groupsize, buf, len) \
   print_hex_dump_debug(KBUILD_MODNAME " ",        \
                DUMP_PREFIX_OFFSET, rowsize,    \
                groupsize, buf, len, false)
#else
#define ice_debug(hw, type, fmt, args...)            \
do {                                \
   if ((type) & (hw)->debug_mask)                \
       dev_info(ice_hw_to_dev(hw), fmt, ##args);    \
} while (0)
 
#ifdef DEBUG
#define ice_debug_array(hw, type, rowsize, groupsize, buf, len) \
do {                                \
   if ((type) & (hw)->debug_mask)                \
       print_hex_dump_debug(KBUILD_MODNAME,        \
                    DUMP_PREFIX_OFFSET,    \
                    rowsize, groupsize, buf,    \
                    len, false);        \
} while (0)
#else
#define ice_debug_array(hw, type, rowsize, groupsize, buf, len) \
do {                                \
   struct ice_hw *hw_l = hw;                \
   if ((type) & (hw_l)->debug_mask) {            \
       u16 len_l = len;                \
       u8 *buf_l = buf;                \
       int i;                        \
       for (i = 0; i < (len_l - 16); i += 16)        \
           ice_debug(hw_l, type, "0x%04X  %16ph\n",\
                 i, ((buf_l) + i));        \
       if (i < len_l)                    \
           ice_debug(hw_l, type, "0x%04X  %*ph\n", \
                 i, ((len_l) - i), ((buf_l) + i));\
   }                            \
} while (0)
#endif /* DEBUG */
#endif /* CONFIG_DYNAMIC_DEBUG */
 
#endif /* _ICE_OSDEP_H_ */