Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit cd1c5665 authored by Alexander Aring's avatar Alexander Aring Committed by Marcel Holtmann
Browse files

ieee802154: iface: move multiple node type check



This patch moves the handling for checking on multiple node type
interface to the corresponding concurrent iface check function.

Signed-off-by: default avatarAlexander Aring <alex.aring@gmail.com>
Signed-off-by: default avatarMarcel Holtmann <marcel@holtmann.org>
parent bd37a78d
Loading
Loading
Loading
Loading
+9 −14
Original line number Original line Diff line number Diff line
@@ -137,25 +137,11 @@ static int mac802154_wpan_mac_addr(struct net_device *dev, void *p)
static int mac802154_slave_open(struct net_device *dev)
static int mac802154_slave_open(struct net_device *dev)
{
{
	struct ieee802154_sub_if_data *sdata = IEEE802154_DEV_TO_SUB_IF(dev);
	struct ieee802154_sub_if_data *sdata = IEEE802154_DEV_TO_SUB_IF(dev);
	struct ieee802154_sub_if_data *subif;
	struct ieee802154_local *local = sdata->local;
	struct ieee802154_local *local = sdata->local;
	int res = 0;
	int res = 0;


	ASSERT_RTNL();
	ASSERT_RTNL();


	if (sdata->vif.type == NL802154_IFTYPE_NODE) {
		mutex_lock(&sdata->local->iflist_mtx);
		list_for_each_entry(subif, &sdata->local->interfaces, list) {
			if (subif != sdata &&
			    subif->vif.type == sdata->vif.type &&
			    ieee802154_sdata_running(subif)) {
				mutex_unlock(&sdata->local->iflist_mtx);
				return -EBUSY;
			}
		}
		mutex_unlock(&sdata->local->iflist_mtx);
	}

	set_bit(SDATA_STATE_RUNNING, &sdata->state);
	set_bit(SDATA_STATE_RUNNING, &sdata->state);


	if (!local->open_count) {
	if (!local->open_count) {
@@ -235,6 +221,15 @@ ieee802154_check_concurrent_iface(struct ieee802154_sub_if_data *sdata,
		if (nsdata != sdata && ieee802154_sdata_running(nsdata)) {
		if (nsdata != sdata && ieee802154_sdata_running(nsdata)) {
			int ret;
			int ret;


			/* TODO currently we don't support multiple node types
			 * we need to run skb_clone at rx path. Check if there
			 * exist really an use case if we need to support
			 * multiple node types at the same time.
			 */
			if (sdata->vif.type == NL802154_IFTYPE_NODE &&
			    nsdata->vif.type == NL802154_IFTYPE_NODE)
				return -EBUSY;

			/* check all phy mac sublayer settings are the same.
			/* check all phy mac sublayer settings are the same.
			 * We have only one phy, different values makes trouble.
			 * We have only one phy, different values makes trouble.
			 */
			 */