mirror of
https://github.com/torvalds/linux.git
synced 2024-11-22 12:11:40 +00:00
drop_monitor: adopt u64_stats_t
As explained in commit 316580b69d
("u64_stats: provide u64_stats_t type")
we should use u64_stats_t and related accessors to avoid load/store tearing.
Signed-off-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
This commit is contained in:
parent
958751e080
commit
c6cce71e74
@ -55,7 +55,7 @@ static bool monitor_hw;
|
||||
static DEFINE_MUTEX(net_dm_mutex);
|
||||
|
||||
struct net_dm_stats {
|
||||
u64 dropped;
|
||||
u64_stats_t dropped;
|
||||
struct u64_stats_sync syncp;
|
||||
};
|
||||
|
||||
@ -530,7 +530,7 @@ static void net_dm_packet_trace_kfree_skb_hit(void *ignore,
|
||||
unlock_free:
|
||||
spin_unlock_irqrestore(&data->drop_queue.lock, flags);
|
||||
u64_stats_update_begin(&data->stats.syncp);
|
||||
data->stats.dropped++;
|
||||
u64_stats_inc(&data->stats.dropped);
|
||||
u64_stats_update_end(&data->stats.syncp);
|
||||
consume_skb(nskb);
|
||||
}
|
||||
@ -986,7 +986,7 @@ net_dm_hw_trap_packet_probe(void *ignore, const struct devlink *devlink,
|
||||
unlock_free:
|
||||
spin_unlock_irqrestore(&hw_data->drop_queue.lock, flags);
|
||||
u64_stats_update_begin(&hw_data->stats.syncp);
|
||||
hw_data->stats.dropped++;
|
||||
u64_stats_inc(&hw_data->stats.dropped);
|
||||
u64_stats_update_end(&hw_data->stats.syncp);
|
||||
net_dm_hw_metadata_free(n_hw_metadata);
|
||||
free:
|
||||
@ -1433,10 +1433,10 @@ static void net_dm_stats_read(struct net_dm_stats *stats)
|
||||
|
||||
do {
|
||||
start = u64_stats_fetch_begin_irq(&cpu_stats->syncp);
|
||||
dropped = cpu_stats->dropped;
|
||||
dropped = u64_stats_read(&cpu_stats->dropped);
|
||||
} while (u64_stats_fetch_retry_irq(&cpu_stats->syncp, start));
|
||||
|
||||
stats->dropped += dropped;
|
||||
u64_stats_add(&stats->dropped, dropped);
|
||||
}
|
||||
}
|
||||
|
||||
@ -1452,7 +1452,7 @@ static int net_dm_stats_put(struct sk_buff *msg)
|
||||
return -EMSGSIZE;
|
||||
|
||||
if (nla_put_u64_64bit(msg, NET_DM_ATTR_STATS_DROPPED,
|
||||
stats.dropped, NET_DM_ATTR_PAD))
|
||||
u64_stats_read(&stats.dropped), NET_DM_ATTR_PAD))
|
||||
goto nla_put_failure;
|
||||
|
||||
nla_nest_end(msg, attr);
|
||||
@ -1477,10 +1477,10 @@ static void net_dm_hw_stats_read(struct net_dm_stats *stats)
|
||||
|
||||
do {
|
||||
start = u64_stats_fetch_begin_irq(&cpu_stats->syncp);
|
||||
dropped = cpu_stats->dropped;
|
||||
dropped = u64_stats_read(&cpu_stats->dropped);
|
||||
} while (u64_stats_fetch_retry_irq(&cpu_stats->syncp, start));
|
||||
|
||||
stats->dropped += dropped;
|
||||
u64_stats_add(&stats->dropped, dropped);
|
||||
}
|
||||
}
|
||||
|
||||
@ -1496,7 +1496,7 @@ static int net_dm_hw_stats_put(struct sk_buff *msg)
|
||||
return -EMSGSIZE;
|
||||
|
||||
if (nla_put_u64_64bit(msg, NET_DM_ATTR_STATS_DROPPED,
|
||||
stats.dropped, NET_DM_ATTR_PAD))
|
||||
u64_stats_read(&stats.dropped), NET_DM_ATTR_PAD))
|
||||
goto nla_put_failure;
|
||||
|
||||
nla_nest_end(msg, attr);
|
||||
|
Loading…
Reference in New Issue
Block a user