diff options
Diffstat (limited to 'net/mac802154/mac_cmd.c')
| -rw-r--r-- | net/mac802154/mac_cmd.c | 47 | 
1 files changed, 45 insertions, 2 deletions
diff --git a/net/mac802154/mac_cmd.c b/net/mac802154/mac_cmd.c index a99910d4d52..bf809131eef 100644 --- a/net/mac802154/mac_cmd.c +++ b/net/mac802154/mac_cmd.c @@ -40,19 +40,41 @@ static int mac802154_mlme_start_req(struct net_device *dev,  				    u8 pan_coord, u8 blx,  				    u8 coord_realign)  { -	BUG_ON(addr->addr_type != IEEE802154_ADDR_SHORT); +	struct ieee802154_mlme_ops *ops = ieee802154_mlme_ops(dev); +	int rc = 0; + +	BUG_ON(addr->mode != IEEE802154_ADDR_SHORT);  	mac802154_dev_set_pan_id(dev, addr->pan_id);  	mac802154_dev_set_short_addr(dev, addr->short_addr);  	mac802154_dev_set_ieee_addr(dev);  	mac802154_dev_set_page_channel(dev, page, channel); +	if (ops->llsec) { +		struct ieee802154_llsec_params params; +		int changed = 0; + +		params.coord_shortaddr = addr->short_addr; +		changed |= IEEE802154_LLSEC_PARAM_COORD_SHORTADDR; + +		params.pan_id = addr->pan_id; +		changed |= IEEE802154_LLSEC_PARAM_PAN_ID; + +		params.hwaddr = ieee802154_devaddr_from_raw(dev->dev_addr); +		changed |= IEEE802154_LLSEC_PARAM_HWADDR; + +		params.coord_hwaddr = params.hwaddr; +		changed |= IEEE802154_LLSEC_PARAM_COORD_HWADDR; + +		rc = ops->llsec->set_params(dev, ¶ms, changed); +	} +  	/* FIXME: add validation for unused parameters to be sane  	 * for SoftMAC  	 */  	ieee802154_nl_start_confirm(dev, IEEE802154_SUCCESS); -	return 0; +	return rc;  }  static struct wpan_phy *mac802154_get_phy(const struct net_device *dev) @@ -64,6 +86,22 @@ static struct wpan_phy *mac802154_get_phy(const struct net_device *dev)  	return to_phy(get_device(&priv->hw->phy->dev));  } +static struct ieee802154_llsec_ops mac802154_llsec_ops = { +	.get_params = mac802154_get_params, +	.set_params = mac802154_set_params, +	.add_key = mac802154_add_key, +	.del_key = mac802154_del_key, +	.add_dev = mac802154_add_dev, +	.del_dev = mac802154_del_dev, +	.add_devkey = mac802154_add_devkey, +	.del_devkey = mac802154_del_devkey, +	.add_seclevel = mac802154_add_seclevel, +	.del_seclevel = mac802154_del_seclevel, +	.lock_table = mac802154_lock_table, +	.get_table = mac802154_get_table, +	.unlock_table = mac802154_unlock_table, +}; +  struct ieee802154_reduced_mlme_ops mac802154_mlme_reduced = {  	.get_phy = mac802154_get_phy,  }; @@ -74,4 +112,9 @@ struct ieee802154_mlme_ops mac802154_mlme_wpan = {  	.get_pan_id = mac802154_dev_get_pan_id,  	.get_short_addr = mac802154_dev_get_short_addr,  	.get_dsn = mac802154_dev_get_dsn, + +	.llsec = &mac802154_llsec_ops, + +	.set_mac_params = mac802154_set_mac_params, +	.get_mac_params = mac802154_get_mac_params,  };  | 
