Linux Audio

Check our new training course

Loading...
Note: File does not exist in v6.8.
  1/*
  2 *  IBM eServer eHCA Infiniband device driver for Linux on POWER
  3 *
  4 *  auxiliary functions
  5 *
  6 *  Authors: Christoph Raisch <raisch@de.ibm.com>
  7 *           Hoang-Nam Nguyen <hnguyen@de.ibm.com>
  8 *           Khadija Souissi <souissik@de.ibm.com>
  9 *           Waleri Fomin <fomin@de.ibm.com>
 10 *           Heiko J Schick <schickhj@de.ibm.com>
 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/abs_addr.h>
 63#include <asm/ibmebus.h>
 64#include <asm/io.h>
 65#include <asm/pgtable.h>
 66#include <asm/hvcall.h>
 67
 68extern int ehca_debug_level;
 69
 70#define ehca_dbg(ib_dev, format, arg...) \
 71	do { \
 72		if (unlikely(ehca_debug_level)) \
 73			dev_printk(KERN_DEBUG, (ib_dev)->dma_device, \
 74				   "PU%04x EHCA_DBG:%s " format "\n", \
 75				   raw_smp_processor_id(), __func__, \
 76				   ## arg); \
 77	} while (0)
 78
 79#define ehca_info(ib_dev, format, arg...) \
 80	dev_info((ib_dev)->dma_device, "PU%04x EHCA_INFO:%s " format "\n", \
 81		 raw_smp_processor_id(), __func__, ## arg)
 82
 83#define ehca_warn(ib_dev, format, arg...) \
 84	dev_warn((ib_dev)->dma_device, "PU%04x EHCA_WARN:%s " format "\n", \
 85		 raw_smp_processor_id(), __func__, ## arg)
 86
 87#define ehca_err(ib_dev, format, arg...) \
 88	dev_err((ib_dev)->dma_device, "PU%04x EHCA_ERR:%s " format "\n", \
 89		raw_smp_processor_id(), __func__, ## arg)
 90
 91/* use this one only if no ib_dev available */
 92#define ehca_gen_dbg(format, arg...) \
 93	do { \
 94		if (unlikely(ehca_debug_level)) \
 95			printk(KERN_DEBUG "PU%04x EHCA_DBG:%s " format "\n", \
 96			       raw_smp_processor_id(), __func__, ## arg); \
 97	} while (0)
 98
 99#define ehca_gen_warn(format, arg...) \
100	printk(KERN_INFO "PU%04x EHCA_WARN:%s " format "\n", \
101	       raw_smp_processor_id(), __func__, ## arg)
102
103#define ehca_gen_err(format, arg...) \
104	printk(KERN_ERR "PU%04x EHCA_ERR:%s " format "\n", \
105	       raw_smp_processor_id(), __func__, ## arg)
106
107/**
108 * ehca_dmp - printk a memory block, whose length is n*8 bytes.
109 * Each line has the following layout:
110 * <format string> adr=X ofs=Y <8 bytes hex> <8 bytes hex>
111 */
112#define ehca_dmp(adr, len, format, args...) \
113	do { \
114		unsigned int x; \
115		unsigned int l = (unsigned int)(len); \
116		unsigned char *deb = (unsigned char *)(adr); \
117		for (x = 0; x < l; x += 16) { \
118			printk(KERN_INFO "EHCA_DMP:%s " format \
119			       " adr=%p ofs=%04x %016llx %016llx\n", \
120			       __func__, ##args, deb, x, \
121			       *((u64 *)&deb[0]), *((u64 *)&deb[8])); \
122			deb += 16; \
123		} \
124	} while (0)
125
126/* define a bitmask, little endian version */
127#define EHCA_BMASK(pos, length) (((pos) << 16) + (length))
128
129/* define a bitmask, the ibm way... */
130#define EHCA_BMASK_IBM(from, to) (((63 - to) << 16) + ((to) - (from) + 1))
131
132/* internal function, don't use */
133#define EHCA_BMASK_SHIFTPOS(mask) (((mask) >> 16) & 0xffff)
134
135/* internal function, don't use */
136#define EHCA_BMASK_MASK(mask) (~0ULL >> ((64 - (mask)) & 0xffff))
137
138/**
139 * EHCA_BMASK_SET - return value shifted and masked by mask
140 * variable|=EHCA_BMASK_SET(MY_MASK,0x4711) ORs the bits in variable
141 * variable&=~EHCA_BMASK_SET(MY_MASK,-1) clears the bits from the mask
142 * in variable
143 */
144#define EHCA_BMASK_SET(mask, value) \
145	((EHCA_BMASK_MASK(mask) & ((u64)(value))) << EHCA_BMASK_SHIFTPOS(mask))
146
147/**
148 * EHCA_BMASK_GET - extract a parameter from value by mask
149 */
150#define EHCA_BMASK_GET(mask, value) \
151	(EHCA_BMASK_MASK(mask) & (((u64)(value)) >> EHCA_BMASK_SHIFTPOS(mask)))
152
153/* Converts ehca to ib return code */
154int ehca2ib_return_code(u64 ehca_rc);
155
156#endif /* EHCA_TOOLS_H */