2013-09-06 07:41:31 +08:00
|
|
|
/*
|
|
|
|
* Intel MIC Platform Software Stack (MPSS)
|
|
|
|
*
|
|
|
|
* Copyright(c) 2013 Intel Corporation.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License, version 2, as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful, but
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* General Public License for more details.
|
|
|
|
*
|
|
|
|
* The full GNU General Public License is included in this distribution in
|
|
|
|
* the file called "COPYING".
|
|
|
|
*
|
|
|
|
* Intel MIC driver.
|
|
|
|
*
|
|
|
|
*/
|
2013-09-28 00:49:42 +08:00
|
|
|
#ifndef __MIC_DEV_H__
|
|
|
|
#define __MIC_DEV_H__
|
2013-09-06 07:41:31 +08:00
|
|
|
|
2015-09-30 09:13:54 +08:00
|
|
|
/* The maximum number of MIC devices supported in a single host system. */
|
|
|
|
#define MIC_MAX_NUM_DEVS 128
|
|
|
|
|
|
|
|
/**
|
|
|
|
* enum mic_hw_family - The hardware family to which a device belongs.
|
|
|
|
*/
|
|
|
|
enum mic_hw_family {
|
|
|
|
MIC_FAMILY_X100 = 0,
|
|
|
|
MIC_FAMILY_X200,
|
|
|
|
MIC_FAMILY_UNKNOWN,
|
|
|
|
MIC_FAMILY_LAST
|
|
|
|
};
|
|
|
|
|
2013-09-06 07:41:31 +08:00
|
|
|
/**
|
|
|
|
* struct mic_mw - MIC memory window
|
|
|
|
*
|
|
|
|
* @pa: Base physical address.
|
|
|
|
* @va: Base ioremap'd virtual address.
|
|
|
|
* @len: Size of the memory window.
|
|
|
|
*/
|
|
|
|
struct mic_mw {
|
|
|
|
phys_addr_t pa;
|
|
|
|
void __iomem *va;
|
|
|
|
resource_size_t len;
|
|
|
|
};
|
|
|
|
|
2013-09-06 07:41:55 +08:00
|
|
|
/*
|
|
|
|
* Scratch pad register offsets used by the host to communicate
|
|
|
|
* device page DMA address to the card.
|
|
|
|
*/
|
|
|
|
#define MIC_DPLO_SPAD 14
|
|
|
|
#define MIC_DPHI_SPAD 15
|
|
|
|
|
2013-09-06 07:42:18 +08:00
|
|
|
/*
|
|
|
|
* These values are supposed to be in the config_change field of the
|
|
|
|
* device page when the host sends a config change interrupt to the card.
|
|
|
|
*/
|
|
|
|
#define MIC_VIRTIO_PARAM_DEV_REMOVE 0x1
|
|
|
|
#define MIC_VIRTIO_PARAM_CONFIG_CHANGED 0x2
|
|
|
|
|
2015-04-29 20:32:32 +08:00
|
|
|
/* Maximum number of DMA channels */
|
|
|
|
#define MIC_MAX_DMA_CHAN 4
|
|
|
|
|
2013-09-06 07:41:31 +08:00
|
|
|
#endif
|