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