Commit 7c747838 authored by Ido Schimmel's avatar Ido Schimmel Committed by David S. Miller

drop_monitor: Split tracing enable / disable to different functions

Subsequent patches will need to enable / disable tracing based on the
configured alerting mode.

Reduce the nesting level and prepare for the introduction of this
functionality by splitting the tracing enable / disable operations into
two different functions.
Signed-off-by: default avatarIdo Schimmel <idosch@mellanox.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 2cc2743d
...@@ -241,38 +241,45 @@ static void trace_napi_poll_hit(void *ignore, struct napi_struct *napi, ...@@ -241,38 +241,45 @@ static void trace_napi_poll_hit(void *ignore, struct napi_struct *napi,
rcu_read_unlock(); rcu_read_unlock();
} }
static int set_all_monitor_traces(int state, struct netlink_ext_ack *extack) static int net_dm_trace_on_set(struct netlink_ext_ack *extack)
{ {
int rc = 0; int rc;
struct dm_hw_stat_delta *new_stat = NULL;
struct dm_hw_stat_delta *temp;
if (state == trace_state) {
NL_SET_ERR_MSG_MOD(extack, "Trace state already set to requested state");
return -EAGAIN;
}
switch (state) {
case TRACE_ON:
if (!try_module_get(THIS_MODULE)) { if (!try_module_get(THIS_MODULE)) {
NL_SET_ERR_MSG_MOD(extack, "Failed to take reference on module"); NL_SET_ERR_MSG_MOD(extack, "Failed to take reference on module");
rc = -ENODEV; return -ENODEV;
break;
} }
rc |= register_trace_kfree_skb(trace_kfree_skb_hit, NULL); rc = register_trace_kfree_skb(trace_kfree_skb_hit, NULL);
rc |= register_trace_napi_poll(trace_napi_poll_hit, NULL); if (rc) {
break; NL_SET_ERR_MSG_MOD(extack, "Failed to connect probe to kfree_skb() tracepoint");
goto err_module_put;
}
case TRACE_OFF: rc = register_trace_napi_poll(trace_napi_poll_hit, NULL);
rc |= unregister_trace_kfree_skb(trace_kfree_skb_hit, NULL); if (rc) {
rc |= unregister_trace_napi_poll(trace_napi_poll_hit, NULL); NL_SET_ERR_MSG_MOD(extack, "Failed to connect probe to napi_poll() tracepoint");
goto err_unregister_trace;
}
return 0;
err_unregister_trace:
unregister_trace_kfree_skb(trace_kfree_skb_hit, NULL);
err_module_put:
module_put(THIS_MODULE);
return rc;
}
static void net_dm_trace_off_set(void)
{
struct dm_hw_stat_delta *new_stat, *temp;
unregister_trace_napi_poll(trace_napi_poll_hit, NULL);
unregister_trace_kfree_skb(trace_kfree_skb_hit, NULL);
tracepoint_synchronize_unregister(); tracepoint_synchronize_unregister();
/*
* Clean the device list
*/
list_for_each_entry_safe(new_stat, temp, &hw_stats_list, list) { list_for_each_entry_safe(new_stat, temp, &hw_stats_list, list) {
if (new_stat->dev == NULL) { if (new_stat->dev == NULL) {
list_del_rcu(&new_stat->list); list_del_rcu(&new_stat->list);
...@@ -281,7 +288,23 @@ static int set_all_monitor_traces(int state, struct netlink_ext_ack *extack) ...@@ -281,7 +288,23 @@ static int set_all_monitor_traces(int state, struct netlink_ext_ack *extack)
} }
module_put(THIS_MODULE); module_put(THIS_MODULE);
}
static int set_all_monitor_traces(int state, struct netlink_ext_ack *extack)
{
int rc = 0;
if (state == trace_state) {
NL_SET_ERR_MSG_MOD(extack, "Trace state already set to requested state");
return -EAGAIN;
}
switch (state) {
case TRACE_ON:
rc = net_dm_trace_on_set(extack);
break;
case TRACE_OFF:
net_dm_trace_off_set();
break; break;
default: default:
rc = 1; rc = 1;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment