Commit e4d5015b authored by Jakub Kicinski's avatar Jakub Kicinski
Browse files

devlink: uniformly take the devlink instance lock in the dump loop



Move the lock taking out of devlink_nl_cmd_region_get_devlink_dumpit().
This way all dumps will take the instance lock in the main iteration
loop directly, making refactoring and reading the code easier.

Reviewed-by: default avatarJiri Pirko <jiri@nvidia.com>
Reviewed-by: default avatarJacob Keller <jacob.e.keller@intel.com>
Signed-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parent c9666bac
Loading
Loading
Loading
Loading
+6 −7
Original line number Diff line number Diff line
@@ -6050,9 +6050,8 @@ static int devlink_nl_cmd_region_get_devlink_dumpit(struct sk_buff *msg,
	struct devlink_region *region;
	struct devlink_port *port;
	unsigned long port_index;
	int err = 0;
	int err;

	devl_lock(devlink);
	list_for_each_entry(region, &devlink->region_list, list) {
		if (*idx < start) {
			(*idx)++;
@@ -6064,7 +6063,7 @@ static int devlink_nl_cmd_region_get_devlink_dumpit(struct sk_buff *msg,
					     cb->nlh->nlmsg_seq,
					     NLM_F_MULTI, region);
		if (err)
			goto out;
			return err;
		(*idx)++;
	}

@@ -6072,12 +6071,10 @@ static int devlink_nl_cmd_region_get_devlink_dumpit(struct sk_buff *msg,
		err = devlink_nl_cmd_region_get_port_dumpit(msg, cb, port, idx,
							    start);
		if (err)
			goto out;
			return err;
	}

out:
	devl_unlock(devlink);
	return err;
	return 0;
}

static int devlink_nl_cmd_region_get_dumpit(struct sk_buff *msg,
@@ -6090,8 +6087,10 @@ static int devlink_nl_cmd_region_get_dumpit(struct sk_buff *msg,
	devlink_dump_for_each_instance_get(msg, state, devlink) {
		int idx = 0;

		devl_lock(devlink);
		err = devlink_nl_cmd_region_get_devlink_dumpit(msg, cb, devlink,
							       &idx, state->idx);
		devl_unlock(devlink);
		devlink_put(devlink);
		if (err) {
			state->idx = idx;