linux/drivers/infiniband/hw/ehca/ehca_tools.h
<<
>>
Prefs
   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 <asm/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 */
 157