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