| 
									
										
										
										
											2008-09-15 09:17:11 -07:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2010-06-24 10:52:26 +00:00
										 |  |  |  * Copyright 2008-2010 Cisco Systems, Inc.  All rights reserved. | 
					
						
							| 
									
										
										
										
											2008-09-15 09:17:11 -07:00
										 |  |  |  * Copyright 2007 Nuova Systems, Inc.  All rights reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software; you may redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU General Public License as published by | 
					
						
							|  |  |  |  * the Free Software Foundation; version 2 of the License. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | 
					
						
							|  |  |  |  * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | 
					
						
							|  |  |  |  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND | 
					
						
							|  |  |  |  * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS | 
					
						
							|  |  |  |  * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN | 
					
						
							|  |  |  |  * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN | 
					
						
							|  |  |  |  * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | 
					
						
							|  |  |  |  * SOFTWARE. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef _VNIC_RESOURCE_H_
 | 
					
						
							|  |  |  | #define _VNIC_RESOURCE_H_
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define VNIC_RES_MAGIC		0x766E6963L	/* 'vnic' */
 | 
					
						
							|  |  |  | #define VNIC_RES_VERSION	0x00000000L
 | 
					
						
							| 
									
										
										
										
											2010-08-10 18:55:00 +00:00
										 |  |  | #define MGMTVNIC_MAGIC		0x544d474dL	/* 'MGMT' */
 | 
					
						
							|  |  |  | #define MGMTVNIC_VERSION	0x00000000L
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* The MAC address assigned to the CFG vNIC is fixed. */ | 
					
						
							|  |  |  | #define MGMTVNIC_MAC		{ 0x02, 0x00, 0x54, 0x4d, 0x47, 0x4d }
 | 
					
						
							| 
									
										
										
										
											2008-09-15 09:17:11 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* vNIC resource types */ | 
					
						
							|  |  |  | enum vnic_res_type { | 
					
						
							|  |  |  | 	RES_TYPE_EOL,			/* End-of-list */ | 
					
						
							|  |  |  | 	RES_TYPE_WQ,			/* Work queues */ | 
					
						
							|  |  |  | 	RES_TYPE_RQ,			/* Receive queues */ | 
					
						
							|  |  |  | 	RES_TYPE_CQ,			/* Completion queues */ | 
					
						
							|  |  |  | 	RES_TYPE_RSVD1, | 
					
						
							|  |  |  | 	RES_TYPE_NIC_CFG,		/* Enet NIC config registers */ | 
					
						
							|  |  |  | 	RES_TYPE_RSVD2, | 
					
						
							|  |  |  | 	RES_TYPE_RSVD3, | 
					
						
							|  |  |  | 	RES_TYPE_RSVD4, | 
					
						
							|  |  |  | 	RES_TYPE_RSVD5, | 
					
						
							|  |  |  | 	RES_TYPE_INTR_CTRL,		/* Interrupt ctrl table */ | 
					
						
							|  |  |  | 	RES_TYPE_INTR_TABLE,		/* MSI/MSI-X Interrupt table */ | 
					
						
							|  |  |  | 	RES_TYPE_INTR_PBA,		/* MSI/MSI-X PBA table */ | 
					
						
							| 
									
										
										
										
											2008-11-21 21:29:25 -08:00
										 |  |  | 	RES_TYPE_INTR_PBA_LEGACY,	/* Legacy intr status */ | 
					
						
							| 
									
										
										
										
											2008-09-15 09:17:11 -07:00
										 |  |  | 	RES_TYPE_RSVD6, | 
					
						
							|  |  |  | 	RES_TYPE_RSVD7, | 
					
						
							|  |  |  | 	RES_TYPE_DEVCMD,		/* Device command region */ | 
					
						
							|  |  |  | 	RES_TYPE_PASS_THRU_PAGE,	/* Pass-thru page */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	RES_TYPE_MAX,			/* Count of resource types */ | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct vnic_resource_header { | 
					
						
							|  |  |  | 	u32 magic; | 
					
						
							|  |  |  | 	u32 version; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-10 18:55:00 +00:00
										 |  |  | struct mgmt_barmap_hdr { | 
					
						
							|  |  |  | 	u32 magic;			/* magic number */ | 
					
						
							|  |  |  | 	u32 version;			/* header format version */ | 
					
						
							|  |  |  | 	u16 lif;			/* loopback lif for mgmt frames */ | 
					
						
							|  |  |  | 	u16 pci_slot;			/* installed pci slot */ | 
					
						
							|  |  |  | 	char serial[16];		/* card serial number */ | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-15 09:17:11 -07:00
										 |  |  | struct vnic_resource { | 
					
						
							|  |  |  | 	u8 type; | 
					
						
							|  |  |  | 	u8 bar; | 
					
						
							|  |  |  | 	u8 pad[2]; | 
					
						
							|  |  |  | 	u32 bar_offset; | 
					
						
							|  |  |  | 	u32 count; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* _VNIC_RESOURCE_H_ */
 |