1*8f3a6c92SHaren Myneni /* SPDX-License-Identifier: GPL-2.0-or-later */ 2*8f3a6c92SHaren Myneni /* 3*8f3a6c92SHaren Myneni * Copyright 2020-21 IBM Corp. 4*8f3a6c92SHaren Myneni */ 5*8f3a6c92SHaren Myneni 6*8f3a6c92SHaren Myneni #ifndef _VAS_H 7*8f3a6c92SHaren Myneni #define _VAS_H 8*8f3a6c92SHaren Myneni #include <asm/vas.h> 9*8f3a6c92SHaren Myneni #include <linux/mutex.h> 10*8f3a6c92SHaren Myneni #include <linux/stringify.h> 11*8f3a6c92SHaren Myneni 12*8f3a6c92SHaren Myneni /* 13*8f3a6c92SHaren Myneni * VAS window modify flags 14*8f3a6c92SHaren Myneni */ 15*8f3a6c92SHaren Myneni #define VAS_MOD_WIN_CLOSE PPC_BIT(0) 16*8f3a6c92SHaren Myneni #define VAS_MOD_WIN_JOBS_KILL PPC_BIT(1) 17*8f3a6c92SHaren Myneni #define VAS_MOD_WIN_DR PPC_BIT(3) 18*8f3a6c92SHaren Myneni #define VAS_MOD_WIN_PR PPC_BIT(4) 19*8f3a6c92SHaren Myneni #define VAS_MOD_WIN_SF PPC_BIT(5) 20*8f3a6c92SHaren Myneni #define VAS_MOD_WIN_TA PPC_BIT(6) 21*8f3a6c92SHaren Myneni #define VAS_MOD_WIN_FLAGS (VAS_MOD_WIN_JOBS_KILL | VAS_MOD_WIN_DR | \ 22*8f3a6c92SHaren Myneni VAS_MOD_WIN_PR | VAS_MOD_WIN_SF) 23*8f3a6c92SHaren Myneni 24*8f3a6c92SHaren Myneni #define VAS_WIN_ACTIVE 0x0 25*8f3a6c92SHaren Myneni #define VAS_WIN_CLOSED 0x1 26*8f3a6c92SHaren Myneni #define VAS_WIN_INACTIVE 0x2 /* Inactive due to HW failure */ 27*8f3a6c92SHaren Myneni /* Process of being modified, deallocated, or quiesced */ 28*8f3a6c92SHaren Myneni #define VAS_WIN_MOD_IN_PROCESS 0x3 29*8f3a6c92SHaren Myneni 30*8f3a6c92SHaren Myneni #define VAS_COPY_PASTE_USER_MODE 0x00000001 31*8f3a6c92SHaren Myneni #define VAS_COP_OP_USER_MODE 0x00000010 32*8f3a6c92SHaren Myneni 33*8f3a6c92SHaren Myneni /* 34*8f3a6c92SHaren Myneni * Co-processor feature - GZIP QoS windows or GZIP default windows 35*8f3a6c92SHaren Myneni */ 36*8f3a6c92SHaren Myneni enum vas_cop_feat_type { 37*8f3a6c92SHaren Myneni VAS_GZIP_QOS_FEAT_TYPE, 38*8f3a6c92SHaren Myneni VAS_GZIP_DEF_FEAT_TYPE, 39*8f3a6c92SHaren Myneni VAS_MAX_FEAT_TYPE, 40*8f3a6c92SHaren Myneni }; 41*8f3a6c92SHaren Myneni 42*8f3a6c92SHaren Myneni /* 43*8f3a6c92SHaren Myneni * Use to get feature specific capabilities from the 44*8f3a6c92SHaren Myneni * hypervisor. 45*8f3a6c92SHaren Myneni */ 46*8f3a6c92SHaren Myneni struct hv_vas_cop_feat_caps { 47*8f3a6c92SHaren Myneni __be64 descriptor; 48*8f3a6c92SHaren Myneni u8 win_type; /* Default or QoS type */ 49*8f3a6c92SHaren Myneni u8 user_mode; 50*8f3a6c92SHaren Myneni __be16 max_lpar_creds; 51*8f3a6c92SHaren Myneni __be16 max_win_creds; 52*8f3a6c92SHaren Myneni union { 53*8f3a6c92SHaren Myneni __be16 reserved; 54*8f3a6c92SHaren Myneni __be16 def_lpar_creds; /* Used for default capabilities */ 55*8f3a6c92SHaren Myneni }; 56*8f3a6c92SHaren Myneni __be16 target_lpar_creds; 57*8f3a6c92SHaren Myneni } __packed __aligned(0x1000); 58*8f3a6c92SHaren Myneni 59*8f3a6c92SHaren Myneni /* 60*8f3a6c92SHaren Myneni * Feature specific (QoS or default) capabilities. 61*8f3a6c92SHaren Myneni */ 62*8f3a6c92SHaren Myneni struct vas_cop_feat_caps { 63*8f3a6c92SHaren Myneni u64 descriptor; 64*8f3a6c92SHaren Myneni u8 win_type; /* Default or QoS type */ 65*8f3a6c92SHaren Myneni u8 user_mode; /* User mode copy/paste or COP HCALL */ 66*8f3a6c92SHaren Myneni u16 max_lpar_creds; /* Max credits available in LPAR */ 67*8f3a6c92SHaren Myneni /* Max credits can be assigned per window */ 68*8f3a6c92SHaren Myneni u16 max_win_creds; 69*8f3a6c92SHaren Myneni union { 70*8f3a6c92SHaren Myneni u16 reserved; /* Used for QoS credit type */ 71*8f3a6c92SHaren Myneni u16 def_lpar_creds; /* Used for default credit type */ 72*8f3a6c92SHaren Myneni }; 73*8f3a6c92SHaren Myneni /* Total LPAR available credits. Can be different from max LPAR */ 74*8f3a6c92SHaren Myneni /* credits due to DLPAR operation */ 75*8f3a6c92SHaren Myneni atomic_t target_lpar_creds; 76*8f3a6c92SHaren Myneni atomic_t used_lpar_creds; /* Used credits so far */ 77*8f3a6c92SHaren Myneni u16 avail_lpar_creds; /* Remaining available credits */ 78*8f3a6c92SHaren Myneni }; 79*8f3a6c92SHaren Myneni 80*8f3a6c92SHaren Myneni /* 81*8f3a6c92SHaren Myneni * Feature (QoS or Default) specific to store capabilities and 82*8f3a6c92SHaren Myneni * the list of open windows. 83*8f3a6c92SHaren Myneni */ 84*8f3a6c92SHaren Myneni struct vas_caps { 85*8f3a6c92SHaren Myneni struct vas_cop_feat_caps caps; 86*8f3a6c92SHaren Myneni struct list_head list; /* List of open windows */ 87*8f3a6c92SHaren Myneni }; 88*8f3a6c92SHaren Myneni 89*8f3a6c92SHaren Myneni /* 90*8f3a6c92SHaren Myneni * To get window information from the hypervisor. 91*8f3a6c92SHaren Myneni */ 92*8f3a6c92SHaren Myneni struct hv_vas_win_lpar { 93*8f3a6c92SHaren Myneni __be16 version; 94*8f3a6c92SHaren Myneni u8 win_type; 95*8f3a6c92SHaren Myneni u8 status; 96*8f3a6c92SHaren Myneni __be16 credits; /* No of credits assigned to this window */ 97*8f3a6c92SHaren Myneni __be16 reserved; 98*8f3a6c92SHaren Myneni __be32 pid; /* LPAR Process ID */ 99*8f3a6c92SHaren Myneni __be32 tid; /* LPAR Thread ID */ 100*8f3a6c92SHaren Myneni __be64 win_addr; /* Paste address */ 101*8f3a6c92SHaren Myneni __be32 interrupt; /* Interrupt when NX request completes */ 102*8f3a6c92SHaren Myneni __be32 fault; /* Interrupt when NX sees fault */ 103*8f3a6c92SHaren Myneni /* Associativity Domain Identifiers as returned in */ 104*8f3a6c92SHaren Myneni /* H_HOME_NODE_ASSOCIATIVITY */ 105*8f3a6c92SHaren Myneni __be64 domain[6]; 106*8f3a6c92SHaren Myneni __be64 win_util; /* Number of bytes processed */ 107*8f3a6c92SHaren Myneni } __packed __aligned(0x1000); 108*8f3a6c92SHaren Myneni 109*8f3a6c92SHaren Myneni struct pseries_vas_window { 110*8f3a6c92SHaren Myneni struct vas_window vas_win; 111*8f3a6c92SHaren Myneni u64 win_addr; /* Physical paste address */ 112*8f3a6c92SHaren Myneni u8 win_type; /* QoS or Default window */ 113*8f3a6c92SHaren Myneni u32 complete_irq; /* Completion interrupt */ 114*8f3a6c92SHaren Myneni u32 fault_irq; /* Fault interrupt */ 115*8f3a6c92SHaren Myneni u64 domain[6]; /* Associativity domain Ids */ 116*8f3a6c92SHaren Myneni /* this window is allocated */ 117*8f3a6c92SHaren Myneni u64 util; 118*8f3a6c92SHaren Myneni 119*8f3a6c92SHaren Myneni /* List of windows opened which is used for LPM */ 120*8f3a6c92SHaren Myneni struct list_head win_list; 121*8f3a6c92SHaren Myneni u64 flags; 122*8f3a6c92SHaren Myneni char *name; 123*8f3a6c92SHaren Myneni int fault_virq; 124*8f3a6c92SHaren Myneni }; 125*8f3a6c92SHaren Myneni #endif /* _VAS_H */ 126