[MTHCA] [VSTAT] feature: added uplink info
[mirror/winof/.git] / inc / mthca / mthca_vc.h
1 /*
2  * Copyright (c) 2005 SilverStorm Technologies.  All rights reserved.
3  * Copyright (c) 2004-2005 Mellanox Technologies, Inc. All rights reserved. 
4  *
5  * This software is available to you under the OpenIB.org BSD license
6  * below:
7  *
8  *     Redistribution and use in source and binary forms, with or
9  *     without modification, are permitted provided that the following
10  *     conditions are met:
11  *
12  *      - Redistributions of source code must retain the above
13  *        copyright notice, this list of conditions and the following
14  *        disclaimer.
15  *
16  *      - Redistributions in binary form must reproduce the above
17  *        copyright notice, this list of conditions and the following
18  *        disclaimer in the documentation and/or other materials
19  *        provided with the distribution.
20  *
21  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
22  * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
23  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
24  * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
25  * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
26  * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
27  * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
28  * SOFTWARE.
29  *
30  * $Id: mthca_vc.c 148 2005-07-12 07:48:46Z sleybo $
31  */
32
33 #ifndef MTHCA_VC_H
34 #define MTHCA_VC_H
35
36 typedef
37 struct _map_crspace {
38         unsigned __int64        va;             /* address of CRSPACE, mapped to user space */
39         unsigned long           size;   /* size of CRSPACE, mapped to user space */
40         unsigned long           reserved;       /* to align on quadword boundary */
41 } map_crspace;
42
43 /* Definitions for hca_driver commands*/
44 #define FW_READ                 0x00
45 #define FW_WRITE                0x01
46 #define FW_READ_CMD             0x08
47 #define FW_WRITE_CMD            0x09
48 #define FW_MAP_CRSPACE          0x0A
49 #define FW_UNMAP_CRSPACE        0x0B
50 #define FW_REREGISTER_HCA       0x0c
51 #define FW_OPEN_IF              0xe7
52 #define FW_CLOSE_IF             0x7e
53
54 /* uplink info */
55 typedef struct {
56         uint8_t bus_type;       /* 1 - PCI, 2 - PCI-X, 3 - PCI_E */
57 #define UPLINK_BUS_PCI          1       
58 #define UPLINK_BUS_PCIX         2       
59 #define UPLINK_BUS_PCIE         3       
60         union {
61                 struct {
62                         uint8_t capabilities;
63 #define UPLINK_BUS_PCIX_133     2       /* 133 MHz capable */
64                         uint16_t        frequency;      /* in MHz */
65                 } pci_x;
66                 struct {
67                         uint8_t reserve;
68                         uint8_t link_speed;             /* 1X link speed */
69 #define UPLINK_BUS_PCIE_SDR     1       /* 2.5 Gbps */
70                         uint8_t link_width;             /* x1, x2, x4, x8, x12, x16, x32 */
71                 } pci_e;
72         } u;
73 } uplink_info_t;
74
75 /* Defines for get data for vendor specific */
76 #define MTHCA_BRD_ID_LEN  64
77
78 inline char* mthca_get_board_id(ib_ca_attr_t *ca_attr)
79 {
80     return (char*)(ca_attr)+(ca_attr->size - MTHCA_BRD_ID_LEN - sizeof(uplink_info_t));
81 }
82
83 inline void* mthca_get_uplink_info(ib_ca_attr_t *ca_attr)
84 {
85     return (char*)(ca_attr)+(ca_attr->size - sizeof(uplink_info_t));
86 }
87
88 #endif