Loading...
1/* SPDX-License-Identifier: GPL-2.0-only */
2/*
3 * Copyright 2008-2010 Cisco Systems, Inc. All rights reserved.
4 * Copyright 2007 Nuova Systems, Inc. All rights reserved.
5 */
6
7#ifndef _VNIC_RESOURCE_H_
8#define _VNIC_RESOURCE_H_
9
10#define VNIC_RES_MAGIC 0x766E6963L /* 'vnic' */
11#define VNIC_RES_VERSION 0x00000000L
12#define MGMTVNIC_MAGIC 0x544d474dL /* 'MGMT' */
13#define MGMTVNIC_VERSION 0x00000000L
14
15/* The MAC address assigned to the CFG vNIC is fixed. */
16#define MGMTVNIC_MAC { 0x02, 0x00, 0x54, 0x4d, 0x47, 0x4d }
17
18/* vNIC resource types */
19enum vnic_res_type {
20 RES_TYPE_EOL, /* End-of-list */
21 RES_TYPE_WQ, /* Work queues */
22 RES_TYPE_RQ, /* Receive queues */
23 RES_TYPE_CQ, /* Completion queues */
24 RES_TYPE_RSVD1,
25 RES_TYPE_NIC_CFG, /* Enet NIC config registers */
26 RES_TYPE_RSVD2,
27 RES_TYPE_RSVD3,
28 RES_TYPE_RSVD4,
29 RES_TYPE_RSVD5,
30 RES_TYPE_INTR_CTRL, /* Interrupt ctrl table */
31 RES_TYPE_INTR_TABLE, /* MSI/MSI-X Interrupt table */
32 RES_TYPE_INTR_PBA, /* MSI/MSI-X PBA table */
33 RES_TYPE_INTR_PBA_LEGACY, /* Legacy intr status */
34 RES_TYPE_RSVD6,
35 RES_TYPE_RSVD7,
36 RES_TYPE_DEVCMD, /* Device command region */
37 RES_TYPE_PASS_THRU_PAGE, /* Pass-thru page */
38 RES_TYPE_SUBVNIC, /* subvnic resource type */
39 RES_TYPE_MQ_WQ, /* MQ Work queues */
40 RES_TYPE_MQ_RQ, /* MQ Receive queues */
41 RES_TYPE_MQ_CQ, /* MQ Completion queues */
42 RES_TYPE_DEPRECATED1, /* Old version of devcmd 2 */
43 RES_TYPE_DEPRECATED2, /* Old version of devcmd 2 */
44 RES_TYPE_DEVCMD2, /* Device control region */
45
46 RES_TYPE_MAX, /* Count of resource types */
47};
48
49struct vnic_resource_header {
50 u32 magic;
51 u32 version;
52};
53
54struct mgmt_barmap_hdr {
55 u32 magic; /* magic number */
56 u32 version; /* header format version */
57 u16 lif; /* loopback lif for mgmt frames */
58 u16 pci_slot; /* installed pci slot */
59 char serial[16]; /* card serial number */
60};
61
62struct vnic_resource {
63 u8 type;
64 u8 bar;
65 u8 pad[2];
66 u32 bar_offset;
67 u32 count;
68};
69
70#endif /* _VNIC_RESOURCE_H_ */
1/*
2 * Copyright 2008-2010 Cisco Systems, Inc. All rights reserved.
3 * Copyright 2007 Nuova Systems, Inc. All rights reserved.
4 *
5 * This program is free software; you may redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; version 2 of the License.
8 *
9 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
10 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
11 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
12 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
13 * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
14 * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
15 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
16 * SOFTWARE.
17 *
18 */
19
20#ifndef _VNIC_RESOURCE_H_
21#define _VNIC_RESOURCE_H_
22
23#define VNIC_RES_MAGIC 0x766E6963L /* 'vnic' */
24#define VNIC_RES_VERSION 0x00000000L
25#define MGMTVNIC_MAGIC 0x544d474dL /* 'MGMT' */
26#define MGMTVNIC_VERSION 0x00000000L
27
28/* The MAC address assigned to the CFG vNIC is fixed. */
29#define MGMTVNIC_MAC { 0x02, 0x00, 0x54, 0x4d, 0x47, 0x4d }
30
31/* vNIC resource types */
32enum vnic_res_type {
33 RES_TYPE_EOL, /* End-of-list */
34 RES_TYPE_WQ, /* Work queues */
35 RES_TYPE_RQ, /* Receive queues */
36 RES_TYPE_CQ, /* Completion queues */
37 RES_TYPE_RSVD1,
38 RES_TYPE_NIC_CFG, /* Enet NIC config registers */
39 RES_TYPE_RSVD2,
40 RES_TYPE_RSVD3,
41 RES_TYPE_RSVD4,
42 RES_TYPE_RSVD5,
43 RES_TYPE_INTR_CTRL, /* Interrupt ctrl table */
44 RES_TYPE_INTR_TABLE, /* MSI/MSI-X Interrupt table */
45 RES_TYPE_INTR_PBA, /* MSI/MSI-X PBA table */
46 RES_TYPE_INTR_PBA_LEGACY, /* Legacy intr status */
47 RES_TYPE_RSVD6,
48 RES_TYPE_RSVD7,
49 RES_TYPE_DEVCMD, /* Device command region */
50 RES_TYPE_PASS_THRU_PAGE, /* Pass-thru page */
51 RES_TYPE_SUBVNIC, /* subvnic resource type */
52 RES_TYPE_MQ_WQ, /* MQ Work queues */
53 RES_TYPE_MQ_RQ, /* MQ Receive queues */
54 RES_TYPE_MQ_CQ, /* MQ Completion queues */
55 RES_TYPE_DEPRECATED1, /* Old version of devcmd 2 */
56 RES_TYPE_DEPRECATED2, /* Old version of devcmd 2 */
57 RES_TYPE_DEVCMD2, /* Device control region */
58
59 RES_TYPE_MAX, /* Count of resource types */
60};
61
62struct vnic_resource_header {
63 u32 magic;
64 u32 version;
65};
66
67struct mgmt_barmap_hdr {
68 u32 magic; /* magic number */
69 u32 version; /* header format version */
70 u16 lif; /* loopback lif for mgmt frames */
71 u16 pci_slot; /* installed pci slot */
72 char serial[16]; /* card serial number */
73};
74
75struct vnic_resource {
76 u8 type;
77 u8 bar;
78 u8 pad[2];
79 u32 bar_offset;
80 u32 count;
81};
82
83#endif /* _VNIC_RESOURCE_H_ */