123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189 |
- #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>
- * Author: Michael Jung <mijung@gmx.net>
- * 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.
- */
- /*
- * 0b0110 Chained descriptor. The descriptor is describing the next
- * descriptor list.
- */
- #define SG_CHAINED (0x6)
- /*
- * 0b0010 First entry of a descriptor list. Start from a Buffer-Empty
- * condition.
- */
- #define SG_DATA (0x2)
- /*
- * 0b0000 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__ */
|