Commit 60e7396f authored by Yoshihiro Shimoda's avatar Yoshihiro Shimoda Committed by Felipe Balbi

usb: gadget: add a new quirk to avoid skb_reserve in u_ether.c

Some platforms (e.g. USB-DMAC on R-Car SoCs) has memory alignment
restriction. If memory alignment is not match, the usb peripheral
driver decides not to use the DMA controller. Then, the performance
is not good.

In the case of u_ether.c, since it calls skb_reserve() in rx_submit(),
it is possible to cause memory alignment mismatch.

So, this patch adds a new quirk "quirk_avoids_skb_reserve" to avoid
skb_reserve() calling in u_ether.c to improve performance.

A peripheral driver will set this flag and network gadget drivers
(e.g. f_ncm.c) will reference the flag via gadget_avoids_skb_reserve().
Signed-off-by: default avatarYoshihiro Shimoda <yoshihiro.shimoda.uh@renesas.com>
Signed-off-by: default avatarFelipe Balbi <felipe.balbi@linux.intel.com>
parent a00c9791
...@@ -346,6 +346,8 @@ struct usb_gadget_ops { ...@@ -346,6 +346,8 @@ struct usb_gadget_ops {
* or B-Peripheral wants to take host role. * or B-Peripheral wants to take host role.
* @quirk_ep_out_aligned_size: epout requires buffer size to be aligned to * @quirk_ep_out_aligned_size: epout requires buffer size to be aligned to
* MaxPacketSize. * MaxPacketSize.
* @quirk_avoids_skb_reserve: udc/platform wants to avoid skb_reserve() in
* u_ether.c to improve performance.
* @is_selfpowered: if the gadget is self-powered. * @is_selfpowered: if the gadget is self-powered.
* @deactivated: True if gadget is deactivated - in deactivated state it cannot * @deactivated: True if gadget is deactivated - in deactivated state it cannot
* be connected. * be connected.
...@@ -398,6 +400,7 @@ struct usb_gadget { ...@@ -398,6 +400,7 @@ struct usb_gadget {
unsigned quirk_altset_not_supp:1; unsigned quirk_altset_not_supp:1;
unsigned quirk_stall_not_supp:1; unsigned quirk_stall_not_supp:1;
unsigned quirk_zlp_not_supp:1; unsigned quirk_zlp_not_supp:1;
unsigned quirk_avoids_skb_reserve:1;
unsigned is_selfpowered:1; unsigned is_selfpowered:1;
unsigned deactivated:1; unsigned deactivated:1;
unsigned connected:1; unsigned connected:1;
...@@ -473,6 +476,16 @@ static inline int gadget_is_zlp_supported(struct usb_gadget *g) ...@@ -473,6 +476,16 @@ static inline int gadget_is_zlp_supported(struct usb_gadget *g)
return !g->quirk_zlp_not_supp; return !g->quirk_zlp_not_supp;
} }
/**
* gadget_avoids_skb_reserve - return true iff the hardware would like to avoid
* skb_reserve to improve performance.
* @g: controller to check for quirk
*/
static inline int gadget_avoids_skb_reserve(struct usb_gadget *g)
{
return g->quirk_avoids_skb_reserve;
}
/** /**
* gadget_is_dualspeed - return true iff the hardware handles high speed * gadget_is_dualspeed - return true iff the hardware handles high speed
* @g: controller that might support both high and full speeds * @g: controller that might support both high and full speeds
......
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