2013-02-05 21:15:02 +08:00
|
|
|
/*
|
|
|
|
* Filename: rsXX_cfg.h
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* Authors: Joshua Morris <josh.h.morris@us.ibm.com>
|
|
|
|
* Philip Kelleher <pjk1939@linux.vnet.ibm.com>
|
|
|
|
*
|
|
|
|
* (C) Copyright 2013 IBM Corporation
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License as
|
|
|
|
* published by the Free Software Foundation; either version 2 of the
|
|
|
|
* License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software Foundation,
|
|
|
|
* Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __RSXX_CFG_H__
|
|
|
|
#define __RSXX_CFG_H__
|
|
|
|
|
|
|
|
/* NOTE: Config values will be saved in network byte order (i.e. Big endian) */
|
|
|
|
#include <linux/types.h>
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The card config version must match the driver's expected version. If it does
|
|
|
|
* not, the DMA interfaces will not be attached and the user will need to
|
|
|
|
* initialize/upgrade the card configuration using the card config utility.
|
|
|
|
*/
|
|
|
|
#define RSXX_CFG_VERSION 4
|
|
|
|
|
|
|
|
struct card_cfg_hdr {
|
|
|
|
__u32 version;
|
|
|
|
__u32 crc;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct card_cfg_data {
|
|
|
|
__u32 block_size;
|
|
|
|
__u32 stripe_size;
|
|
|
|
__u32 vendor_id;
|
|
|
|
__u32 cache_order;
|
|
|
|
struct {
|
|
|
|
__u32 mode; /* Disabled, manual, auto-tune... */
|
|
|
|
__u32 count; /* Number of intr to coalesce */
|
|
|
|
__u32 latency;/* Max wait time (in ns) */
|
|
|
|
} intr_coal;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct rsxx_card_cfg {
|
|
|
|
struct card_cfg_hdr hdr;
|
|
|
|
struct card_cfg_data data;
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Vendor ID Values */
|
2013-02-27 23:24:59 +08:00
|
|
|
#define RSXX_VENDOR_ID_IBM 0
|
2013-02-05 21:15:02 +08:00
|
|
|
#define RSXX_VENDOR_ID_DSI 1
|
|
|
|
#define RSXX_VENDOR_COUNT 2
|
|
|
|
|
|
|
|
/* Interrupt Coalescing Values */
|
|
|
|
#define RSXX_INTR_COAL_DISABLED 0
|
|
|
|
#define RSXX_INTR_COAL_EXPLICIT 1
|
|
|
|
#define RSXX_INTR_COAL_AUTO_TUNE 2
|
|
|
|
|
|
|
|
|
|
|
|
#endif /* __RSXX_CFG_H__ */
|
|
|
|
|