fc58bb41d15f0f993a00eb1827c9e9088aac4cb9
[deb_dpdk.git] / drivers / net / enic / enic_compat.h
1 /*
2  * Copyright 2008-2014 Cisco Systems, Inc.  All rights reserved.
3  * Copyright 2007 Nuova Systems, Inc.  All rights reserved.
4  *
5  * Copyright (c) 2014, Cisco Systems, Inc.
6  * All rights reserved.
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions
10  * are met:
11  *
12  * 1. Redistributions of source code must retain the above copyright
13  * notice, this list of conditions and the following disclaimer.
14  *
15  * 2. Redistributions in binary form must reproduce the above copyright
16  * notice, this list of conditions and the following disclaimer in
17  * the documentation and/or other materials provided with the
18  * distribution.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
23  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
24  * COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
25  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
26  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
27  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
28  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
30  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
31  * POSSIBILITY OF SUCH DAMAGE.
32  *
33  */
34
35 #ifndef _ENIC_COMPAT_H_
36 #define _ENIC_COMPAT_H_
37
38 #include <stdio.h>
39 #include <unistd.h>
40
41 #include <rte_atomic.h>
42 #include <rte_malloc.h>
43 #include <rte_log.h>
44 #include <rte_io.h>
45
46 #define ENIC_PAGE_ALIGN 4096UL
47 #define ENIC_ALIGN      ENIC_PAGE_ALIGN
48 #define NAME_MAX        255
49 #define ETH_ALEN        6
50
51 #define __iomem
52
53 #define rmb()     rte_rmb() /* dpdk rte provided rmb */
54 #define wmb()     rte_wmb() /* dpdk rte provided wmb */
55
56 #define le16_to_cpu
57 #define le32_to_cpu
58 #define le64_to_cpu
59 #define cpu_to_le16
60 #define cpu_to_le32
61 #define cpu_to_le64
62
63 #ifndef offsetof
64 #define offsetof(t, m) ((size_t) &((t *)0)->m)
65 #endif
66
67 #define pr_err(y, args...) dev_err(0, y, ##args)
68 #define pr_warn(y, args...) dev_warning(0, y, ##args)
69 #define BUG() pr_err("BUG at %s:%d", __func__, __LINE__)
70
71 #define VNIC_ALIGN(x, a)         __ALIGN_MASK(x, (typeof(x))(a)-1)
72 #define __ALIGN_MASK(x, mask)    (((x)+(mask))&~(mask))
73 #define udelay usleep
74 #define DIV_ROUND_UP(n, d) (((n) + (d) - 1) / (d))
75
76 #define kzalloc(size, flags) calloc(1, size)
77 #define kfree(x) free(x)
78
79 #define dev_printk(level, fmt, args...) \
80         RTE_LOG(level, PMD, "rte_enic_pmd: " fmt, ## args)
81
82 #define dev_err(x, args...) dev_printk(ERR, args)
83 #define dev_info(x, args...) dev_printk(INFO,  args)
84 #define dev_warning(x, args...) dev_printk(WARNING, args)
85 #define dev_debug(x, args...) dev_printk(DEBUG, args)
86
87 #define __le16 u16
88 #define __le32 u32
89 #define __le64 u64
90
91 typedef         unsigned char       u8;
92 typedef         unsigned short      u16;
93 typedef         unsigned int        u32;
94 typedef         unsigned long long  u64;
95 typedef         unsigned long long  dma_addr_t;
96
97 static inline uint32_t ioread32(volatile void *addr)
98 {
99         return rte_read32(addr);
100 }
101
102 static inline uint16_t ioread16(volatile void *addr)
103 {
104         return rte_read16(addr);
105 }
106
107 static inline uint8_t ioread8(volatile void *addr)
108 {
109         return rte_read8(addr);
110 }
111
112 static inline void iowrite32(uint32_t val, volatile void *addr)
113 {
114         rte_write32(val, addr);
115 }
116
117 static inline void iowrite32_relaxed(uint32_t val, volatile void *addr)
118 {
119         rte_write32_relaxed(val, addr);
120 }
121
122 static inline void iowrite16(uint16_t val, volatile void *addr)
123 {
124         rte_write16(val, addr);
125 }
126
127 static inline void iowrite8(uint8_t val, volatile void *addr)
128 {
129         rte_write8(val, addr);
130 }
131
132 static inline unsigned int readl(volatile void __iomem *addr)
133 {
134         return rte_read32(addr);
135 }
136
137 static inline unsigned int readl_relaxed(volatile void __iomem *addr)
138 {
139         return rte_read32_relaxed(addr);
140 }
141
142 static inline void writel(unsigned int val, volatile void __iomem *addr)
143 {
144         rte_write32(val, addr);
145 }
146
147 #define min_t(type, x, y) ({                    \
148         type __min1 = (x);                      \
149         type __min2 = (y);                      \
150         __min1 < __min2 ? __min1 : __min2; })
151
152 #define max_t(type, x, y) ({                    \
153         type __max1 = (x);                      \
154         type __max2 = (y);                      \
155         __max1 > __max2 ? __max1 : __max2; })
156
157 #endif /* _ENIC_COMPAT_H_ */