cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

pci_clp.h (5224B)


      1/* SPDX-License-Identifier: GPL-2.0 */
      2#ifndef _ASM_S390_PCI_CLP_H
      3#define _ASM_S390_PCI_CLP_H
      4
      5#include <asm/clp.h>
      6
      7/*
      8 * Call Logical Processor - Command Codes
      9 */
     10#define CLP_SLPC		0x0001
     11#define CLP_LIST_PCI		0x0002
     12#define CLP_QUERY_PCI_FN	0x0003
     13#define CLP_QUERY_PCI_FNGRP	0x0004
     14#define CLP_SET_PCI_FN		0x0005
     15
     16/* PCI function handle list entry */
     17struct clp_fh_list_entry {
     18	u16 device_id;
     19	u16 vendor_id;
     20	u32 config_state :  1;
     21	u32		 : 31;
     22	u32 fid;		/* PCI function id */
     23	u32 fh;			/* PCI function handle */
     24} __packed;
     25
     26#define CLP_RC_SETPCIFN_FH	0x0101	/* Invalid PCI fn handle */
     27#define CLP_RC_SETPCIFN_FHOP	0x0102	/* Fn handle not valid for op */
     28#define CLP_RC_SETPCIFN_DMAAS	0x0103	/* Invalid DMA addr space */
     29#define CLP_RC_SETPCIFN_RES	0x0104	/* Insufficient resources */
     30#define CLP_RC_SETPCIFN_ALRDY	0x0105	/* Fn already in requested state */
     31#define CLP_RC_SETPCIFN_ERR	0x0106	/* Fn in permanent error state */
     32#define CLP_RC_SETPCIFN_RECPND	0x0107	/* Error recovery pending */
     33#define CLP_RC_SETPCIFN_BUSY	0x0108	/* Fn busy */
     34#define CLP_RC_LISTPCI_BADRT	0x010a	/* Resume token not recognized */
     35#define CLP_RC_QUERYPCIFG_PFGID	0x010b	/* Unrecognized PFGID */
     36
     37/* request or response block header length */
     38#define LIST_PCI_HDR_LEN	32
     39
     40/* Number of function handles fitting in response block */
     41#define CLP_FH_LIST_NR_ENTRIES				\
     42	((CLP_BLK_SIZE - 2 * LIST_PCI_HDR_LEN)		\
     43		/ sizeof(struct clp_fh_list_entry))
     44
     45#define CLP_SET_ENABLE_PCI_FN	0	/* Yes, 0 enables it */
     46#define CLP_SET_DISABLE_PCI_FN	1	/* Yes, 1 disables it */
     47#define CLP_SET_ENABLE_MIO	2
     48#define CLP_SET_DISABLE_MIO	3
     49
     50#define CLP_UTIL_STR_LEN	64
     51#define CLP_PFIP_NR_SEGMENTS	4
     52
     53extern bool zpci_unique_uid;
     54
     55struct clp_rsp_slpc_pci {
     56	struct clp_rsp_hdr hdr;
     57	u32 reserved2[4];
     58	u32 lpif[8];
     59	u32 reserved3[4];
     60	u32 vwb		:  1;
     61	u32		:  1;
     62	u32 mio_wb	:  6;
     63	u32		: 24;
     64	u32 reserved5[3];
     65	u32 lpic[8];
     66} __packed;
     67
     68/* List PCI functions request */
     69struct clp_req_list_pci {
     70	struct clp_req_hdr hdr;
     71	u64 resume_token;
     72	u64 reserved2;
     73} __packed;
     74
     75/* List PCI functions response */
     76struct clp_rsp_list_pci {
     77	struct clp_rsp_hdr hdr;
     78	u64 resume_token;
     79	u32 reserved2;
     80	u16 max_fn;
     81	u8			: 7;
     82	u8 uid_checking		: 1;
     83	u8 entry_size;
     84	struct clp_fh_list_entry fh_list[CLP_FH_LIST_NR_ENTRIES];
     85} __packed;
     86
     87struct mio_info {
     88	u32 valid : 6;
     89	u32 : 26;
     90	u32 : 32;
     91	struct {
     92		u64 wb;
     93		u64 wt;
     94	} addr[PCI_STD_NUM_BARS];
     95	u32 reserved[6];
     96} __packed;
     97
     98/* Query PCI function request */
     99struct clp_req_query_pci {
    100	struct clp_req_hdr hdr;
    101	u32 fh;				/* function handle */
    102	u32 reserved2;
    103	u64 reserved3;
    104} __packed;
    105
    106/* Query PCI function response */
    107struct clp_rsp_query_pci {
    108	struct clp_rsp_hdr hdr;
    109	u16 vfn;			/* virtual fn number */
    110	u16			:  3;
    111	u16 rid_avail		:  1;
    112	u16 is_physfn		:  1;
    113	u16 reserved1		:  1;
    114	u16 mio_addr_avail	:  1;
    115	u16 util_str_avail	:  1;	/* utility string available? */
    116	u16 pfgid		:  8;	/* pci function group id */
    117	u32 fid;			/* pci function id */
    118	u8 bar_size[PCI_STD_NUM_BARS];
    119	u16 pchid;
    120	__le32 bar[PCI_STD_NUM_BARS];
    121	u8 pfip[CLP_PFIP_NR_SEGMENTS];	/* pci function internal path */
    122	u16			: 12;
    123	u16 port		:  4;
    124	u8 fmb_len;
    125	u8 pft;				/* pci function type */
    126	u64 sdma;			/* start dma as */
    127	u64 edma;			/* end dma as */
    128#define ZPCI_RID_MASK_DEVFN 0x00ff
    129	u16 rid;			/* BUS/DEVFN PCI address */
    130	u16 reserved0;
    131	u32 reserved[10];
    132	u32 uid;			/* user defined id */
    133	u8 util_str[CLP_UTIL_STR_LEN];	/* utility string */
    134	u32 reserved2[16];
    135	struct mio_info mio;
    136} __packed;
    137
    138/* Query PCI function group request */
    139struct clp_req_query_pci_grp {
    140	struct clp_req_hdr hdr;
    141	u32 reserved2		: 24;
    142	u32 pfgid		:  8;	/* function group id */
    143	u32 reserved3;
    144	u64 reserved4;
    145} __packed;
    146
    147/* Query PCI function group response */
    148struct clp_rsp_query_pci_grp {
    149	struct clp_rsp_hdr hdr;
    150	u16			:  4;
    151	u16 noi			: 12;	/* number of interrupts */
    152	u8 version;
    153	u8			:  6;
    154	u8 frame		:  1;
    155	u8 refresh		:  1;	/* TLB refresh mode */
    156	u16 reserved2;
    157	u16 mui;
    158	u16			: 16;
    159	u16 maxfaal;
    160	u16			:  4;
    161	u16 dnoi		: 12;
    162	u16 maxcpu;
    163	u64 dasm;			/* dma address space mask */
    164	u64 msia;			/* MSI address */
    165	u64 reserved4;
    166	u64 reserved5;
    167} __packed;
    168
    169/* Set PCI function request */
    170struct clp_req_set_pci {
    171	struct clp_req_hdr hdr;
    172	u32 fh;				/* function handle */
    173	u16 reserved2;
    174	u8 oc;				/* operation controls */
    175	u8 ndas;			/* number of dma spaces */
    176	u64 reserved3;
    177} __packed;
    178
    179/* Set PCI function response */
    180struct clp_rsp_set_pci {
    181	struct clp_rsp_hdr hdr;
    182	u32 fh;				/* function handle */
    183	u32 reserved1;
    184	u64 reserved2;
    185	struct mio_info mio;
    186} __packed;
    187
    188/* Combined request/response block structures used by clp insn */
    189struct clp_req_rsp_slpc_pci {
    190	struct clp_req_slpc request;
    191	struct clp_rsp_slpc_pci response;
    192} __packed;
    193
    194struct clp_req_rsp_list_pci {
    195	struct clp_req_list_pci request;
    196	struct clp_rsp_list_pci response;
    197} __packed;
    198
    199struct clp_req_rsp_set_pci {
    200	struct clp_req_set_pci request;
    201	struct clp_rsp_set_pci response;
    202} __packed;
    203
    204struct clp_req_rsp_query_pci {
    205	struct clp_req_query_pci request;
    206	struct clp_rsp_query_pci response;
    207} __packed;
    208
    209struct clp_req_rsp_query_pci_grp {
    210	struct clp_req_query_pci_grp request;
    211	struct clp_rsp_query_pci_grp response;
    212} __packed;
    213
    214#endif