diff options
author | Yevgeny Petrilin <yevgenyp@mellanox.co.il> | 2011-03-22 18:37:47 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2011-03-23 15:24:18 -0400 |
commit | 0b7ca5a928e2271bbc225e9e1ac1f22e9fbee54f (patch) | |
tree | 8a24efdb4ceb6f28a8d49e942f80d397c06f4a5f /include/linux/mlx4 | |
parent | 908222655b38005483d64385e06341a38647fdf1 (diff) |
mlx4: Changing interrupt scheme
Adding a pool of MSI-X vectors and EQs that can be used explicitly by mlx4_core
customers (mlx4_ib, mlx4_en). The consumers will assign their own names to the
interrupt vectors. Those vectors are not opened at mlx4 device initialization,
opened by demand.
Changed the max number of possible EQs according to the new scheme, no longer relies on
on number of cores.
The new functionality is exposed through mlx4_assign_eq() and mlx4_release_eq().
Customers that do not use the new API will get completion vectors as before.
Signed-off-by: Markuze Alex <markuze@mellanox.co.il>
Signed-off-by: Yevgeny Petrilin <yevgenyp@mellanox.co.il>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include/linux/mlx4')
-rw-r--r-- | include/linux/mlx4/device.h | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/include/linux/mlx4/device.h b/include/linux/mlx4/device.h index 049214642036..78380823d827 100644 --- a/include/linux/mlx4/device.h +++ b/include/linux/mlx4/device.h | |||
@@ -39,6 +39,11 @@ | |||
39 | 39 | ||
40 | #include <asm/atomic.h> | 40 | #include <asm/atomic.h> |
41 | 41 | ||
42 | #define MAX_MSIX_P_PORT 17 | ||
43 | #define MAX_MSIX 64 | ||
44 | #define MSIX_LEGACY_SZ 4 | ||
45 | #define MIN_MSIX_P_PORT 5 | ||
46 | |||
42 | enum { | 47 | enum { |
43 | MLX4_FLAG_MSI_X = 1 << 0, | 48 | MLX4_FLAG_MSI_X = 1 << 0, |
44 | MLX4_FLAG_OLD_PORT_CMDS = 1 << 1, | 49 | MLX4_FLAG_OLD_PORT_CMDS = 1 << 1, |
@@ -223,6 +228,7 @@ struct mlx4_caps { | |||
223 | int num_eqs; | 228 | int num_eqs; |
224 | int reserved_eqs; | 229 | int reserved_eqs; |
225 | int num_comp_vectors; | 230 | int num_comp_vectors; |
231 | int comp_pool; | ||
226 | int num_mpts; | 232 | int num_mpts; |
227 | int num_mtt_segs; | 233 | int num_mtt_segs; |
228 | int mtts_per_seg; | 234 | int mtts_per_seg; |
@@ -526,5 +532,7 @@ void mlx4_fmr_unmap(struct mlx4_dev *dev, struct mlx4_fmr *fmr, | |||
526 | int mlx4_fmr_free(struct mlx4_dev *dev, struct mlx4_fmr *fmr); | 532 | int mlx4_fmr_free(struct mlx4_dev *dev, struct mlx4_fmr *fmr); |
527 | int mlx4_SYNC_TPT(struct mlx4_dev *dev); | 533 | int mlx4_SYNC_TPT(struct mlx4_dev *dev); |
528 | int mlx4_test_interrupts(struct mlx4_dev *dev); | 534 | int mlx4_test_interrupts(struct mlx4_dev *dev); |
535 | int mlx4_assign_eq(struct mlx4_dev *dev, char* name , int* vector); | ||
536 | void mlx4_release_eq(struct mlx4_dev *dev, int vec); | ||
529 | 537 | ||
530 | #endif /* MLX4_DEVICE_H */ | 538 | #endif /* MLX4_DEVICE_H */ |