2013-12-09 13:30:40 +01:00
# ifndef __CARD_DDCB_H__
# define __CARD_DDCB_H__
/**
* IBM Accelerator Family ' GenWQE '
*
* ( C ) Copyright IBM Corp . 2013
*
* Author : Frank Haverkamp < haver @ linux . vnet . ibm . com >
* Author : Joerg - Stephan Vogt < jsvogt @ de . ibm . com >
2014-09-10 16:37:48 +02:00
* Author : Michael Jung < mijung @ gmx . net >
2013-12-09 13:30:40 +01:00
* Author : Michael Ruettger < michael @ ibmra . de >
*
* 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 , 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 .
*/
# include <linux/types.h>
# include <asm/byteorder.h>
# include "genwqe_driver.h"
# include "card_base.h"
/**
* struct ddcb - Device Driver Control Block DDCB
* @ hsi : Hardware software interlock
* @ shi : Software hardware interlock . Hsi and shi are used to interlock
* software and hardware activities . We are using a compare and
* swap operation to ensure that there are no races when
* activating new DDCBs on the queue , or when we need to
* purge a DDCB from a running queue .
* @ acfunc : Accelerator function addresses a unit within the chip
* @ cmd : Command to work on
* @ cmdopts_16 : Options for the command
* @ asiv : Input data
* @ asv : Output data
*
* The DDCB data format is big endian . Multiple consequtive DDBCs form
* a DDCB queue .
*/
# define ASIV_LENGTH 104 /* Old specification without ATS field */
# define ASIV_LENGTH_ATS 96 /* New specification with ATS field */
# define ASV_LENGTH 64
struct ddcb {
union {
__be32 icrc_hsi_shi_32 ; /* iCRC, Hardware/SW interlock */
struct {
__be16 icrc_16 ;
u8 hsi ;
u8 shi ;
} ;
} ;
u8 pre ; /* Preamble */
u8 xdir ; /* Execution Directives */
__be16 seqnum_16 ; /* Sequence Number */
u8 acfunc ; /* Accelerator Function.. */
u8 cmd ; /* Command. */
__be16 cmdopts_16 ; /* Command Options */
u8 sur ; /* Status Update Rate */
u8 psp ; /* Protection Section Pointer */
__be16 rsvd_0e_16 ; /* Reserved invariant */
__be64 fwiv_64 ; /* Firmware Invariant. */
union {
struct {
__be64 ats_64 ; /* Address Translation Spec */
u8 asiv [ ASIV_LENGTH_ATS ] ; /* New ASIV */
} n ;
u8 __asiv [ ASIV_LENGTH ] ; /* obsolete */
} ;
u8 asv [ ASV_LENGTH ] ; /* Appl Spec Variant */
__be16 rsvd_c0_16 ; /* Reserved Variant */
__be16 vcrc_16 ; /* Variant CRC */
__be32 rsvd_32 ; /* Reserved unprotected */
__be64 deque_ts_64 ; /* Deque Time Stamp. */
__be16 retc_16 ; /* Return Code */
__be16 attn_16 ; /* Attention/Extended Error Codes */
__be32 progress_32 ; /* Progress indicator. */
__be64 cmplt_ts_64 ; /* Completion Time Stamp. */
/* The following layout matches the new service layer format */
__be32 ibdc_32 ; /* Inbound Data Count (* 256) */
__be32 obdc_32 ; /* Outbound Data Count (* 256) */
__be64 rsvd_SLH_64 ; /* Reserved for hardware */
union { /* private data for driver */
u8 priv [ 8 ] ;
__be64 priv_64 ;
} ;
__be64 disp_ts_64 ; /* Dispatch TimeStamp */
} __attribute__ ( ( __packed__ ) ) ;
/* CRC polynomials for DDCB */
# define CRC16_POLYNOMIAL 0x1021
/*
* SHI : Software to Hardware Interlock
* This 1 byte field is written by software to interlock the
* movement of one queue entry to another with the hardware in the
* chip .
*/
# define DDCB_SHI_INTR 0x04 /* Bit 2 */
# define DDCB_SHI_PURGE 0x02 /* Bit 1 */
# define DDCB_SHI_NEXT 0x01 /* Bit 0 */
/*
* HSI : Hardware to Software interlock
* This 1 byte field is written by hardware to interlock the movement
* of one queue entry to another with the software in the chip .
*/
# define DDCB_HSI_COMPLETED 0x40 /* Bit 6 */
# define DDCB_HSI_FETCHED 0x04 /* Bit 2 */
/*
* Accessing HSI / SHI is done 32 - bit wide
* Normally 16 - bit access would work too , but on some platforms the
* 16 compare and swap operation is not supported . Therefore
* switching to 32 - bit such that those platforms will work too .
*
* iCRC HSI / SHI
*/
# define DDCB_INTR_BE32 cpu_to_be32(0x00000004)
# define DDCB_PURGE_BE32 cpu_to_be32(0x00000002)
# define DDCB_NEXT_BE32 cpu_to_be32(0x00000001)
# define DDCB_COMPLETED_BE32 cpu_to_be32(0x00004000)
# define DDCB_FETCHED_BE32 cpu_to_be32(0x00000400)
/* Definitions of DDCB presets */
# define DDCB_PRESET_PRE 0x80
# define ICRC_LENGTH(n) ((n) + 8 + 8 + 8) /* used ASIV + hdr fields */
# define VCRC_LENGTH(n) ((n)) /* used ASV */
/*
* Genwqe Scatter Gather list
* Each element has up to 8 entries .
* The chaining element is element 0 cause of prefetching needs .
*/
/*
* 0 b0110 Chained descriptor . The descriptor is describing the next
* descriptor list .
*/
# define SG_CHAINED (0x6)
/*
* 0 b0010 First entry of a descriptor list . Start from a Buffer - Empty
* condition .
*/
# define SG_DATA (0x2)
/*
* 0 b0000 Early terminator . This is the last entry on the list
* irregardless of the length indicated .
*/
# define SG_END_LIST (0x0)
/**
* struct sglist - Scatter gather list
* @ target_addr : Either a dma addr of memory to work on or a
* dma addr or a subsequent sglist block .
* @ len : Length of the data block .
* @ flags : See above .
*
* Depending on the command the GenWQE card can use a scatter gather
* list to describe the memory it works on . Always 8 sg_entry ' s form
* a block .
*/
struct sg_entry {
__be64 target_addr ;
__be32 len ;
__be32 flags ;
} ;
# endif /* __CARD_DDCB_H__ */