~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/include/linux/mlx5/eq.h

Version: ~ [ linux-6.11.5 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.58 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.114 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.169 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.228 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.284 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.322 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /include/linux/mlx5/eq.h (Version linux-6.11.5) and /include/linux/mlx5/eq.h (Version linux-4.12.14)


  1 /* SPDX-License-Identifier: GPL-2.0 OR Linux-O      1 
  2 /* Copyright (c) 2018 Mellanox Technologies. *    
  3                                                   
  4 #ifndef MLX5_CORE_EQ_H                            
  5 #define MLX5_CORE_EQ_H                            
  6                                                   
  7 #define MLX5_NUM_CMD_EQE   (32)                   
  8 #define MLX5_NUM_ASYNC_EQE (0x1000)               
  9 #define MLX5_NUM_SPARE_EQE (0x80)                 
 10                                                   
 11 struct mlx5_eq;                                   
 12 struct mlx5_irq;                                  
 13 struct mlx5_core_dev;                             
 14                                                   
 15 struct mlx5_eq_param {                            
 16         int            nent;                      
 17         u64            mask[4];                   
 18         struct mlx5_irq *irq;                     
 19 };                                                
 20                                                   
 21 struct mlx5_eq *                                  
 22 mlx5_eq_create_generic(struct mlx5_core_dev *d    
 23 int                                               
 24 mlx5_eq_destroy_generic(struct mlx5_core_dev *    
 25 int mlx5_eq_enable(struct mlx5_core_dev *dev,     
 26                    struct notifier_block *nb);    
 27 void mlx5_eq_disable(struct mlx5_core_dev *dev    
 28                      struct notifier_block *nb    
 29                                                   
 30 struct mlx5_eqe *mlx5_eq_get_eqe(struct mlx5_e    
 31 void mlx5_eq_update_ci(struct mlx5_eq *eq, u32    
 32                                                   
 33 /* The HCA will think the queue has overflowed    
 34  * don't tell it we've been processing events.    
 35  * create EQs with MLX5_NUM_SPARE_EQE extra en    
 36  * so we must update our consumer index at        
 37  * least that often.                              
 38  *                                                
 39  * mlx5_eq_update_cc must be called on every E    
 40  */                                               
 41 static inline u32 mlx5_eq_update_cc(struct mlx    
 42 {                                                 
 43         if (unlikely(cc >= MLX5_NUM_SPARE_EQE)    
 44                 mlx5_eq_update_ci(eq, cc, 0);     
 45                 cc = 0;                           
 46         }                                         
 47         return cc;                                
 48 }                                                 
 49                                                   
 50 struct mlx5_nb {                                  
 51         struct notifier_block nb;                 
 52         u8 event_type;                            
 53 };                                                
 54                                                   
 55 #define mlx5_nb_cof(ptr, type, member) \          
 56         (container_of(container_of(ptr, struct    
 57                                                   
 58 #define MLX5_NB_INIT(name, handler, event) do     
 59         (name)->nb.notifier_call = handler;       
 60         (name)->event_type = MLX5_EVENT_TYPE_#    
 61 } while (0)                                       
 62                                                   
 63 #endif /* MLX5_CORE_EQ_H */                       
 64                                                   

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php