177241056SMike Marciniszyn /* 2bf90aaddSMichael J. Ruhl * Copyright(c) 2015 - 2017 Intel Corporation. 377241056SMike Marciniszyn * 477241056SMike Marciniszyn * This file is provided under a dual BSD/GPLv2 license. When using or 577241056SMike Marciniszyn * redistributing this file, you may do so under either license. 677241056SMike Marciniszyn * 777241056SMike Marciniszyn * GPL LICENSE SUMMARY 877241056SMike Marciniszyn * 977241056SMike Marciniszyn * This program is free software; you can redistribute it and/or modify 1077241056SMike Marciniszyn * it under the terms of version 2 of the GNU General Public License as 1177241056SMike Marciniszyn * published by the Free Software Foundation. 1277241056SMike Marciniszyn * 1377241056SMike Marciniszyn * This program is distributed in the hope that it will be useful, but 1477241056SMike Marciniszyn * WITHOUT ANY WARRANTY; without even the implied warranty of 1577241056SMike Marciniszyn * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 1677241056SMike Marciniszyn * General Public License for more details. 1777241056SMike Marciniszyn * 1877241056SMike Marciniszyn * BSD LICENSE 1977241056SMike Marciniszyn * 2077241056SMike Marciniszyn * Redistribution and use in source and binary forms, with or without 2177241056SMike Marciniszyn * modification, are permitted provided that the following conditions 2277241056SMike Marciniszyn * are met: 2377241056SMike Marciniszyn * 2477241056SMike Marciniszyn * - Redistributions of source code must retain the above copyright 2577241056SMike Marciniszyn * notice, this list of conditions and the following disclaimer. 2677241056SMike Marciniszyn * - Redistributions in binary form must reproduce the above copyright 2777241056SMike Marciniszyn * notice, this list of conditions and the following disclaimer in 2877241056SMike Marciniszyn * the documentation and/or other materials provided with the 2977241056SMike Marciniszyn * distribution. 3077241056SMike Marciniszyn * - Neither the name of Intel Corporation nor the names of its 3177241056SMike Marciniszyn * contributors may be used to endorse or promote products derived 3277241056SMike Marciniszyn * from this software without specific prior written permission. 3377241056SMike Marciniszyn * 3477241056SMike Marciniszyn * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 3577241056SMike Marciniszyn * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 3677241056SMike Marciniszyn * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 3777241056SMike Marciniszyn * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 3877241056SMike Marciniszyn * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 3977241056SMike Marciniszyn * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 4077241056SMike Marciniszyn * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 4177241056SMike Marciniszyn * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 4277241056SMike Marciniszyn * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 4377241056SMike Marciniszyn * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 4477241056SMike Marciniszyn * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 4577241056SMike Marciniszyn * 4677241056SMike Marciniszyn */ 4777241056SMike Marciniszyn #ifndef _HFI1_MAD_H 4877241056SMike Marciniszyn #define _HFI1_MAD_H 4977241056SMike Marciniszyn 5077241056SMike Marciniszyn #include <rdma/ib_pma.h> 5177241056SMike Marciniszyn #include <rdma/opa_smi.h> 5277241056SMike Marciniszyn #include <rdma/opa_port_info.h> 5377241056SMike Marciniszyn #include "opa_compat.h" 5477241056SMike Marciniszyn 5571a1d624SJubin John /* 5671a1d624SJubin John * OPA Traps 5771a1d624SJubin John */ 5871a1d624SJubin John #define OPA_TRAP_GID_NOW_IN_SERVICE cpu_to_be16(64) 5971a1d624SJubin John #define OPA_TRAP_GID_OUT_OF_SERVICE cpu_to_be16(65) 6071a1d624SJubin John #define OPA_TRAP_ADD_MULTICAST_GROUP cpu_to_be16(66) 6171a1d624SJubin John #define OPA_TRAL_DEL_MULTICAST_GROUP cpu_to_be16(67) 6271a1d624SJubin John #define OPA_TRAP_UNPATH cpu_to_be16(68) 6371a1d624SJubin John #define OPA_TRAP_REPATH cpu_to_be16(69) 6471a1d624SJubin John #define OPA_TRAP_PORT_CHANGE_STATE cpu_to_be16(128) 6571a1d624SJubin John #define OPA_TRAP_LINK_INTEGRITY cpu_to_be16(129) 6671a1d624SJubin John #define OPA_TRAP_EXCESSIVE_BUFFER_OVERRUN cpu_to_be16(130) 6771a1d624SJubin John #define OPA_TRAP_FLOW_WATCHDOG cpu_to_be16(131) 6871a1d624SJubin John #define OPA_TRAP_CHANGE_CAPABILITY cpu_to_be16(144) 6971a1d624SJubin John #define OPA_TRAP_CHANGE_SYSGUID cpu_to_be16(145) 7071a1d624SJubin John #define OPA_TRAP_BAD_M_KEY cpu_to_be16(256) 7171a1d624SJubin John #define OPA_TRAP_BAD_P_KEY cpu_to_be16(257) 7271a1d624SJubin John #define OPA_TRAP_BAD_Q_KEY cpu_to_be16(258) 7371a1d624SJubin John #define OPA_TRAP_SWITCH_BAD_PKEY cpu_to_be16(259) 7471a1d624SJubin John #define OPA_SMA_TRAP_DATA_LINK_WIDTH cpu_to_be16(2048) 7577241056SMike Marciniszyn 7671a1d624SJubin John /* 7771a1d624SJubin John * Generic trap/notice other local changes flags (trap 144). 7871a1d624SJubin John */ 7971a1d624SJubin John #define OPA_NOTICE_TRAP_LWDE_CHG 0x08 /* Link Width Downgrade Enable 8071a1d624SJubin John * changed 8171a1d624SJubin John */ 8271a1d624SJubin John #define OPA_NOTICE_TRAP_LSE_CHG 0x04 /* Link Speed Enable changed */ 8371a1d624SJubin John #define OPA_NOTICE_TRAP_LWE_CHG 0x02 /* Link Width Enable changed */ 8471a1d624SJubin John #define OPA_NOTICE_TRAP_NODE_DESC_CHG 0x01 8571a1d624SJubin John 8671a1d624SJubin John struct opa_mad_notice_attr { 8771a1d624SJubin John u8 generic_type; 8871a1d624SJubin John u8 prod_type_msb; 8971a1d624SJubin John __be16 prod_type_lsb; 9071a1d624SJubin John __be16 trap_num; 9171a1d624SJubin John __be16 toggle_count; 9271a1d624SJubin John __be32 issuer_lid; 9371a1d624SJubin John __be32 reserved1; 9471a1d624SJubin John union ib_gid issuer_gid; 9571a1d624SJubin John 9671a1d624SJubin John union { 9771a1d624SJubin John struct { 9871a1d624SJubin John u8 details[64]; 9971a1d624SJubin John } raw_data; 10071a1d624SJubin John 10171a1d624SJubin John struct { 10271a1d624SJubin John union ib_gid gid; 10371a1d624SJubin John } __packed ntc_64_65_66_67; 10471a1d624SJubin John 10571a1d624SJubin John struct { 10671a1d624SJubin John __be32 lid; 10771a1d624SJubin John } __packed ntc_128; 10871a1d624SJubin John 10971a1d624SJubin John struct { 11071a1d624SJubin John __be32 lid; /* where violation happened */ 11171a1d624SJubin John u8 port_num; /* where violation happened */ 11271a1d624SJubin John } __packed ntc_129_130_131; 11371a1d624SJubin John 11471a1d624SJubin John struct { 11571a1d624SJubin John __be32 lid; /* LID where change occurred */ 11671a1d624SJubin John __be32 new_cap_mask; /* new capability mask */ 11771a1d624SJubin John __be16 reserved2; 118cb49366fSVishwanathapura, Niranjana __be16 cap_mask3; 11971a1d624SJubin John __be16 change_flags; /* low 4 bits only */ 12071a1d624SJubin John } __packed ntc_144; 12171a1d624SJubin John 12271a1d624SJubin John struct { 12371a1d624SJubin John __be64 new_sys_guid; 12471a1d624SJubin John __be32 lid; /* lid where sys guid changed */ 12571a1d624SJubin John } __packed ntc_145; 12671a1d624SJubin John 12771a1d624SJubin John struct { 12871a1d624SJubin John __be32 lid; 12971a1d624SJubin John __be32 dr_slid; 13071a1d624SJubin John u8 method; 13171a1d624SJubin John u8 dr_trunc_hop; 13271a1d624SJubin John __be16 attr_id; 13371a1d624SJubin John __be32 attr_mod; 13471a1d624SJubin John __be64 mkey; 13571a1d624SJubin John u8 dr_rtn_path[30]; 13671a1d624SJubin John } __packed ntc_256; 13771a1d624SJubin John 13871a1d624SJubin John struct { 13971a1d624SJubin John __be32 lid1; 14071a1d624SJubin John __be32 lid2; 14171a1d624SJubin John __be32 key; 14271a1d624SJubin John u8 sl; /* SL: high 5 bits */ 14371a1d624SJubin John u8 reserved3[3]; 14471a1d624SJubin John union ib_gid gid1; 14571a1d624SJubin John union ib_gid gid2; 14671a1d624SJubin John __be32 qp1; /* high 8 bits reserved */ 14771a1d624SJubin John __be32 qp2; /* high 8 bits reserved */ 14871a1d624SJubin John } __packed ntc_257_258; 14971a1d624SJubin John 15071a1d624SJubin John struct { 15171a1d624SJubin John __be16 flags; /* low 8 bits reserved */ 15271a1d624SJubin John __be16 pkey; 15371a1d624SJubin John __be32 lid1; 15471a1d624SJubin John __be32 lid2; 15571a1d624SJubin John u8 sl; /* SL: high 5 bits */ 15671a1d624SJubin John u8 reserved4[3]; 15771a1d624SJubin John union ib_gid gid1; 15871a1d624SJubin John union ib_gid gid2; 15971a1d624SJubin John __be32 qp1; /* high 8 bits reserved */ 16071a1d624SJubin John __be32 qp2; /* high 8 bits reserved */ 16171a1d624SJubin John } __packed ntc_259; 16271a1d624SJubin John 16371a1d624SJubin John struct { 16471a1d624SJubin John __be32 lid; 16571a1d624SJubin John } __packed ntc_2048; 16671a1d624SJubin John 16771a1d624SJubin John }; 16871a1d624SJubin John u8 class_data[0]; 16971a1d624SJubin John }; 17077241056SMike Marciniszyn 17177241056SMike Marciniszyn #define IB_VLARB_LOWPRI_0_31 1 17277241056SMike Marciniszyn #define IB_VLARB_LOWPRI_32_63 2 17377241056SMike Marciniszyn #define IB_VLARB_HIGHPRI_0_31 3 17477241056SMike Marciniszyn #define IB_VLARB_HIGHPRI_32_63 4 17577241056SMike Marciniszyn 17677241056SMike Marciniszyn #define OPA_MAX_PREEMPT_CAP 32 17777241056SMike Marciniszyn #define OPA_VLARB_LOW_ELEMENTS 0 17877241056SMike Marciniszyn #define OPA_VLARB_HIGH_ELEMENTS 1 17977241056SMike Marciniszyn #define OPA_VLARB_PREEMPT_ELEMENTS 2 18077241056SMike Marciniszyn #define OPA_VLARB_PREEMPT_MATRIX 3 18177241056SMike Marciniszyn 18277241056SMike Marciniszyn #define IB_PMA_PORT_COUNTERS_CONG cpu_to_be16(0xFF00) 18377241056SMike Marciniszyn 18477241056SMike Marciniszyn struct ib_pma_portcounters_cong { 18577241056SMike Marciniszyn u8 reserved; 18677241056SMike Marciniszyn u8 reserved1; 18777241056SMike Marciniszyn __be16 port_check_rate; 18877241056SMike Marciniszyn __be16 symbol_error_counter; 18977241056SMike Marciniszyn u8 link_error_recovery_counter; 19077241056SMike Marciniszyn u8 link_downed_counter; 19177241056SMike Marciniszyn __be16 port_rcv_errors; 19277241056SMike Marciniszyn __be16 port_rcv_remphys_errors; 19377241056SMike Marciniszyn __be16 port_rcv_switch_relay_errors; 19477241056SMike Marciniszyn __be16 port_xmit_discards; 19577241056SMike Marciniszyn u8 port_xmit_constraint_errors; 19677241056SMike Marciniszyn u8 port_rcv_constraint_errors; 19777241056SMike Marciniszyn u8 reserved2; 19877241056SMike Marciniszyn u8 link_overrun_errors; /* LocalLink: 7:4, BufferOverrun: 3:0 */ 19977241056SMike Marciniszyn __be16 reserved3; 20077241056SMike Marciniszyn __be16 vl15_dropped; 20177241056SMike Marciniszyn __be64 port_xmit_data; 20277241056SMike Marciniszyn __be64 port_rcv_data; 20377241056SMike Marciniszyn __be64 port_xmit_packets; 20477241056SMike Marciniszyn __be64 port_rcv_packets; 20577241056SMike Marciniszyn __be64 port_xmit_wait; 20677241056SMike Marciniszyn __be64 port_adr_events; 20777241056SMike Marciniszyn } __packed; 20877241056SMike Marciniszyn 20977241056SMike Marciniszyn #define IB_SMP_UNSUP_VERSION cpu_to_be16(0x0004) 21077241056SMike Marciniszyn #define IB_SMP_UNSUP_METHOD cpu_to_be16(0x0008) 21177241056SMike Marciniszyn #define IB_SMP_UNSUP_METH_ATTR cpu_to_be16(0x000C) 21277241056SMike Marciniszyn #define IB_SMP_INVALID_FIELD cpu_to_be16(0x001C) 21377241056SMike Marciniszyn 21477241056SMike Marciniszyn #define OPA_MAX_PREEMPT_CAP 32 21577241056SMike Marciniszyn #define OPA_VLARB_LOW_ELEMENTS 0 21677241056SMike Marciniszyn #define OPA_VLARB_HIGH_ELEMENTS 1 21777241056SMike Marciniszyn #define OPA_VLARB_PREEMPT_ELEMENTS 2 21877241056SMike Marciniszyn #define OPA_VLARB_PREEMPT_MATRIX 3 21977241056SMike Marciniszyn 22077241056SMike Marciniszyn #define HFI1_XMIT_RATE_UNSUPPORTED 0x0 22177241056SMike Marciniszyn #define HFI1_XMIT_RATE_PICO 0x7 22277241056SMike Marciniszyn /* number of 4nsec cycles equaling 2secs */ 22377241056SMike Marciniszyn #define HFI1_CONG_TIMER_PSINTERVAL 0x1DCD64EC 22477241056SMike Marciniszyn 22577241056SMike Marciniszyn #define IB_CC_SVCTYPE_RC 0x0 22677241056SMike Marciniszyn #define IB_CC_SVCTYPE_UC 0x1 22777241056SMike Marciniszyn #define IB_CC_SVCTYPE_RD 0x2 22877241056SMike Marciniszyn #define IB_CC_SVCTYPE_UD 0x3 22977241056SMike Marciniszyn 23077241056SMike Marciniszyn /* 23177241056SMike Marciniszyn * There should be an equivalent IB #define for the following, but 23277241056SMike Marciniszyn * I cannot find it. 23377241056SMike Marciniszyn */ 23477241056SMike Marciniszyn #define OPA_CC_LOG_TYPE_HFI 2 23577241056SMike Marciniszyn 23677241056SMike Marciniszyn struct opa_hfi1_cong_log_event_internal { 23777241056SMike Marciniszyn u32 lqpn; 23877241056SMike Marciniszyn u32 rqpn; 23977241056SMike Marciniszyn u8 sl; 24077241056SMike Marciniszyn u8 svc_type; 24177241056SMike Marciniszyn u32 rlid; 24277241056SMike Marciniszyn s64 timestamp; /* wider than 32 bits to detect 32 bit rollover */ 24377241056SMike Marciniszyn }; 24477241056SMike Marciniszyn 24577241056SMike Marciniszyn struct opa_hfi1_cong_log_event { 24677241056SMike Marciniszyn u8 local_qp_cn_entry[3]; 24777241056SMike Marciniszyn u8 remote_qp_number_cn_entry[3]; 24877241056SMike Marciniszyn u8 sl_svc_type_cn_entry; /* 5 bits SL, 3 bits svc type */ 24977241056SMike Marciniszyn u8 reserved; 25077241056SMike Marciniszyn __be32 remote_lid_cn_entry; 25177241056SMike Marciniszyn __be32 timestamp_cn_entry; 25277241056SMike Marciniszyn } __packed; 25377241056SMike Marciniszyn 25477241056SMike Marciniszyn #define OPA_CONG_LOG_ELEMS 96 25577241056SMike Marciniszyn 25677241056SMike Marciniszyn struct opa_hfi1_cong_log { 25777241056SMike Marciniszyn u8 log_type; 25877241056SMike Marciniszyn u8 congestion_flags; 25977241056SMike Marciniszyn __be16 threshold_event_counter; 26077241056SMike Marciniszyn __be32 current_time_stamp; 26177241056SMike Marciniszyn u8 threshold_cong_event_map[OPA_MAX_SLS / 8]; 26277241056SMike Marciniszyn struct opa_hfi1_cong_log_event events[OPA_CONG_LOG_ELEMS]; 26377241056SMike Marciniszyn } __packed; 26477241056SMike Marciniszyn 26577241056SMike Marciniszyn #define IB_CC_TABLE_CAP_DEFAULT 31 26677241056SMike Marciniszyn 26777241056SMike Marciniszyn /* Port control flags */ 26877241056SMike Marciniszyn #define IB_CC_CCS_PC_SL_BASED 0x01 26977241056SMike Marciniszyn 27077241056SMike Marciniszyn struct opa_congestion_setting_entry { 27177241056SMike Marciniszyn u8 ccti_increase; 27277241056SMike Marciniszyn u8 reserved; 27377241056SMike Marciniszyn __be16 ccti_timer; 27477241056SMike Marciniszyn u8 trigger_threshold; 27577241056SMike Marciniszyn u8 ccti_min; /* min CCTI for cc table */ 27677241056SMike Marciniszyn } __packed; 27777241056SMike Marciniszyn 27877241056SMike Marciniszyn struct opa_congestion_setting_entry_shadow { 27977241056SMike Marciniszyn u8 ccti_increase; 28077241056SMike Marciniszyn u8 reserved; 28177241056SMike Marciniszyn u16 ccti_timer; 28277241056SMike Marciniszyn u8 trigger_threshold; 28377241056SMike Marciniszyn u8 ccti_min; /* min CCTI for cc table */ 28477241056SMike Marciniszyn } __packed; 28577241056SMike Marciniszyn 28677241056SMike Marciniszyn struct opa_congestion_setting_attr { 28777241056SMike Marciniszyn __be32 control_map; 28877241056SMike Marciniszyn __be16 port_control; 28977241056SMike Marciniszyn struct opa_congestion_setting_entry entries[OPA_MAX_SLS]; 29077241056SMike Marciniszyn } __packed; 29177241056SMike Marciniszyn 29277241056SMike Marciniszyn struct opa_congestion_setting_attr_shadow { 29377241056SMike Marciniszyn u32 control_map; 29477241056SMike Marciniszyn u16 port_control; 29577241056SMike Marciniszyn struct opa_congestion_setting_entry_shadow entries[OPA_MAX_SLS]; 29677241056SMike Marciniszyn } __packed; 29777241056SMike Marciniszyn 29877241056SMike Marciniszyn #define IB_CC_TABLE_ENTRY_INCREASE_DEFAULT 1 29977241056SMike Marciniszyn #define IB_CC_TABLE_ENTRY_TIMER_DEFAULT 1 30077241056SMike Marciniszyn 30177241056SMike Marciniszyn /* 64 Congestion Control table entries in a single MAD */ 30277241056SMike Marciniszyn #define IB_CCT_ENTRIES 64 30377241056SMike Marciniszyn #define IB_CCT_MIN_ENTRIES (IB_CCT_ENTRIES * 2) 30477241056SMike Marciniszyn 30577241056SMike Marciniszyn struct ib_cc_table_entry { 30677241056SMike Marciniszyn __be16 entry; /* shift:2, multiplier:14 */ 30777241056SMike Marciniszyn }; 30877241056SMike Marciniszyn 30977241056SMike Marciniszyn struct ib_cc_table_entry_shadow { 31077241056SMike Marciniszyn u16 entry; /* shift:2, multiplier:14 */ 31177241056SMike Marciniszyn }; 31277241056SMike Marciniszyn 31377241056SMike Marciniszyn struct ib_cc_table_attr { 31477241056SMike Marciniszyn __be16 ccti_limit; /* max CCTI for cc table */ 31577241056SMike Marciniszyn struct ib_cc_table_entry ccti_entries[IB_CCT_ENTRIES]; 31677241056SMike Marciniszyn } __packed; 31777241056SMike Marciniszyn 31877241056SMike Marciniszyn struct ib_cc_table_attr_shadow { 31977241056SMike Marciniszyn u16 ccti_limit; /* max CCTI for cc table */ 32077241056SMike Marciniszyn struct ib_cc_table_entry_shadow ccti_entries[IB_CCT_ENTRIES]; 32177241056SMike Marciniszyn } __packed; 32277241056SMike Marciniszyn 32377241056SMike Marciniszyn #define CC_TABLE_SHADOW_MAX \ 32477241056SMike Marciniszyn (IB_CC_TABLE_CAP_DEFAULT * IB_CCT_ENTRIES) 32577241056SMike Marciniszyn 32677241056SMike Marciniszyn struct cc_table_shadow { 32777241056SMike Marciniszyn u16 ccti_limit; /* max CCTI for cc table */ 32877241056SMike Marciniszyn struct ib_cc_table_entry_shadow entries[CC_TABLE_SHADOW_MAX]; 32977241056SMike Marciniszyn } __packed; 33077241056SMike Marciniszyn 33177241056SMike Marciniszyn /* 33277241056SMike Marciniszyn * struct cc_state combines the (active) per-port congestion control 33377241056SMike Marciniszyn * table, and the (active) per-SL congestion settings. cc_state data 33477241056SMike Marciniszyn * may need to be read in code paths that we want to be fast, so it 33577241056SMike Marciniszyn * is an RCU protected structure. 33677241056SMike Marciniszyn */ 33777241056SMike Marciniszyn struct cc_state { 33877241056SMike Marciniszyn struct rcu_head rcu; 33977241056SMike Marciniszyn struct cc_table_shadow cct; 34077241056SMike Marciniszyn struct opa_congestion_setting_attr_shadow cong_setting; 34177241056SMike Marciniszyn }; 34277241056SMike Marciniszyn 34377241056SMike Marciniszyn /* 34477241056SMike Marciniszyn * OPA BufferControl MAD 34577241056SMike Marciniszyn */ 34677241056SMike Marciniszyn 34777241056SMike Marciniszyn /* attribute modifier macros */ 34877241056SMike Marciniszyn #define OPA_AM_NPORT_SHIFT 24 34977241056SMike Marciniszyn #define OPA_AM_NPORT_MASK 0xff 35077241056SMike Marciniszyn #define OPA_AM_NPORT_SMASK (OPA_AM_NPORT_MASK << OPA_AM_NPORT_SHIFT) 35177241056SMike Marciniszyn #define OPA_AM_NPORT(am) (((am) >> OPA_AM_NPORT_SHIFT) & \ 35277241056SMike Marciniszyn OPA_AM_NPORT_MASK) 35377241056SMike Marciniszyn 35477241056SMike Marciniszyn #define OPA_AM_NBLK_SHIFT 24 35577241056SMike Marciniszyn #define OPA_AM_NBLK_MASK 0xff 35677241056SMike Marciniszyn #define OPA_AM_NBLK_SMASK (OPA_AM_NBLK_MASK << OPA_AM_NBLK_SHIFT) 35777241056SMike Marciniszyn #define OPA_AM_NBLK(am) (((am) >> OPA_AM_NBLK_SHIFT) & \ 35877241056SMike Marciniszyn OPA_AM_NBLK_MASK) 35977241056SMike Marciniszyn 36077241056SMike Marciniszyn #define OPA_AM_START_BLK_SHIFT 0 36177241056SMike Marciniszyn #define OPA_AM_START_BLK_MASK 0xff 36277241056SMike Marciniszyn #define OPA_AM_START_BLK_SMASK (OPA_AM_START_BLK_MASK << \ 36377241056SMike Marciniszyn OPA_AM_START_BLK_SHIFT) 36477241056SMike Marciniszyn #define OPA_AM_START_BLK(am) (((am) >> OPA_AM_START_BLK_SHIFT) & \ 36577241056SMike Marciniszyn OPA_AM_START_BLK_MASK) 36677241056SMike Marciniszyn 36777241056SMike Marciniszyn #define OPA_AM_PORTNUM_SHIFT 0 36877241056SMike Marciniszyn #define OPA_AM_PORTNUM_MASK 0xff 36977241056SMike Marciniszyn #define OPA_AM_PORTNUM_SMASK (OPA_AM_PORTNUM_MASK << OPA_AM_PORTNUM_SHIFT) 37077241056SMike Marciniszyn #define OPA_AM_PORTNUM(am) (((am) >> OPA_AM_PORTNUM_SHIFT) & \ 37177241056SMike Marciniszyn OPA_AM_PORTNUM_MASK) 37277241056SMike Marciniszyn 37377241056SMike Marciniszyn #define OPA_AM_ASYNC_SHIFT 12 37477241056SMike Marciniszyn #define OPA_AM_ASYNC_MASK 0x1 37577241056SMike Marciniszyn #define OPA_AM_ASYNC_SMASK (OPA_AM_ASYNC_MASK << OPA_AM_ASYNC_SHIFT) 37677241056SMike Marciniszyn #define OPA_AM_ASYNC(am) (((am) >> OPA_AM_ASYNC_SHIFT) & \ 37777241056SMike Marciniszyn OPA_AM_ASYNC_MASK) 37877241056SMike Marciniszyn 37977241056SMike Marciniszyn #define OPA_AM_START_SM_CFG_SHIFT 9 38077241056SMike Marciniszyn #define OPA_AM_START_SM_CFG_MASK 0x1 38177241056SMike Marciniszyn #define OPA_AM_START_SM_CFG_SMASK (OPA_AM_START_SM_CFG_MASK << \ 38277241056SMike Marciniszyn OPA_AM_START_SM_CFG_SHIFT) 38377241056SMike Marciniszyn #define OPA_AM_START_SM_CFG(am) (((am) >> OPA_AM_START_SM_CFG_SHIFT) \ 38477241056SMike Marciniszyn & OPA_AM_START_SM_CFG_MASK) 38577241056SMike Marciniszyn 38677241056SMike Marciniszyn #define OPA_AM_CI_ADDR_SHIFT 19 38777241056SMike Marciniszyn #define OPA_AM_CI_ADDR_MASK 0xfff 38877241056SMike Marciniszyn #define OPA_AM_CI_ADDR_SMASK (OPA_AM_CI_ADDR_MASK << OPA_CI_ADDR_SHIFT) 38977241056SMike Marciniszyn #define OPA_AM_CI_ADDR(am) (((am) >> OPA_AM_CI_ADDR_SHIFT) & \ 39077241056SMike Marciniszyn OPA_AM_CI_ADDR_MASK) 39177241056SMike Marciniszyn 39277241056SMike Marciniszyn #define OPA_AM_CI_LEN_SHIFT 13 39377241056SMike Marciniszyn #define OPA_AM_CI_LEN_MASK 0x3f 39477241056SMike Marciniszyn #define OPA_AM_CI_LEN_SMASK (OPA_AM_CI_LEN_MASK << OPA_CI_LEN_SHIFT) 39577241056SMike Marciniszyn #define OPA_AM_CI_LEN(am) (((am) >> OPA_AM_CI_LEN_SHIFT) & \ 39677241056SMike Marciniszyn OPA_AM_CI_LEN_MASK) 39777241056SMike Marciniszyn 39877241056SMike Marciniszyn /* error info macros */ 39977241056SMike Marciniszyn #define OPA_EI_STATUS_SMASK 0x80 40077241056SMike Marciniszyn #define OPA_EI_CODE_SMASK 0x0f 40177241056SMike Marciniszyn 40277241056SMike Marciniszyn struct vl_limit { 40377241056SMike Marciniszyn __be16 dedicated; 40477241056SMike Marciniszyn __be16 shared; 40577241056SMike Marciniszyn }; 40677241056SMike Marciniszyn 40777241056SMike Marciniszyn struct buffer_control { 40877241056SMike Marciniszyn __be16 reserved; 40977241056SMike Marciniszyn __be16 overall_shared_limit; 41077241056SMike Marciniszyn struct vl_limit vl[OPA_MAX_VLS]; 41177241056SMike Marciniszyn }; 41277241056SMike Marciniszyn 41377241056SMike Marciniszyn struct sc2vlnt { 41477241056SMike Marciniszyn u8 vlnt[32]; /* 5 bit VL, 3 bits reserved */ 41577241056SMike Marciniszyn }; 41677241056SMike Marciniszyn 41777241056SMike Marciniszyn /* 41877241056SMike Marciniszyn * The PortSamplesControl.CounterMasks field is an array of 3 bit fields 41977241056SMike Marciniszyn * which specify the N'th counter's capabilities. See ch. 16.1.3.2. 42077241056SMike Marciniszyn * We support 5 counters which only count the mandatory quantities. 42177241056SMike Marciniszyn */ 42277241056SMike Marciniszyn #define COUNTER_MASK(q, n) (q << ((9 - n) * 3)) 42377241056SMike Marciniszyn #define COUNTER_MASK0_9 \ 42477241056SMike Marciniszyn cpu_to_be32(COUNTER_MASK(1, 0) | \ 42577241056SMike Marciniszyn COUNTER_MASK(1, 1) | \ 42677241056SMike Marciniszyn COUNTER_MASK(1, 2) | \ 42777241056SMike Marciniszyn COUNTER_MASK(1, 3) | \ 42877241056SMike Marciniszyn COUNTER_MASK(1, 4)) 42977241056SMike Marciniszyn 43034d351f8SSebastian Sanchez void hfi1_event_pkey_change(struct hfi1_devdata *dd, u8 port); 431*8064135eSKees Cook void hfi1_handle_trap_timer(struct timer_list *t); 43234d351f8SSebastian Sanchez 43377241056SMike Marciniszyn #endif /* _HFI1_MAD_H */ 434