diff options
Diffstat (limited to 'net/core/drop_monitor.c')
| -rw-r--r-- | net/core/drop_monitor.c | 29 | 
1 files changed, 16 insertions, 13 deletions
| diff --git a/net/core/drop_monitor.c b/net/core/drop_monitor.c index b0f221d658be..2e0ae3328232 100644 --- a/net/core/drop_monitor.c +++ b/net/core/drop_monitor.c @@ -74,7 +74,7 @@ struct net_dm_hw_entries {  };  struct per_cpu_dm_data { -	spinlock_t		lock;	/* Protects 'skb', 'hw_entries' and +	raw_spinlock_t		lock;	/* Protects 'skb', 'hw_entries' and  					 * 'send_timer'  					 */  	union { @@ -109,7 +109,8 @@ static u32 net_dm_queue_len = 1000;  struct net_dm_alert_ops {  	void (*kfree_skb_probe)(void *ignore, struct sk_buff *skb,  				void *location, -				enum skb_drop_reason reason); +				enum skb_drop_reason reason, +				struct sock *rx_sk);  	void (*napi_poll_probe)(void *ignore, struct napi_struct *napi,  				int work, int budget);  	void (*work_item_func)(struct work_struct *work); @@ -168,9 +169,9 @@ static struct sk_buff *reset_per_cpu_data(struct per_cpu_dm_data *data)  err:  	mod_timer(&data->send_timer, jiffies + HZ / 10);  out: -	spin_lock_irqsave(&data->lock, flags); +	raw_spin_lock_irqsave(&data->lock, flags);  	swap(data->skb, skb); -	spin_unlock_irqrestore(&data->lock, flags); +	raw_spin_unlock_irqrestore(&data->lock, flags);  	if (skb) {  		struct nlmsghdr *nlh = (struct nlmsghdr *)skb->data; @@ -225,7 +226,7 @@ static void trace_drop_common(struct sk_buff *skb, void *location)  	local_irq_save(flags);  	data = this_cpu_ptr(&dm_cpu_data); -	spin_lock(&data->lock); +	raw_spin_lock(&data->lock);  	dskb = data->skb;  	if (!dskb) @@ -259,12 +260,13 @@ static void trace_drop_common(struct sk_buff *skb, void *location)  	}  out: -	spin_unlock_irqrestore(&data->lock, flags); +	raw_spin_unlock_irqrestore(&data->lock, flags);  }  static void trace_kfree_skb_hit(void *ignore, struct sk_buff *skb,  				void *location, -				enum skb_drop_reason reason) +				enum skb_drop_reason reason, +				struct sock *rx_sk)  {  	trace_drop_common(skb, location);  } @@ -314,9 +316,9 @@ net_dm_hw_reset_per_cpu_data(struct per_cpu_dm_data *hw_data)  		mod_timer(&hw_data->send_timer, jiffies + HZ / 10);  	} -	spin_lock_irqsave(&hw_data->lock, flags); +	raw_spin_lock_irqsave(&hw_data->lock, flags);  	swap(hw_data->hw_entries, hw_entries); -	spin_unlock_irqrestore(&hw_data->lock, flags); +	raw_spin_unlock_irqrestore(&hw_data->lock, flags);  	return hw_entries;  } @@ -448,7 +450,7 @@ net_dm_hw_trap_summary_probe(void *ignore, const struct devlink *devlink,  		return;  	hw_data = this_cpu_ptr(&dm_hw_cpu_data); -	spin_lock_irqsave(&hw_data->lock, flags); +	raw_spin_lock_irqsave(&hw_data->lock, flags);  	hw_entries = hw_data->hw_entries;  	if (!hw_entries) @@ -477,7 +479,7 @@ net_dm_hw_trap_summary_probe(void *ignore, const struct devlink *devlink,  	}  out: -	spin_unlock_irqrestore(&hw_data->lock, flags); +	raw_spin_unlock_irqrestore(&hw_data->lock, flags);  }  static const struct net_dm_alert_ops net_dm_alert_summary_ops = { @@ -491,7 +493,8 @@ static const struct net_dm_alert_ops net_dm_alert_summary_ops = {  static void net_dm_packet_trace_kfree_skb_hit(void *ignore,  					      struct sk_buff *skb,  					      void *location, -					      enum skb_drop_reason reason) +					      enum skb_drop_reason reason, +					      struct sock *rx_sk)  {  	ktime_t tstamp = ktime_get_real();  	struct per_cpu_dm_data *data; @@ -1673,7 +1676,7 @@ static struct notifier_block dropmon_net_notifier = {  static void __net_dm_cpu_data_init(struct per_cpu_dm_data *data)  { -	spin_lock_init(&data->lock); +	raw_spin_lock_init(&data->lock);  	skb_queue_head_init(&data->drop_queue);  	u64_stats_init(&data->stats.syncp);  } | 
