lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite for Android: free password hash cracker in your pocket
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Date:	Sat, 7 Feb 2015 11:29:24 -0800
From:	Mahesh Bandewar <maheshb@...gle.com>
To:	Andy Gospodarek <gospo@...ulusnetworks.com>
Cc:	Jay Vosburgh <j.vosburgh@...il.com>,
	Andy Gospodarek <andy@...yhouse.net>,
	Veaceslav Falico <vfalico@...il.com>,
	Nikolay Aleksandrov <nikolay@...hat.com>,
	David Miller <davem@...emloft.net>,
	netdev <netdev@...r.kernel.org>,
	Eric Dumazet <edumazet@...gle.com>
Subject: Re: [PATCH next 6/6] bonding: Implement user key part of port_key in
 an AD system.

On Fri, Feb 6, 2015 at 7:40 PM, Andy Gospodarek
<gospo@...ulusnetworks.com> wrote:
> On Fri, Feb 06, 2015 at 04:51:57PM -0800, Mahesh Bandewar wrote:
>> The port key has three components - user-key, speed-part, and duplex-part.
>> The LSBit is for the duplex-part, next 5 bits are for the speed while the
>> remaining 10 bits are the user defined key bits. Get these 10 bits
>> from the user-space (through the SysFs interface) and use it to form the
>> admin port-key. Allowed range for the user-key is 0 - 1023 (10 bits). If
>> it is not provided then use zero for the user-key-bits (default).
>>
>> It can set using following example code -
>>
>>    # modprobe bonding mode=4
>>    # usr_port_key=$(( RANDOM & 0x3FF ))
>>    # echo $usr_port_key > /sys/class/net/bond0/bonding/ad_actor_user_port_key
>>    # echo +eth1 > /sys/class/net/bond0/bonding/slaves
>
> If the other ones don't have 'actor' maybe drop it here too.
>
> (Sorry to be picky about these, but as someone who has typed many of
> these options a bunch it would be great to have shorter names in config
> files.)
>
Thanks for the suggestions Andy. Now I don't have to battle with
myself for the correct names :) I wanted to move the naming discussion
in the other thread where I have proposed this to be changed to
'ad_user_portkey'.

