Commit c26f1c10 authored by Linyu Yuan's avatar Linyu Yuan Committed by Greg Kroah-Hartman

usb: gadget: configfs: change config attributes file operation

in order to add trace event in configfs function with same
struct gadget_info *gi parameter,
add struct config_usb_cfg *cfg variable in below functions,
gadget_config_desc_MaxPower_show(),
gadget_config_desc_MaxPower_store(),
gadget_config_desc_bmAttributes_show(),
gadget_config_desc_bmAttributes_store(),
this allow following patch easy change cfg to gi with helper function
cfg_to_gadget_info().
Signed-off-by: default avatarLinyu Yuan <quic_linyyuan@quicinc.com>
Link: https://lore.kernel.org/r/1634649997-28745-3-git-send-email-quic_linyyuan@quicinc.comSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 260d88b7
...@@ -508,12 +508,15 @@ static struct configfs_item_operations gadget_config_item_ops = { ...@@ -508,12 +508,15 @@ static struct configfs_item_operations gadget_config_item_ops = {
static ssize_t gadget_config_desc_MaxPower_show(struct config_item *item, static ssize_t gadget_config_desc_MaxPower_show(struct config_item *item,
char *page) char *page)
{ {
return sprintf(page, "%u\n", to_config_usb_cfg(item)->c.MaxPower); struct config_usb_cfg *cfg = to_config_usb_cfg(item);
return sprintf(page, "%u\n", cfg->c.MaxPower);
} }
static ssize_t gadget_config_desc_MaxPower_store(struct config_item *item, static ssize_t gadget_config_desc_MaxPower_store(struct config_item *item,
const char *page, size_t len) const char *page, size_t len)
{ {
struct config_usb_cfg *cfg = to_config_usb_cfg(item);
u16 val; u16 val;
int ret; int ret;
ret = kstrtou16(page, 0, &val); ret = kstrtou16(page, 0, &val);
...@@ -521,20 +524,22 @@ static ssize_t gadget_config_desc_MaxPower_store(struct config_item *item, ...@@ -521,20 +524,22 @@ static ssize_t gadget_config_desc_MaxPower_store(struct config_item *item,
return ret; return ret;
if (DIV_ROUND_UP(val, 8) > 0xff) if (DIV_ROUND_UP(val, 8) > 0xff)
return -ERANGE; return -ERANGE;
to_config_usb_cfg(item)->c.MaxPower = val; cfg->c.MaxPower = val;
return len; return len;
} }
static ssize_t gadget_config_desc_bmAttributes_show(struct config_item *item, static ssize_t gadget_config_desc_bmAttributes_show(struct config_item *item,
char *page) char *page)
{ {
return sprintf(page, "0x%02x\n", struct config_usb_cfg *cfg = to_config_usb_cfg(item);
to_config_usb_cfg(item)->c.bmAttributes);
return sprintf(page, "0x%02x\n", cfg->c.bmAttributes);
} }
static ssize_t gadget_config_desc_bmAttributes_store(struct config_item *item, static ssize_t gadget_config_desc_bmAttributes_store(struct config_item *item,
const char *page, size_t len) const char *page, size_t len)
{ {
struct config_usb_cfg *cfg = to_config_usb_cfg(item);
u8 val; u8 val;
int ret; int ret;
ret = kstrtou8(page, 0, &val); ret = kstrtou8(page, 0, &val);
...@@ -545,7 +550,7 @@ static ssize_t gadget_config_desc_bmAttributes_store(struct config_item *item, ...@@ -545,7 +550,7 @@ static ssize_t gadget_config_desc_bmAttributes_store(struct config_item *item,
if (val & ~(USB_CONFIG_ATT_ONE | USB_CONFIG_ATT_SELFPOWER | if (val & ~(USB_CONFIG_ATT_ONE | USB_CONFIG_ATT_SELFPOWER |
USB_CONFIG_ATT_WAKEUP)) USB_CONFIG_ATT_WAKEUP))
return -EINVAL; return -EINVAL;
to_config_usb_cfg(item)->c.bmAttributes = val; cfg->c.bmAttributes = val;
return len; return len;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment