73f4dc749ed3ee87512787f97f34fa80bb6786cb
[mirror/winof/.git] / hw / mlx4 / kernel / inc / 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.h 1912 2007-01-17 11:08:02Z leonid $
31  */
32
33 #pragma once
34
35 #include <iba/ib_types.h>
36
37 typedef
38 struct _map_crspace {
39         unsigned __int64        va;             /* address of CRSPACE, mapped to user space */
40         unsigned long           size;   /* size of CRSPACE, mapped to user space */
41         unsigned long           reserved;       /* to align on quadword boundary */
42 } map_crspace;
43
44 /* Definitions for hca_driver commands*/
45 #define FW_READ                 0x00
46 #define FW_WRITE                0x01
47 #define FW_READ_CMD             0x08
48 #define FW_WRITE_CMD            0x09
49 #define FW_MAP_CRSPACE          0x0A
50 #define FW_UNMAP_CRSPACE        0x0B
51 #define FW_OPEN_IF              0xe7
52 #define FW_CLOSE_IF             0x7e
53
54 #if WORKAROUND_POLL_EQ
55 #define FW_POLL_EQ_START                0x0D
56 #define FW_POLL_EQ_STOP                 0x0E
57 #endif
58
59 /* uplink info */
60 typedef struct {
61         uint8_t bus_type;       /* 1 - PCI, 2 - PCI-X, 3 - PCI_E */
62 #define UPLINK_BUS_PCI          1       
63 #define UPLINK_BUS_PCIX         2       
64 #define UPLINK_BUS_PCIE         3       
65         union {
66                 struct {
67                         uint8_t capabilities;
68 #define UPLINK_BUS_PCIX_133     2       /* 133 MHz capable */
69                         uint16_t        frequency;      /* in MHz */
70                 } pci_x;
71                 struct {
72                         uint8_t capabilities;
73                         uint8_t link_speed;             /* 1X link speed */
74 #define UPLINK_BUS_PCIE_SDR     1       /* 2.5 Gbps */
75 #define UPLINK_BUS_PCIE_DDR     2       /* 5 Gbps */
76                         uint8_t link_width;             /* x1, x2, x4, x8, x12, x16, x32 */
77                 } pci_e;
78         } u;
79 } uplink_info_t;
80
81