>>    ...
>>    # ip link set bond0 up
>>
>> Signed-off-by: Mahesh Bandewar <maheshb@...gle.com>
>> ---
>>  drivers/net/bonding/bond_3ad.c     |  6 +++---
>>  drivers/net/bonding/bond_main.c    | 10 ++++++++++
>>  drivers/net/bonding/bond_options.c | 26 ++++++++++++++++++++++++++
>>  drivers/net/bonding/bond_sysfs.c   | 15 +++++++++++++++
>>  include/net/bond_options.h         |  1 +
>>  include/net/bonding.h              |  1 +
>>  6 files changed, 56 insertions(+), 3 deletions(-)
>>
>> diff --git a/drivers/net/bonding/bond_3ad.c b/drivers/net/bonding/bond_3ad.c
>> index 373d3db3809f..c69c393ba8c5 100644
>> --- a/drivers/net/bonding/bond_3ad.c
>> +++ b/drivers/net/bonding/bond_3ad.c
>> @@ -1955,10 +1955,10 @@ void bond_3ad_bind_slave(struct slave *slave)
>>
>>               port->slave = slave;
>>               port->actor_port_number = SLAVE_AD_INFO(slave)->id;
>> -             /* key is determined according to the link speed, duplex and user key(which
>> -              * is yet not supported)
>> +             /* key is determined according to the link speed, duplex and
>> +              * user key
>>                */
>> -             port->actor_admin_port_key = 0;
>> +             port->actor_admin_port_key = bond->params.ad_actor_portkey << 6;
>>               port->actor_admin_port_key |= __get_duplex(port);
>>               port->actor_admin_port_key |= (__get_link_speed(port) << 1);
>>               port->actor_oper_port_key = port->actor_admin_port_key;
>> diff --git a/drivers/net/bonding/bond_main.c b/drivers/net/bonding/bond_main.c
>> index 1a6735ef2ea7..f9f001f35a91 100644
>> --- a/drivers/net/bonding/bond_main.c
>> +++ b/drivers/net/bonding/bond_main.c
>> @@ -4105,6 +4105,7 @@ static int bond_check_params(struct bond_params *params)
>>       const struct bond_opt_value *valptr;
>>       int arp_all_targets_value;
>>       u16 ad_actor_sysprio = 0;
>> +     u16 ad_actor_portkey = 0;
>>
>>       /* Convert string parameters. */
>>       if (mode) {
>> @@ -4409,6 +4410,14 @@ static int bond_check_params(struct bond_params *params)
>>                       return -EINVAL;
>>               }
>>               ad_actor_sysprio = valptr->value;
>> +
>> +             valptr = bond_opt_parse(bond_opt_get(BOND_OPT_AD_ACTOR_PORTKEY),
>> +                                     &newval);
>> +             if (!valptr) {
>> +                     pr_err("Error: No ad_actor_portkey default value");
>> +                     return -EINVAL;
>> +             }
>> +             ad_actor_portkey = valptr->value;
>>       }
>>
>>       if (lp_interval == 0) {
>> @@ -4441,6 +4450,7 @@ static int bond_check_params(struct bond_params *params)
>>       params->tlb_dynamic_lb = 1; /* Default value */
>>       params->ad_actor_sysprio = ad_actor_sysprio;
>>       eth_zero_addr(params->ad_actor_sys_macaddr);
>> +     params->ad_actor_portkey = ad_actor_portkey;
>>       if (packets_per_slave > 0) {
>>               params->reciprocal_packets_per_slave =
>>                       reciprocal_value(packets_per_slave);
>> diff --git a/drivers/net/bonding/bond_options.c b/drivers/net/bonding/bond_options.c
>> index 330d48b6a1e6..c3f77c6d0d2e 100644
>> --- a/drivers/net/bonding/bond_options.c
>> +++ b/drivers/net/bonding/bond_options.c
>> @@ -74,6 +74,8 @@ static int bond_option_ad_actor_sysprio_set(struct bonding *bond,
>>                                 const struct bond_opt_value *newval);
>>  static int bond_option_ad_actor_sys_macaddr_set(struct bonding *bond,
>>                                 const struct bond_opt_value *newval);
>> +static int bond_option_ad_actor_portkey_set(struct bonding *bond,
>> +                               const struct bond_opt_value *newval);
>>
>>
>>  static const struct bond_opt_value bond_mode_tbl[] = {
>> @@ -196,6 +198,12 @@ static const struct bond_opt_value bond_ad_actor_sysprio_tbl[] = {
>>       { NULL,      -1,    0},
>>  };
>>
>> +static const struct bond_opt_value bond_ad_actor_portkey_tbl[] = {
>> +     { "minval",  0,     BOND_VALFLAG_MIN | BOND_VALFLAG_DEFAULT},
>> +     { "maxval",  1023,  BOND_VALFLAG_MAX},
>> +     { NULL,      -1,    0},
>> +};
>> +
>>  static const struct bond_option bond_opts[BOND_OPT_LAST] = {
>>       [BOND_OPT_MODE] = {
>>               .id = BOND_OPT_MODE,
>> @@ -405,6 +413,14 @@ static const struct bond_option bond_opts[BOND_OPT_LAST] = {
>>               .flags = BOND_OPTFLAG_RAWVAL | BOND_OPTFLAG_IFDOWN,
>>               .set = bond_option_ad_actor_sys_macaddr_set,
>>       },
>> +     [BOND_OPT_AD_ACTOR_PORTKEY] = {
>> +             .id = BOND_OPT_AD_ACTOR_PORTKEY,
>> +             .name = "ad_actor_user_port_key",
>> +             .unsuppmodes = BOND_MODE_ALL_EX(BIT(BOND_MODE_8023AD)),
>> +             .flags = BOND_OPTFLAG_IFDOWN,
>> +             .values = bond_ad_actor_portkey_tbl,
>> +             .set = bond_option_ad_actor_portkey_set,
>> +     }
>>  };
>>
>>  /* Searches for an option by name */
>> @@ -1405,3 +1421,13 @@ static int bond_option_ad_actor_sys_macaddr_set(struct bonding *bond,
>>
>>       return 0;
>>  }
>> +
>> +static int bond_option_ad_actor_portkey_set(struct bonding *bond,
>> +                                         const struct bond_opt_value *newval)
>> +{
>> +     netdev_info(bond->dev, "Setting ad_actor_portkey to (%llu)\n",
>> +                 newval->value);
>> +
>> +     bond->params.ad_actor_portkey = newval->value;
>> +     return 0;
>> +}
>> diff --git a/drivers/net/bonding/bond_sysfs.c b/drivers/net/bonding/bond_sysfs.c
>> index 91713d0b6685..17d84d5a1608 100644
>> --- a/drivers/net/bonding/bond_sysfs.c
>> +++ b/drivers/net/bonding/bond_sysfs.c
>> @@ -721,6 +721,20 @@ static DEVICE_ATTR(ad_actor_system_mac_address, S_IRUGO | S_IWUSR,
>>                  bonding_show_ad_actor_sys_macaddr,
>>                  bonding_sysfs_store_option);
>>
>> +static ssize_t bonding_show_ad_actor_portkey(struct device *d,
>> +                                          struct device_attribute *attr,
>> +                                          char *buf)
>> +{
>> +     struct bonding *bond = to_bond(d);
>> +
>> +     if (BOND_MODE(bond) == BOND_MODE_8023AD)
>> +             return sprintf(buf, "%hu\n", bond->params.ad_actor_portkey);
>> +
>> +     return 0;
>> +}
>> +static DEVICE_ATTR(ad_actor_user_port_key, S_IRUGO | S_IWUSR,
>> +                bonding_show_ad_actor_portkey, bonding_sysfs_store_option);
>> +
>>  static struct attribute *per_bond_attrs[] = {
>>       &dev_attr_slaves.attr,
>>       &dev_attr_mode.attr,
>> @@ -756,6 +770,7 @@ static struct attribute *per_bond_attrs[] = {
>>       &dev_attr_tlb_dynamic_lb.attr,
>>       &dev_attr_ad_actor_system_priority.attr,
>>       &dev_attr_ad_actor_system_mac_address.attr,
>> +     &dev_attr_ad_actor_user_port_key.attr,
>>       NULL,
>>  };
>>
>> diff --git a/include/net/bond_options.h b/include/net/bond_options.h
>> index 993ef73cd050..4c36455aacb4 100644
>> --- a/include/net/bond_options.h
>> +++ b/include/net/bond_options.h
>> @@ -65,6 +65,7 @@ enum {
>>       BOND_OPT_TLB_DYNAMIC_LB,
>>       BOND_OPT_AD_ACTOR_SYSPRIO,
>>       BOND_OPT_AD_ACTOR_SYS_MACADDR,
>> +     BOND_OPT_AD_ACTOR_PORTKEY,
>>       BOND_OPT_LAST
>>  };
>>
>> diff --git a/include/net/bonding.h b/include/net/bonding.h
>> index cd2092e6bc71..e91db2566437 100644
>> --- a/include/net/bonding.h
>> +++ b/include/net/bonding.h
>> @@ -144,6 +144,7 @@ struct bond_params {
>>       int tlb_dynamic_lb;
>>       struct reciprocal_value reciprocal_packets_per_slave;
>>       u16 ad_actor_sysprio;
>> +     u16 ad_actor_portkey;
>>       u8 ad_actor_sys_macaddr[ETH_ALEN];
>>  };
>>
>> --
>> 2.2.0.rc0.207.ga3a616c
>>
>> --
>> To unsubscribe from this list: send the line "unsubscribe netdev" in
>> the body of a message to majordomo@...r.kernel.org
>> More majordomo info at  http://vger.kernel.org/majordomo-info.html
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