162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */ 262306a36Sopenharmony_ci/* Copyright 2014 Cisco Systems, Inc. All rights reserved. */ 362306a36Sopenharmony_ci 462306a36Sopenharmony_ci#ifndef _VNIC_RESOURCE_H_ 562306a36Sopenharmony_ci#define _VNIC_RESOURCE_H_ 662306a36Sopenharmony_ci 762306a36Sopenharmony_ci#define VNIC_RES_MAGIC 0x766E6963L /* 'vnic' */ 862306a36Sopenharmony_ci#define VNIC_RES_VERSION 0x00000000L 962306a36Sopenharmony_ci 1062306a36Sopenharmony_ci/* vNIC resource types */ 1162306a36Sopenharmony_cienum vnic_res_type { 1262306a36Sopenharmony_ci RES_TYPE_EOL, /* End-of-list */ 1362306a36Sopenharmony_ci RES_TYPE_WQ, /* Work queues */ 1462306a36Sopenharmony_ci RES_TYPE_RQ, /* Receive queues */ 1562306a36Sopenharmony_ci RES_TYPE_CQ, /* Completion queues */ 1662306a36Sopenharmony_ci RES_TYPE_RSVD1, 1762306a36Sopenharmony_ci RES_TYPE_NIC_CFG, /* Enet NIC config registers */ 1862306a36Sopenharmony_ci RES_TYPE_RSVD2, 1962306a36Sopenharmony_ci RES_TYPE_RSVD3, 2062306a36Sopenharmony_ci RES_TYPE_RSVD4, 2162306a36Sopenharmony_ci RES_TYPE_RSVD5, 2262306a36Sopenharmony_ci RES_TYPE_INTR_CTRL, /* Interrupt ctrl table */ 2362306a36Sopenharmony_ci RES_TYPE_INTR_TABLE, /* MSI/MSI-X Interrupt table */ 2462306a36Sopenharmony_ci RES_TYPE_INTR_PBA, /* MSI/MSI-X PBA table */ 2562306a36Sopenharmony_ci RES_TYPE_INTR_PBA_LEGACY, /* Legacy intr status */ 2662306a36Sopenharmony_ci RES_TYPE_RSVD6, 2762306a36Sopenharmony_ci RES_TYPE_RSVD7, 2862306a36Sopenharmony_ci RES_TYPE_DEVCMD, /* Device command region */ 2962306a36Sopenharmony_ci RES_TYPE_PASS_THRU_PAGE, /* Pass-thru page */ 3062306a36Sopenharmony_ci RES_TYPE_SUBVNIC, /* subvnic resource type */ 3162306a36Sopenharmony_ci RES_TYPE_MQ_WQ, /* MQ Work queues */ 3262306a36Sopenharmony_ci RES_TYPE_MQ_RQ, /* MQ Receive queues */ 3362306a36Sopenharmony_ci RES_TYPE_MQ_CQ, /* MQ Completion queues */ 3462306a36Sopenharmony_ci RES_TYPE_DEPRECATED1, /* Old version of devcmd 2 */ 3562306a36Sopenharmony_ci RES_TYPE_DEPRECATED2, /* Old version of devcmd 2 */ 3662306a36Sopenharmony_ci RES_TYPE_DEVCMD2, /* Device control region */ 3762306a36Sopenharmony_ci 3862306a36Sopenharmony_ci RES_TYPE_MAX, /* Count of resource types */ 3962306a36Sopenharmony_ci}; 4062306a36Sopenharmony_ci 4162306a36Sopenharmony_cistruct vnic_resource_header { 4262306a36Sopenharmony_ci u32 magic; 4362306a36Sopenharmony_ci u32 version; 4462306a36Sopenharmony_ci}; 4562306a36Sopenharmony_ci 4662306a36Sopenharmony_cistruct vnic_resource { 4762306a36Sopenharmony_ci u8 type; 4862306a36Sopenharmony_ci u8 bar; 4962306a36Sopenharmony_ci u8 pad[2]; 5062306a36Sopenharmony_ci u32 bar_offset; 5162306a36Sopenharmony_ci u32 count; 5262306a36Sopenharmony_ci}; 5362306a36Sopenharmony_ci 5462306a36Sopenharmony_ci#endif /* _VNIC_RESOURCE_H_ */ 55