Linux Kernel  3.7.1
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
ehca_tools.h
Go to the documentation of this file.
1 /*
2  * IBM eServer eHCA Infiniband device driver for Linux on POWER
3  *
4  * auxiliary functions
5  *
6  * Authors: Christoph Raisch <[email protected]>
7  * Hoang-Nam Nguyen <[email protected]>
8  * Khadija Souissi <[email protected]>
9  * Waleri Fomin <[email protected]>
10  * Heiko J Schick <[email protected]>
11  *
12  * Copyright (c) 2005 IBM Corporation
13  *
14  * This source code is distributed under a dual license of GPL v2.0 and OpenIB
15  * BSD.
16  *
17  * OpenIB BSD License
18  *
19  * Redistribution and use in source and binary forms, with or without
20  * modification, are permitted provided that the following conditions are met:
21  *
22  * Redistributions of source code must retain the above copyright notice, this
23  * list of conditions and the following disclaimer.
24  *
25  * Redistributions in binary form must reproduce the above copyright notice,
26  * this list of conditions and the following disclaimer in the documentation
27  * and/or other materials
28  * provided with the distribution.
29  *
30  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
31  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
32  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
33  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
34  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
35  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
36  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
37  * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER
38  * IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
39  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
40  * POSSIBILITY OF SUCH DAMAGE.
41  */
42 
43 
44 #ifndef EHCA_TOOLS_H
45 #define EHCA_TOOLS_H
46 
47 #include <linux/kernel.h>
48 #include <linux/spinlock.h>
49 #include <linux/delay.h>
50 #include <linux/idr.h>
51 #include <linux/kthread.h>
52 #include <linux/mm.h>
53 #include <linux/mman.h>
54 #include <linux/module.h>
55 #include <linux/moduleparam.h>
56 #include <linux/vmalloc.h>
57 #include <linux/notifier.h>
58 #include <linux/cpu.h>
59 #include <linux/device.h>
60 
61 #include <linux/atomic.h>
62 #include <asm/ibmebus.h>
63 #include <asm/io.h>
64 #include <asm/pgtable.h>
65 #include <asm/hvcall.h>
66 
67 extern int ehca_debug_level;
68 
69 #define ehca_dbg(ib_dev, format, arg...) \
70  do { \
71  if (unlikely(ehca_debug_level)) \
72  dev_printk(KERN_DEBUG, (ib_dev)->dma_device, \
73  "PU%04x EHCA_DBG:%s " format "\n", \
74  raw_smp_processor_id(), __func__, \
75  ## arg); \
76  } while (0)
77 
78 #define ehca_info(ib_dev, format, arg...) \
79  dev_info((ib_dev)->dma_device, "PU%04x EHCA_INFO:%s " format "\n", \
80  raw_smp_processor_id(), __func__, ## arg)
81 
82 #define ehca_warn(ib_dev, format, arg...) \
83  dev_warn((ib_dev)->dma_device, "PU%04x EHCA_WARN:%s " format "\n", \
84  raw_smp_processor_id(), __func__, ## arg)
85 
86 #define ehca_err(ib_dev, format, arg...) \
87  dev_err((ib_dev)->dma_device, "PU%04x EHCA_ERR:%s " format "\n", \
88  raw_smp_processor_id(), __func__, ## arg)
89 
90 /* use this one only if no ib_dev available */
91 #define ehca_gen_dbg(format, arg...) \
92  do { \
93  if (unlikely(ehca_debug_level)) \
94  printk(KERN_DEBUG "PU%04x EHCA_DBG:%s " format "\n", \
95  raw_smp_processor_id(), __func__, ## arg); \
96  } while (0)
97 
98 #define ehca_gen_warn(format, arg...) \
99  printk(KERN_INFO "PU%04x EHCA_WARN:%s " format "\n", \
100  raw_smp_processor_id(), __func__, ## arg)
101 
102 #define ehca_gen_err(format, arg...) \
103  printk(KERN_ERR "PU%04x EHCA_ERR:%s " format "\n", \
104  raw_smp_processor_id(), __func__, ## arg)
105 
111 #define ehca_dmp(adr, len, format, args...) \
112  do { \
113  unsigned int x; \
114  unsigned int l = (unsigned int)(len); \
115  unsigned char *deb = (unsigned char *)(adr); \
116  for (x = 0; x < l; x += 16) { \
117  printk(KERN_INFO "EHCA_DMP:%s " format \
118  " adr=%p ofs=%04x %016llx %016llx\n", \
119  __func__, ##args, deb, x, \
120  *((u64 *)&deb[0]), *((u64 *)&deb[8])); \
121  deb += 16; \
122  } \
123  } while (0)
124 
125 /* define a bitmask, little endian version */
126 #define EHCA_BMASK(pos, length) (((pos) << 16) + (length))
127 
128 /* define a bitmask, the ibm way... */
129 #define EHCA_BMASK_IBM(from, to) (((63 - to) << 16) + ((to) - (from) + 1))
130 
131 /* internal function, don't use */
132 #define EHCA_BMASK_SHIFTPOS(mask) (((mask) >> 16) & 0xffff)
133 
134 /* internal function, don't use */
135 #define EHCA_BMASK_MASK(mask) (~0ULL >> ((64 - (mask)) & 0xffff))
136 
143 #define EHCA_BMASK_SET(mask, value) \
144  ((EHCA_BMASK_MASK(mask) & ((u64)(value))) << EHCA_BMASK_SHIFTPOS(mask))
145 
149 #define EHCA_BMASK_GET(mask, value) \
150  (EHCA_BMASK_MASK(mask) & (((u64)(value)) >> EHCA_BMASK_SHIFTPOS(mask)))
151 
152 /* Converts ehca to ib return code */
153 int ehca2ib_return_code(u64 ehca_rc);
154 
155 #endif /* EHCA_TOOLS_H */