diff options
author | Or Gerlitz <ogerlitz@mellanox.com> | 2011-06-15 10:41:42 -0400 |
---|---|---|
committer | Roland Dreier <roland@purestorage.com> | 2011-07-19 00:04:32 -0400 |
commit | 52eafc68d601afd699b023201b0c6be5209f39ce (patch) | |
tree | 01a65357f2f39b07836c44f8b2cd490e5cd62853 /drivers/net/mlx4 | |
parent | 6451c712fef3b13bb3fc5a41adadc539e0d06a42 (diff) |
mlx4_core: Extend capability flags to 64 bits
The latest firmware adds a second dword containing more device flags,
so extend the device capabilities flags field from 32 to 64 bits.
Derived from patch by Eli Cohen <eli@mellanox.co.il>
Signed-off-by: Or Gerlitz <ogerlitz@mellanox.co.il>
Signed-off-by: Roland Dreier <roland@purestorage.com>
Diffstat (limited to 'drivers/net/mlx4')
-rw-r--r-- | drivers/net/mlx4/fw.c | 9 | ||||
-rw-r--r-- | drivers/net/mlx4/fw.h | 2 |
2 files changed, 6 insertions, 5 deletions
diff --git a/drivers/net/mlx4/fw.c b/drivers/net/mlx4/fw.c index 67a209ba939..346d8b3d03d 100644 --- a/drivers/net/mlx4/fw.c +++ b/drivers/net/mlx4/fw.c | |||
@@ -75,7 +75,7 @@ MODULE_PARM_DESC(enable_qos, "Enable Quality of Service support in the HCA (defa | |||
75 | } \ | 75 | } \ |
76 | } while (0) | 76 | } while (0) |
77 | 77 | ||
78 | static void dump_dev_cap_flags(struct mlx4_dev *dev, u32 flags) | 78 | static void dump_dev_cap_flags(struct mlx4_dev *dev, u64 flags) |
79 | { | 79 | { |
80 | static const char *fname[] = { | 80 | static const char *fname[] = { |
81 | [ 0] = "RC transport", | 81 | [ 0] = "RC transport", |
@@ -105,7 +105,7 @@ static void dump_dev_cap_flags(struct mlx4_dev *dev, u32 flags) | |||
105 | 105 | ||
106 | mlx4_dbg(dev, "DEV_CAP flags:\n"); | 106 | mlx4_dbg(dev, "DEV_CAP flags:\n"); |
107 | for (i = 0; i < ARRAY_SIZE(fname); ++i) | 107 | for (i = 0; i < ARRAY_SIZE(fname); ++i) |
108 | if (fname[i] && (flags & (1 << i))) | 108 | if (fname[i] && (flags & (1LL << i))) |
109 | mlx4_dbg(dev, " %s\n", fname[i]); | 109 | mlx4_dbg(dev, " %s\n", fname[i]); |
110 | } | 110 | } |
111 | 111 | ||
@@ -142,7 +142,7 @@ int mlx4_QUERY_DEV_CAP(struct mlx4_dev *dev, struct mlx4_dev_cap *dev_cap) | |||
142 | struct mlx4_cmd_mailbox *mailbox; | 142 | struct mlx4_cmd_mailbox *mailbox; |
143 | u32 *outbox; | 143 | u32 *outbox; |
144 | u8 field; | 144 | u8 field; |
145 | u32 field32; | 145 | u32 field32, flags; |
146 | u16 size; | 146 | u16 size; |
147 | u16 stat_rate; | 147 | u16 stat_rate; |
148 | int err; | 148 | int err; |
@@ -279,7 +279,8 @@ int mlx4_QUERY_DEV_CAP(struct mlx4_dev *dev, struct mlx4_dev_cap *dev_cap) | |||
279 | MLX4_GET(field, outbox, QUERY_DEV_CAP_ETH_UC_LOOPBACK_OFFSET); | 279 | MLX4_GET(field, outbox, QUERY_DEV_CAP_ETH_UC_LOOPBACK_OFFSET); |
280 | dev_cap->loopback_support = field & 0x1; | 280 | dev_cap->loopback_support = field & 0x1; |
281 | dev_cap->wol = field & 0x40; | 281 | dev_cap->wol = field & 0x40; |
282 | MLX4_GET(dev_cap->flags, outbox, QUERY_DEV_CAP_FLAGS_OFFSET); | 282 | MLX4_GET(flags, outbox, QUERY_DEV_CAP_FLAGS_OFFSET); |
283 | dev_cap->flags = flags; | ||
283 | MLX4_GET(field, outbox, QUERY_DEV_CAP_RSVD_UAR_OFFSET); | 284 | MLX4_GET(field, outbox, QUERY_DEV_CAP_RSVD_UAR_OFFSET); |
284 | dev_cap->reserved_uars = field >> 4; | 285 | dev_cap->reserved_uars = field >> 4; |
285 | MLX4_GET(field, outbox, QUERY_DEV_CAP_UAR_SZ_OFFSET); | 286 | MLX4_GET(field, outbox, QUERY_DEV_CAP_UAR_SZ_OFFSET); |
diff --git a/drivers/net/mlx4/fw.h b/drivers/net/mlx4/fw.h index 88003ebc618..2a8d11008c5 100644 --- a/drivers/net/mlx4/fw.h +++ b/drivers/net/mlx4/fw.h | |||
@@ -83,7 +83,7 @@ struct mlx4_dev_cap { | |||
83 | int vep_uc_steering; | 83 | int vep_uc_steering; |
84 | int vep_mc_steering; | 84 | int vep_mc_steering; |
85 | int wol; | 85 | int wol; |
86 | u32 flags; | 86 | u64 flags; |
87 | int reserved_uars; | 87 | int reserved_uars; |
88 | int uar_size; | 88 | int uar_size; |
89 | int min_page_sz; | 89 | int min_page_sz; |