On Wed, 2008-05-21 at 00:43 +0100, David Woodhouse wrote: > From: Javier Cardona <javier@xxxxxxxxxxx> > > This will create the following entry: > /sys/class/net/mshX > -- boot_options > | |-- ... > | `-- channel > ... > > ... which I overlooked on my previous patch. > > Signed-off-by: Javier Cardona <javier@xxxxxxxxxxx> > Signed-off-by: David Woodhouse <dwmw2@xxxxxxxxxxxxx> Acked-by: Dan Williams <dcbw@xxxxxxxxxx> > --- > Added to git://git.infradead.org/~dwmw2/libertas-2.6.git > (from which I dropped the OLPC reset patch which Andres is going to improve on) > > diff --git a/drivers/net/wireless/libertas/persistcfg.c b/drivers/net/wireless/libertas/persistcfg.c > index baa6627..6cf5e39 100644 > --- a/drivers/net/wireless/libertas/persistcfg.c > +++ b/drivers/net/wireless/libertas/persistcfg.c > @@ -130,6 +130,49 @@ static ssize_t boottime_set(struct device *dev, > } > > /** > + * @brief Get function for sysfs attribute channel > + */ > +static ssize_t channel_get(struct device *dev, > + struct device_attribute *attr, char *buf) > +{ > + struct mrvl_mesh_defaults defs; > + int ret; > + > + ret = mesh_get_default_parameters(dev, &defs); > + > + if (ret) > + return ret; > + > + return snprintf(buf, 12, "0x%x\n", le16_to_cpu(defs.channel)); > +} > + > +/** > + * @brief Set function for sysfs attribute channel > + */ > +static ssize_t channel_set(struct device *dev, struct device_attribute *attr, > + const char *buf, size_t count) > +{ > + struct lbs_private *priv = to_net_dev(dev)->priv; > + struct cmd_ds_mesh_config cmd; > + uint16_t datum; > + int ret; > + > + memset(&cmd, 0, sizeof(cmd)); > + ret = sscanf(buf, "%hx", &datum); > + if (ret != 1 || datum < 1 || datum > 11) > + return -EINVAL; > + > + *((__le16 *)&cmd.data[0]) = cpu_to_le16(datum); > + cmd.length = cpu_to_le16(sizeof(uint16_t)); > + ret = lbs_mesh_config_send(priv, &cmd, CMD_ACT_MESH_CONFIG_SET, > + CMD_TYPE_MESH_SET_DEF_CHANNEL); > + if (ret) > + return ret; > + > + return strlen(buf); > +} > + > +/** > * @brief Get function for sysfs attribute mesh_id > */ > static ssize_t mesh_id_get(struct device *dev, struct device_attribute *attr, > @@ -365,6 +408,7 @@ static ssize_t capability_set(struct device *dev, struct device_attribute *attr, > > static DEVICE_ATTR(bootflag, 0644, bootflag_get, bootflag_set); > static DEVICE_ATTR(boottime, 0644, boottime_get, boottime_set); > +static DEVICE_ATTR(channel, 0644, channel_get, channel_set); > static DEVICE_ATTR(mesh_id, 0644, mesh_id_get, mesh_id_set); > static DEVICE_ATTR(protocol_id, 0644, protocol_id_get, protocol_id_set); > static DEVICE_ATTR(metric_id, 0644, metric_id_get, metric_id_set); > @@ -373,6 +417,7 @@ static DEVICE_ATTR(capability, 0644, capability_get, capability_set); > static struct attribute *boot_opts_attrs[] = { > &dev_attr_bootflag.attr, > &dev_attr_boottime.attr, > + &dev_attr_channel.attr, > NULL > }; > > -- To unsubscribe from this list: send the line "unsubscribe linux-wireless" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html