mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-10 07:10:27 +00:00
drop_monitor: adopt u64_stats_t
As explained in commit 316580b69d0a ("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);
|
static DEFINE_MUTEX(net_dm_mutex);
|
||||||
|
|
||||||
struct net_dm_stats {
|
struct net_dm_stats {
|
||||||
u64 dropped;
|
u64_stats_t dropped;
|
||||||
struct u64_stats_sync syncp;
|
struct u64_stats_sync syncp;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -530,7 +530,7 @@ static void net_dm_packet_trace_kfree_skb_hit(void *ignore,
|
|||||||
unlock_free:
|
unlock_free:
|
||||||
spin_unlock_irqrestore(&data->drop_queue.lock, flags);
|
spin_unlock_irqrestore(&data->drop_queue.lock, flags);
|
||||||
u64_stats_update_begin(&data->stats.syncp);
|
u64_stats_update_begin(&data->stats.syncp);
|
||||||
data->stats.dropped++;
|
u64_stats_inc(&data->stats.dropped);
|
||||||
u64_stats_update_end(&data->stats.syncp);
|
u64_stats_update_end(&data->stats.syncp);
|
||||||
consume_skb(nskb);
|
consume_skb(nskb);
|
||||||
}
|
}
|
||||||
@ -986,7 +986,7 @@ net_dm_hw_trap_packet_probe(void *ignore, const struct devlink *devlink,
|
|||||||
unlock_free:
|
unlock_free:
|
||||||
spin_unlock_irqrestore(&hw_data->drop_queue.lock, flags);
|
spin_unlock_irqrestore(&hw_data->drop_queue.lock, flags);
|
||||||
u64_stats_update_begin(&hw_data->stats.syncp);
|
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);
|
u64_stats_update_end(&hw_data->stats.syncp);
|
||||||
net_dm_hw_metadata_free(n_hw_metadata);
|
net_dm_hw_metadata_free(n_hw_metadata);
|
||||||
free:
|
free:
|
||||||
@ -1433,10 +1433,10 @@ static void net_dm_stats_read(struct net_dm_stats *stats)
|
|||||||
|
|
||||||
do {
|
do {
|
||||||
start = u64_stats_fetch_begin_irq(&cpu_stats->syncp);
|
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));
|
} 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;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
if (nla_put_u64_64bit(msg, NET_DM_ATTR_STATS_DROPPED,
|
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;
|
goto nla_put_failure;
|
||||||
|
|
||||||
nla_nest_end(msg, attr);
|
nla_nest_end(msg, attr);
|
||||||
@ -1477,10 +1477,10 @@ static void net_dm_hw_stats_read(struct net_dm_stats *stats)
|
|||||||
|
|
||||||
do {
|
do {
|
||||||
start = u64_stats_fetch_begin_irq(&cpu_stats->syncp);
|
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));
|
} 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;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
if (nla_put_u64_64bit(msg, NET_DM_ATTR_STATS_DROPPED,
|
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;
|
goto nla_put_failure;
|
||||||
|
|
||||||
nla_nest_end(msg, attr);
|
nla_nest_end(msg, attr);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user