162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-or-later */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * linux/drivers/net/ethernet/ibm/ehea/ehea_phyp.h 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * eHEA ethernet device driver for IBM eServer System p 662306a36Sopenharmony_ci * 762306a36Sopenharmony_ci * (C) Copyright IBM Corp. 2006 862306a36Sopenharmony_ci * 962306a36Sopenharmony_ci * Authors: 1062306a36Sopenharmony_ci * Christoph Raisch <raisch@de.ibm.com> 1162306a36Sopenharmony_ci * Jan-Bernd Themann <themann@de.ibm.com> 1262306a36Sopenharmony_ci * Thomas Klein <tklein@de.ibm.com> 1362306a36Sopenharmony_ci */ 1462306a36Sopenharmony_ci 1562306a36Sopenharmony_ci#ifndef __EHEA_PHYP_H__ 1662306a36Sopenharmony_ci#define __EHEA_PHYP_H__ 1762306a36Sopenharmony_ci 1862306a36Sopenharmony_ci#include <linux/delay.h> 1962306a36Sopenharmony_ci#include <asm/hvcall.h> 2062306a36Sopenharmony_ci#include "ehea.h" 2162306a36Sopenharmony_ci#include "ehea_hw.h" 2262306a36Sopenharmony_ci 2362306a36Sopenharmony_ci/* Some abbreviations used here: 2462306a36Sopenharmony_ci * 2562306a36Sopenharmony_ci * hcp_* - structures, variables and functions releated to Hypervisor Calls 2662306a36Sopenharmony_ci */ 2762306a36Sopenharmony_ci 2862306a36Sopenharmony_ci/* Number of pages which can be registered at once by H_REGISTER_HEA_RPAGES */ 2962306a36Sopenharmony_ci#define EHEA_MAX_RPAGE 512 3062306a36Sopenharmony_ci 3162306a36Sopenharmony_ci/* Notification Event Queue (NEQ) Entry bit masks */ 3262306a36Sopenharmony_ci#define NEQE_EVENT_CODE EHEA_BMASK_IBM(2, 7) 3362306a36Sopenharmony_ci#define NEQE_PORTNUM EHEA_BMASK_IBM(32, 47) 3462306a36Sopenharmony_ci#define NEQE_PORT_UP EHEA_BMASK_IBM(16, 16) 3562306a36Sopenharmony_ci#define NEQE_EXTSWITCH_PORT_UP EHEA_BMASK_IBM(17, 17) 3662306a36Sopenharmony_ci#define NEQE_EXTSWITCH_PRIMARY EHEA_BMASK_IBM(18, 18) 3762306a36Sopenharmony_ci#define NEQE_PLID EHEA_BMASK_IBM(16, 47) 3862306a36Sopenharmony_ci 3962306a36Sopenharmony_ci/* Notification Event Codes */ 4062306a36Sopenharmony_ci#define EHEA_EC_PORTSTATE_CHG 0x30 4162306a36Sopenharmony_ci#define EHEA_EC_ADAPTER_MALFUNC 0x32 4262306a36Sopenharmony_ci#define EHEA_EC_PORT_MALFUNC 0x33 4362306a36Sopenharmony_ci 4462306a36Sopenharmony_ci/* Notification Event Log Register (NELR) bit masks */ 4562306a36Sopenharmony_ci#define NELR_PORT_MALFUNC EHEA_BMASK_IBM(61, 61) 4662306a36Sopenharmony_ci#define NELR_ADAPTER_MALFUNC EHEA_BMASK_IBM(62, 62) 4762306a36Sopenharmony_ci#define NELR_PORTSTATE_CHG EHEA_BMASK_IBM(63, 63) 4862306a36Sopenharmony_ci 4962306a36Sopenharmony_cistatic inline void hcp_epas_ctor(struct h_epas *epas, u64 paddr_kernel, 5062306a36Sopenharmony_ci u64 paddr_user) 5162306a36Sopenharmony_ci{ 5262306a36Sopenharmony_ci /* To support 64k pages we must round to 64k page boundary */ 5362306a36Sopenharmony_ci epas->kernel.addr = ioremap((paddr_kernel & PAGE_MASK), PAGE_SIZE) + 5462306a36Sopenharmony_ci (paddr_kernel & ~PAGE_MASK); 5562306a36Sopenharmony_ci epas->user.addr = paddr_user; 5662306a36Sopenharmony_ci} 5762306a36Sopenharmony_ci 5862306a36Sopenharmony_cistatic inline void hcp_epas_dtor(struct h_epas *epas) 5962306a36Sopenharmony_ci{ 6062306a36Sopenharmony_ci if (epas->kernel.addr) 6162306a36Sopenharmony_ci iounmap((void __iomem *)((u64)epas->kernel.addr & PAGE_MASK)); 6262306a36Sopenharmony_ci 6362306a36Sopenharmony_ci epas->user.addr = 0; 6462306a36Sopenharmony_ci epas->kernel.addr = 0; 6562306a36Sopenharmony_ci} 6662306a36Sopenharmony_ci 6762306a36Sopenharmony_cistruct hcp_modify_qp_cb0 { 6862306a36Sopenharmony_ci u64 qp_ctl_reg; /* 00 */ 6962306a36Sopenharmony_ci u32 max_swqe; /* 02 */ 7062306a36Sopenharmony_ci u32 max_rwqe; /* 03 */ 7162306a36Sopenharmony_ci u32 port_nb; /* 04 */ 7262306a36Sopenharmony_ci u32 reserved0; /* 05 */ 7362306a36Sopenharmony_ci u64 qp_aer; /* 06 */ 7462306a36Sopenharmony_ci u64 qp_tenure; /* 08 */ 7562306a36Sopenharmony_ci}; 7662306a36Sopenharmony_ci 7762306a36Sopenharmony_ci/* Hcall Query/Modify Queue Pair Control Block 0 Selection Mask Bits */ 7862306a36Sopenharmony_ci#define H_QPCB0_ALL EHEA_BMASK_IBM(0, 5) 7962306a36Sopenharmony_ci#define H_QPCB0_QP_CTL_REG EHEA_BMASK_IBM(0, 0) 8062306a36Sopenharmony_ci#define H_QPCB0_MAX_SWQE EHEA_BMASK_IBM(1, 1) 8162306a36Sopenharmony_ci#define H_QPCB0_MAX_RWQE EHEA_BMASK_IBM(2, 2) 8262306a36Sopenharmony_ci#define H_QPCB0_PORT_NB EHEA_BMASK_IBM(3, 3) 8362306a36Sopenharmony_ci#define H_QPCB0_QP_AER EHEA_BMASK_IBM(4, 4) 8462306a36Sopenharmony_ci#define H_QPCB0_QP_TENURE EHEA_BMASK_IBM(5, 5) 8562306a36Sopenharmony_ci 8662306a36Sopenharmony_ci/* Queue Pair Control Register Status Bits */ 8762306a36Sopenharmony_ci#define H_QP_CR_ENABLED 0x8000000000000000ULL /* QP enabled */ 8862306a36Sopenharmony_ci /* QP States: */ 8962306a36Sopenharmony_ci#define H_QP_CR_STATE_RESET 0x0000010000000000ULL /* Reset */ 9062306a36Sopenharmony_ci#define H_QP_CR_STATE_INITIALIZED 0x0000020000000000ULL /* Initialized */ 9162306a36Sopenharmony_ci#define H_QP_CR_STATE_RDY2RCV 0x0000030000000000ULL /* Ready to recv */ 9262306a36Sopenharmony_ci#define H_QP_CR_STATE_RDY2SND 0x0000050000000000ULL /* Ready to send */ 9362306a36Sopenharmony_ci#define H_QP_CR_STATE_ERROR 0x0000800000000000ULL /* Error */ 9462306a36Sopenharmony_ci#define H_QP_CR_RES_STATE 0x0000007F00000000ULL /* Resultant state */ 9562306a36Sopenharmony_ci 9662306a36Sopenharmony_cistruct hcp_modify_qp_cb1 { 9762306a36Sopenharmony_ci u32 qpn; /* 00 */ 9862306a36Sopenharmony_ci u32 qp_asyn_ev_eq_nb; /* 01 */ 9962306a36Sopenharmony_ci u64 sq_cq_handle; /* 02 */ 10062306a36Sopenharmony_ci u64 rq_cq_handle; /* 04 */ 10162306a36Sopenharmony_ci /* sgel = scatter gather element */ 10262306a36Sopenharmony_ci u32 sgel_nb_sq; /* 06 */ 10362306a36Sopenharmony_ci u32 sgel_nb_rq1; /* 07 */ 10462306a36Sopenharmony_ci u32 sgel_nb_rq2; /* 08 */ 10562306a36Sopenharmony_ci u32 sgel_nb_rq3; /* 09 */ 10662306a36Sopenharmony_ci}; 10762306a36Sopenharmony_ci 10862306a36Sopenharmony_ci/* Hcall Query/Modify Queue Pair Control Block 1 Selection Mask Bits */ 10962306a36Sopenharmony_ci#define H_QPCB1_ALL EHEA_BMASK_IBM(0, 7) 11062306a36Sopenharmony_ci#define H_QPCB1_QPN EHEA_BMASK_IBM(0, 0) 11162306a36Sopenharmony_ci#define H_QPCB1_ASYN_EV_EQ_NB EHEA_BMASK_IBM(1, 1) 11262306a36Sopenharmony_ci#define H_QPCB1_SQ_CQ_HANDLE EHEA_BMASK_IBM(2, 2) 11362306a36Sopenharmony_ci#define H_QPCB1_RQ_CQ_HANDLE EHEA_BMASK_IBM(3, 3) 11462306a36Sopenharmony_ci#define H_QPCB1_SGEL_NB_SQ EHEA_BMASK_IBM(4, 4) 11562306a36Sopenharmony_ci#define H_QPCB1_SGEL_NB_RQ1 EHEA_BMASK_IBM(5, 5) 11662306a36Sopenharmony_ci#define H_QPCB1_SGEL_NB_RQ2 EHEA_BMASK_IBM(6, 6) 11762306a36Sopenharmony_ci#define H_QPCB1_SGEL_NB_RQ3 EHEA_BMASK_IBM(7, 7) 11862306a36Sopenharmony_ci 11962306a36Sopenharmony_cistruct hcp_query_ehea { 12062306a36Sopenharmony_ci u32 cur_num_qps; /* 00 */ 12162306a36Sopenharmony_ci u32 cur_num_cqs; /* 01 */ 12262306a36Sopenharmony_ci u32 cur_num_eqs; /* 02 */ 12362306a36Sopenharmony_ci u32 cur_num_mrs; /* 03 */ 12462306a36Sopenharmony_ci u32 auth_level; /* 04 */ 12562306a36Sopenharmony_ci u32 max_num_qps; /* 05 */ 12662306a36Sopenharmony_ci u32 max_num_cqs; /* 06 */ 12762306a36Sopenharmony_ci u32 max_num_eqs; /* 07 */ 12862306a36Sopenharmony_ci u32 max_num_mrs; /* 08 */ 12962306a36Sopenharmony_ci u32 reserved0; /* 09 */ 13062306a36Sopenharmony_ci u32 int_clock_freq; /* 10 */ 13162306a36Sopenharmony_ci u32 max_num_pds; /* 11 */ 13262306a36Sopenharmony_ci u32 max_num_addr_handles; /* 12 */ 13362306a36Sopenharmony_ci u32 max_num_cqes; /* 13 */ 13462306a36Sopenharmony_ci u32 max_num_wqes; /* 14 */ 13562306a36Sopenharmony_ci u32 max_num_sgel_rq1wqe; /* 15 */ 13662306a36Sopenharmony_ci u32 max_num_sgel_rq2wqe; /* 16 */ 13762306a36Sopenharmony_ci u32 max_num_sgel_rq3wqe; /* 17 */ 13862306a36Sopenharmony_ci u32 mr_page_size; /* 18 */ 13962306a36Sopenharmony_ci u32 reserved1; /* 19 */ 14062306a36Sopenharmony_ci u64 max_mr_size; /* 20 */ 14162306a36Sopenharmony_ci u64 reserved2; /* 22 */ 14262306a36Sopenharmony_ci u32 num_ports; /* 24 */ 14362306a36Sopenharmony_ci u32 reserved3; /* 25 */ 14462306a36Sopenharmony_ci u32 reserved4; /* 26 */ 14562306a36Sopenharmony_ci u32 reserved5; /* 27 */ 14662306a36Sopenharmony_ci u64 max_mc_mac; /* 28 */ 14762306a36Sopenharmony_ci u64 ehea_cap; /* 30 */ 14862306a36Sopenharmony_ci u32 max_isn_per_eq; /* 32 */ 14962306a36Sopenharmony_ci u32 max_num_neq; /* 33 */ 15062306a36Sopenharmony_ci u64 max_num_vlan_ids; /* 34 */ 15162306a36Sopenharmony_ci u32 max_num_port_group; /* 36 */ 15262306a36Sopenharmony_ci u32 max_num_phys_port; /* 37 */ 15362306a36Sopenharmony_ci 15462306a36Sopenharmony_ci}; 15562306a36Sopenharmony_ci 15662306a36Sopenharmony_ci/* Hcall Query/Modify Port Control Block defines */ 15762306a36Sopenharmony_ci#define H_PORT_CB0 0 15862306a36Sopenharmony_ci#define H_PORT_CB1 1 15962306a36Sopenharmony_ci#define H_PORT_CB2 2 16062306a36Sopenharmony_ci#define H_PORT_CB3 3 16162306a36Sopenharmony_ci#define H_PORT_CB4 4 16262306a36Sopenharmony_ci#define H_PORT_CB5 5 16362306a36Sopenharmony_ci#define H_PORT_CB6 6 16462306a36Sopenharmony_ci#define H_PORT_CB7 7 16562306a36Sopenharmony_ci 16662306a36Sopenharmony_cistruct hcp_ehea_port_cb0 { 16762306a36Sopenharmony_ci u64 port_mac_addr; 16862306a36Sopenharmony_ci u64 port_rc; 16962306a36Sopenharmony_ci u64 reserved0; 17062306a36Sopenharmony_ci u32 port_op_state; 17162306a36Sopenharmony_ci u32 port_speed; 17262306a36Sopenharmony_ci u32 ext_swport_op_state; 17362306a36Sopenharmony_ci u32 neg_tpf_prpf; 17462306a36Sopenharmony_ci u32 num_default_qps; 17562306a36Sopenharmony_ci u32 reserved1; 17662306a36Sopenharmony_ci u64 default_qpn_arr[16]; 17762306a36Sopenharmony_ci}; 17862306a36Sopenharmony_ci 17962306a36Sopenharmony_ci/* Hcall Query/Modify Port Control Block 0 Selection Mask Bits */ 18062306a36Sopenharmony_ci#define H_PORT_CB0_ALL EHEA_BMASK_IBM(0, 7) /* Set all bits */ 18162306a36Sopenharmony_ci#define H_PORT_CB0_MAC EHEA_BMASK_IBM(0, 0) /* MAC address */ 18262306a36Sopenharmony_ci#define H_PORT_CB0_PRC EHEA_BMASK_IBM(1, 1) /* Port Recv Control */ 18362306a36Sopenharmony_ci#define H_PORT_CB0_DEFQPNARRAY EHEA_BMASK_IBM(7, 7) /* Default QPN Array */ 18462306a36Sopenharmony_ci 18562306a36Sopenharmony_ci/* Hcall Query Port: Returned port speed values */ 18662306a36Sopenharmony_ci#define H_SPEED_10M_H 1 /* 10 Mbps, Half Duplex */ 18762306a36Sopenharmony_ci#define H_SPEED_10M_F 2 /* 10 Mbps, Full Duplex */ 18862306a36Sopenharmony_ci#define H_SPEED_100M_H 3 /* 100 Mbps, Half Duplex */ 18962306a36Sopenharmony_ci#define H_SPEED_100M_F 4 /* 100 Mbps, Full Duplex */ 19062306a36Sopenharmony_ci#define H_SPEED_1G_F 6 /* 1 Gbps, Full Duplex */ 19162306a36Sopenharmony_ci#define H_SPEED_10G_F 8 /* 10 Gbps, Full Duplex */ 19262306a36Sopenharmony_ci 19362306a36Sopenharmony_ci/* Port Receive Control Status Bits */ 19462306a36Sopenharmony_ci#define PXLY_RC_VALID EHEA_BMASK_IBM(49, 49) 19562306a36Sopenharmony_ci#define PXLY_RC_VLAN_XTRACT EHEA_BMASK_IBM(50, 50) 19662306a36Sopenharmony_ci#define PXLY_RC_TCP_6_TUPLE EHEA_BMASK_IBM(51, 51) 19762306a36Sopenharmony_ci#define PXLY_RC_UDP_6_TUPLE EHEA_BMASK_IBM(52, 52) 19862306a36Sopenharmony_ci#define PXLY_RC_TCP_3_TUPLE EHEA_BMASK_IBM(53, 53) 19962306a36Sopenharmony_ci#define PXLY_RC_TCP_2_TUPLE EHEA_BMASK_IBM(54, 54) 20062306a36Sopenharmony_ci#define PXLY_RC_LLC_SNAP EHEA_BMASK_IBM(55, 55) 20162306a36Sopenharmony_ci#define PXLY_RC_JUMBO_FRAME EHEA_BMASK_IBM(56, 56) 20262306a36Sopenharmony_ci#define PXLY_RC_FRAG_IP_PKT EHEA_BMASK_IBM(57, 57) 20362306a36Sopenharmony_ci#define PXLY_RC_TCP_UDP_CHKSUM EHEA_BMASK_IBM(58, 58) 20462306a36Sopenharmony_ci#define PXLY_RC_IP_CHKSUM EHEA_BMASK_IBM(59, 59) 20562306a36Sopenharmony_ci#define PXLY_RC_MAC_FILTER EHEA_BMASK_IBM(60, 60) 20662306a36Sopenharmony_ci#define PXLY_RC_UNTAG_FILTER EHEA_BMASK_IBM(61, 61) 20762306a36Sopenharmony_ci#define PXLY_RC_VLAN_TAG_FILTER EHEA_BMASK_IBM(62, 63) 20862306a36Sopenharmony_ci 20962306a36Sopenharmony_ci#define PXLY_RC_VLAN_FILTER 2 21062306a36Sopenharmony_ci#define PXLY_RC_VLAN_PERM 0 21162306a36Sopenharmony_ci 21262306a36Sopenharmony_ci 21362306a36Sopenharmony_ci#define H_PORT_CB1_ALL 0x8000000000000000ULL 21462306a36Sopenharmony_ci 21562306a36Sopenharmony_cistruct hcp_ehea_port_cb1 { 21662306a36Sopenharmony_ci u64 vlan_filter[64]; 21762306a36Sopenharmony_ci}; 21862306a36Sopenharmony_ci 21962306a36Sopenharmony_ci#define H_PORT_CB2_ALL 0xFFE0000000000000ULL 22062306a36Sopenharmony_ci 22162306a36Sopenharmony_cistruct hcp_ehea_port_cb2 { 22262306a36Sopenharmony_ci u64 rxo; 22362306a36Sopenharmony_ci u64 rxucp; 22462306a36Sopenharmony_ci u64 rxufd; 22562306a36Sopenharmony_ci u64 rxuerr; 22662306a36Sopenharmony_ci u64 rxftl; 22762306a36Sopenharmony_ci u64 rxmcp; 22862306a36Sopenharmony_ci u64 rxbcp; 22962306a36Sopenharmony_ci u64 txo; 23062306a36Sopenharmony_ci u64 txucp; 23162306a36Sopenharmony_ci u64 txmcp; 23262306a36Sopenharmony_ci u64 txbcp; 23362306a36Sopenharmony_ci}; 23462306a36Sopenharmony_ci 23562306a36Sopenharmony_cistruct hcp_ehea_port_cb3 { 23662306a36Sopenharmony_ci u64 vlan_bc_filter[64]; 23762306a36Sopenharmony_ci u64 vlan_mc_filter[64]; 23862306a36Sopenharmony_ci u64 vlan_un_filter[64]; 23962306a36Sopenharmony_ci u64 port_mac_hash_array[64]; 24062306a36Sopenharmony_ci}; 24162306a36Sopenharmony_ci 24262306a36Sopenharmony_ci#define H_PORT_CB4_ALL 0xF000000000000000ULL 24362306a36Sopenharmony_ci#define H_PORT_CB4_JUMBO 0x1000000000000000ULL 24462306a36Sopenharmony_ci#define H_PORT_CB4_SPEED 0x8000000000000000ULL 24562306a36Sopenharmony_ci 24662306a36Sopenharmony_cistruct hcp_ehea_port_cb4 { 24762306a36Sopenharmony_ci u32 port_speed; 24862306a36Sopenharmony_ci u32 pause_frame; 24962306a36Sopenharmony_ci u32 ens_port_op_state; 25062306a36Sopenharmony_ci u32 jumbo_frame; 25162306a36Sopenharmony_ci u32 ens_port_wrap; 25262306a36Sopenharmony_ci}; 25362306a36Sopenharmony_ci 25462306a36Sopenharmony_ci/* Hcall Query/Modify Port Control Block 5 Selection Mask Bits */ 25562306a36Sopenharmony_ci#define H_PORT_CB5_RCU 0x0001000000000000ULL 25662306a36Sopenharmony_ci#define PXS_RCU EHEA_BMASK_IBM(61, 63) 25762306a36Sopenharmony_ci 25862306a36Sopenharmony_cistruct hcp_ehea_port_cb5 { 25962306a36Sopenharmony_ci u64 prc; /* 00 */ 26062306a36Sopenharmony_ci u64 uaa; /* 01 */ 26162306a36Sopenharmony_ci u64 macvc; /* 02 */ 26262306a36Sopenharmony_ci u64 xpcsc; /* 03 */ 26362306a36Sopenharmony_ci u64 xpcsp; /* 04 */ 26462306a36Sopenharmony_ci u64 pcsid; /* 05 */ 26562306a36Sopenharmony_ci u64 xpcsst; /* 06 */ 26662306a36Sopenharmony_ci u64 pthlb; /* 07 */ 26762306a36Sopenharmony_ci u64 pthrb; /* 08 */ 26862306a36Sopenharmony_ci u64 pqu; /* 09 */ 26962306a36Sopenharmony_ci u64 pqd; /* 10 */ 27062306a36Sopenharmony_ci u64 prt; /* 11 */ 27162306a36Sopenharmony_ci u64 wsth; /* 12 */ 27262306a36Sopenharmony_ci u64 rcb; /* 13 */ 27362306a36Sopenharmony_ci u64 rcm; /* 14 */ 27462306a36Sopenharmony_ci u64 rcu; /* 15 */ 27562306a36Sopenharmony_ci u64 macc; /* 16 */ 27662306a36Sopenharmony_ci u64 pc; /* 17 */ 27762306a36Sopenharmony_ci u64 pst; /* 18 */ 27862306a36Sopenharmony_ci u64 ducqpn; /* 19 */ 27962306a36Sopenharmony_ci u64 mcqpn; /* 20 */ 28062306a36Sopenharmony_ci u64 mma; /* 21 */ 28162306a36Sopenharmony_ci u64 pmc0h; /* 22 */ 28262306a36Sopenharmony_ci u64 pmc0l; /* 23 */ 28362306a36Sopenharmony_ci u64 lbc; /* 24 */ 28462306a36Sopenharmony_ci}; 28562306a36Sopenharmony_ci 28662306a36Sopenharmony_ci#define H_PORT_CB6_ALL 0xFFFFFE7FFFFF8000ULL 28762306a36Sopenharmony_ci 28862306a36Sopenharmony_cistruct hcp_ehea_port_cb6 { 28962306a36Sopenharmony_ci u64 rxo; /* 00 */ 29062306a36Sopenharmony_ci u64 rx64; /* 01 */ 29162306a36Sopenharmony_ci u64 rx65; /* 02 */ 29262306a36Sopenharmony_ci u64 rx128; /* 03 */ 29362306a36Sopenharmony_ci u64 rx256; /* 04 */ 29462306a36Sopenharmony_ci u64 rx512; /* 05 */ 29562306a36Sopenharmony_ci u64 rx1024; /* 06 */ 29662306a36Sopenharmony_ci u64 rxbfcs; /* 07 */ 29762306a36Sopenharmony_ci u64 rxime; /* 08 */ 29862306a36Sopenharmony_ci u64 rxrle; /* 09 */ 29962306a36Sopenharmony_ci u64 rxorle; /* 10 */ 30062306a36Sopenharmony_ci u64 rxftl; /* 11 */ 30162306a36Sopenharmony_ci u64 rxjab; /* 12 */ 30262306a36Sopenharmony_ci u64 rxse; /* 13 */ 30362306a36Sopenharmony_ci u64 rxce; /* 14 */ 30462306a36Sopenharmony_ci u64 rxrf; /* 15 */ 30562306a36Sopenharmony_ci u64 rxfrag; /* 16 */ 30662306a36Sopenharmony_ci u64 rxuoc; /* 17 */ 30762306a36Sopenharmony_ci u64 rxcpf; /* 18 */ 30862306a36Sopenharmony_ci u64 rxsb; /* 19 */ 30962306a36Sopenharmony_ci u64 rxfd; /* 20 */ 31062306a36Sopenharmony_ci u64 rxoerr; /* 21 */ 31162306a36Sopenharmony_ci u64 rxaln; /* 22 */ 31262306a36Sopenharmony_ci u64 ducqpn; /* 23 */ 31362306a36Sopenharmony_ci u64 reserved0; /* 24 */ 31462306a36Sopenharmony_ci u64 rxmcp; /* 25 */ 31562306a36Sopenharmony_ci u64 rxbcp; /* 26 */ 31662306a36Sopenharmony_ci u64 txmcp; /* 27 */ 31762306a36Sopenharmony_ci u64 txbcp; /* 28 */ 31862306a36Sopenharmony_ci u64 txo; /* 29 */ 31962306a36Sopenharmony_ci u64 tx64; /* 30 */ 32062306a36Sopenharmony_ci u64 tx65; /* 31 */ 32162306a36Sopenharmony_ci u64 tx128; /* 32 */ 32262306a36Sopenharmony_ci u64 tx256; /* 33 */ 32362306a36Sopenharmony_ci u64 tx512; /* 34 */ 32462306a36Sopenharmony_ci u64 tx1024; /* 35 */ 32562306a36Sopenharmony_ci u64 txbfcs; /* 36 */ 32662306a36Sopenharmony_ci u64 txcpf; /* 37 */ 32762306a36Sopenharmony_ci u64 txlf; /* 38 */ 32862306a36Sopenharmony_ci u64 txrf; /* 39 */ 32962306a36Sopenharmony_ci u64 txime; /* 40 */ 33062306a36Sopenharmony_ci u64 txsc; /* 41 */ 33162306a36Sopenharmony_ci u64 txmc; /* 42 */ 33262306a36Sopenharmony_ci u64 txsqe; /* 43 */ 33362306a36Sopenharmony_ci u64 txdef; /* 44 */ 33462306a36Sopenharmony_ci u64 txlcol; /* 45 */ 33562306a36Sopenharmony_ci u64 txexcol; /* 46 */ 33662306a36Sopenharmony_ci u64 txcse; /* 47 */ 33762306a36Sopenharmony_ci u64 txbor; /* 48 */ 33862306a36Sopenharmony_ci}; 33962306a36Sopenharmony_ci 34062306a36Sopenharmony_ci#define H_PORT_CB7_DUCQPN 0x8000000000000000ULL 34162306a36Sopenharmony_ci 34262306a36Sopenharmony_cistruct hcp_ehea_port_cb7 { 34362306a36Sopenharmony_ci u64 def_uc_qpn; 34462306a36Sopenharmony_ci}; 34562306a36Sopenharmony_ci 34662306a36Sopenharmony_ciu64 ehea_h_query_ehea_qp(const u64 adapter_handle, 34762306a36Sopenharmony_ci const u8 qp_category, 34862306a36Sopenharmony_ci const u64 qp_handle, const u64 sel_mask, 34962306a36Sopenharmony_ci void *cb_addr); 35062306a36Sopenharmony_ci 35162306a36Sopenharmony_ciu64 ehea_h_modify_ehea_qp(const u64 adapter_handle, 35262306a36Sopenharmony_ci const u8 cat, 35362306a36Sopenharmony_ci const u64 qp_handle, 35462306a36Sopenharmony_ci const u64 sel_mask, 35562306a36Sopenharmony_ci void *cb_addr, 35662306a36Sopenharmony_ci u64 *inv_attr_id, 35762306a36Sopenharmony_ci u64 *proc_mask, u16 *out_swr, u16 *out_rwr); 35862306a36Sopenharmony_ci 35962306a36Sopenharmony_ciu64 ehea_h_alloc_resource_eq(const u64 adapter_handle, 36062306a36Sopenharmony_ci struct ehea_eq_attr *eq_attr, u64 *eq_handle); 36162306a36Sopenharmony_ci 36262306a36Sopenharmony_ciu64 ehea_h_alloc_resource_cq(const u64 adapter_handle, 36362306a36Sopenharmony_ci struct ehea_cq_attr *cq_attr, 36462306a36Sopenharmony_ci u64 *cq_handle, struct h_epas *epas); 36562306a36Sopenharmony_ci 36662306a36Sopenharmony_ciu64 ehea_h_alloc_resource_qp(const u64 adapter_handle, 36762306a36Sopenharmony_ci struct ehea_qp_init_attr *init_attr, 36862306a36Sopenharmony_ci const u32 pd, 36962306a36Sopenharmony_ci u64 *qp_handle, struct h_epas *h_epas); 37062306a36Sopenharmony_ci 37162306a36Sopenharmony_ci#define H_REG_RPAGE_PAGE_SIZE EHEA_BMASK_IBM(48, 55) 37262306a36Sopenharmony_ci#define H_REG_RPAGE_QT EHEA_BMASK_IBM(62, 63) 37362306a36Sopenharmony_ci 37462306a36Sopenharmony_ciu64 ehea_h_register_rpage(const u64 adapter_handle, 37562306a36Sopenharmony_ci const u8 pagesize, 37662306a36Sopenharmony_ci const u8 queue_type, 37762306a36Sopenharmony_ci const u64 resource_handle, 37862306a36Sopenharmony_ci const u64 log_pageaddr, u64 count); 37962306a36Sopenharmony_ci 38062306a36Sopenharmony_ci#define H_DISABLE_GET_EHEA_WQE_P 1 38162306a36Sopenharmony_ci#define H_DISABLE_GET_SQ_WQE_P 2 38262306a36Sopenharmony_ci#define H_DISABLE_GET_RQC 3 38362306a36Sopenharmony_ci 38462306a36Sopenharmony_ciu64 ehea_h_disable_and_get_hea(const u64 adapter_handle, const u64 qp_handle); 38562306a36Sopenharmony_ci 38662306a36Sopenharmony_ci#define FORCE_FREE 1 38762306a36Sopenharmony_ci#define NORMAL_FREE 0 38862306a36Sopenharmony_ci 38962306a36Sopenharmony_ciu64 ehea_h_free_resource(const u64 adapter_handle, const u64 res_handle, 39062306a36Sopenharmony_ci u64 force_bit); 39162306a36Sopenharmony_ci 39262306a36Sopenharmony_ciu64 ehea_h_alloc_resource_mr(const u64 adapter_handle, const u64 vaddr, 39362306a36Sopenharmony_ci const u64 length, const u32 access_ctrl, 39462306a36Sopenharmony_ci const u32 pd, u64 *mr_handle, u32 *lkey); 39562306a36Sopenharmony_ci 39662306a36Sopenharmony_ciu64 ehea_h_register_rpage_mr(const u64 adapter_handle, const u64 mr_handle, 39762306a36Sopenharmony_ci const u8 pagesize, const u8 queue_type, 39862306a36Sopenharmony_ci const u64 log_pageaddr, const u64 count); 39962306a36Sopenharmony_ci 40062306a36Sopenharmony_ciu64 ehea_h_register_smr(const u64 adapter_handle, const u64 orig_mr_handle, 40162306a36Sopenharmony_ci const u64 vaddr_in, const u32 access_ctrl, const u32 pd, 40262306a36Sopenharmony_ci struct ehea_mr *mr); 40362306a36Sopenharmony_ci 40462306a36Sopenharmony_ciu64 ehea_h_query_ehea(const u64 adapter_handle, void *cb_addr); 40562306a36Sopenharmony_ci 40662306a36Sopenharmony_ci/* output param R5 */ 40762306a36Sopenharmony_ci#define H_MEHEAPORT_CAT EHEA_BMASK_IBM(40, 47) 40862306a36Sopenharmony_ci#define H_MEHEAPORT_PN EHEA_BMASK_IBM(48, 63) 40962306a36Sopenharmony_ci 41062306a36Sopenharmony_ciu64 ehea_h_query_ehea_port(const u64 adapter_handle, const u16 port_num, 41162306a36Sopenharmony_ci const u8 cb_cat, const u64 select_mask, 41262306a36Sopenharmony_ci void *cb_addr); 41362306a36Sopenharmony_ci 41462306a36Sopenharmony_ciu64 ehea_h_modify_ehea_port(const u64 adapter_handle, const u16 port_num, 41562306a36Sopenharmony_ci const u8 cb_cat, const u64 select_mask, 41662306a36Sopenharmony_ci void *cb_addr); 41762306a36Sopenharmony_ci 41862306a36Sopenharmony_ci#define H_REGBCMC_PN EHEA_BMASK_IBM(48, 63) 41962306a36Sopenharmony_ci#define H_REGBCMC_REGTYPE EHEA_BMASK_IBM(60, 63) 42062306a36Sopenharmony_ci#define H_REGBCMC_MACADDR EHEA_BMASK_IBM(16, 63) 42162306a36Sopenharmony_ci#define H_REGBCMC_VLANID EHEA_BMASK_IBM(52, 63) 42262306a36Sopenharmony_ci 42362306a36Sopenharmony_ciu64 ehea_h_reg_dereg_bcmc(const u64 adapter_handle, const u16 port_num, 42462306a36Sopenharmony_ci const u8 reg_type, const u64 mc_mac_addr, 42562306a36Sopenharmony_ci const u16 vlan_id, const u32 hcall_id); 42662306a36Sopenharmony_ci 42762306a36Sopenharmony_ciu64 ehea_h_reset_events(const u64 adapter_handle, const u64 neq_handle, 42862306a36Sopenharmony_ci const u64 event_mask); 42962306a36Sopenharmony_ci 43062306a36Sopenharmony_ciu64 ehea_h_error_data(const u64 adapter_handle, const u64 ressource_handle, 43162306a36Sopenharmony_ci void *rblock); 43262306a36Sopenharmony_ci 43362306a36Sopenharmony_ci#endif /* __EHEA_PHYP_H__ */ 434