usb: cdns3: allocate TX FIFO size according to composite EP number
Some devices have USB compositions which may require multiple endpoints. To get better performance, need bigger CDNS3_EP_BUF_SIZE. But bigger CDNS3_EP_BUF_SIZE may exceed total hardware FIFO size when multiple endpoints. By introducing the check_config() callback, calculate CDNS3_EP_BUF_SIZE. Move CDNS3_EP_BUF_SIZE into cnds3_device: ep_buf_size Combine CDNS3_EP_ISO_SS_BURST and CDNS3_EP_ISO_HS_MULT into cnds3_device:ep_iso_burst Using a simple algorithm to calculate ep_buf_size. ep_buf_size = ep_iso_burst = (onchip_buffers - 2k) / (number of IN EP + 1). Test at 8qxp: Gadget ep_buf_size RNDIS: 5 RNDIS+ACM: 3 Mass Storage + NCM + ACM 2 Previous CDNS3_EP_BUF_SIZE is 4, RNDIS + ACM will be failure because exceed FIFO memory. Acked-by: Peter Chen <peter.chen@kernel.org> Signed-off-by: Frank Li <Frank.Li@nxp.com> Link: https://lore.kernel.org/r/20220509164055.1815081-1-Frank.Li@nxp.com Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
9d778f0c5f
commit
dce49449e0
@@ -562,15 +562,18 @@ struct cdns3_usb_regs {
|
||||
/* Max burst size (used only in SS mode). */
|
||||
#define EP_CFG_MAXBURST_MASK GENMASK(11, 8)
|
||||
#define EP_CFG_MAXBURST(p) (((p) << 8) & EP_CFG_MAXBURST_MASK)
|
||||
#define EP_CFG_MAXBURST_MAX 15
|
||||
/* ISO max burst. */
|
||||
#define EP_CFG_MULT_MASK GENMASK(15, 14)
|
||||
#define EP_CFG_MULT(p) (((p) << 14) & EP_CFG_MULT_MASK)
|
||||
#define EP_CFG_MULT_MAX 2
|
||||
/* ISO max burst. */
|
||||
#define EP_CFG_MAXPKTSIZE_MASK GENMASK(26, 16)
|
||||
#define EP_CFG_MAXPKTSIZE(p) (((p) << 16) & EP_CFG_MAXPKTSIZE_MASK)
|
||||
/* Max number of buffered packets. */
|
||||
#define EP_CFG_BUFFERING_MASK GENMASK(31, 27)
|
||||
#define EP_CFG_BUFFERING(p) (((p) << 27) & EP_CFG_BUFFERING_MASK)
|
||||
#define EP_CFG_BUFFERING_MAX 15
|
||||
|
||||
/* EP_CMD - bitmasks */
|
||||
/* Endpoint reset. */
|
||||
@@ -1094,9 +1097,6 @@ struct cdns3_trb {
|
||||
#define CDNS3_ENDPOINTS_MAX_COUNT 32
|
||||
#define CDNS3_EP_ZLP_BUF_SIZE 1024
|
||||
|
||||
#define CDNS3_EP_BUF_SIZE 4 /* KB */
|
||||
#define CDNS3_EP_ISO_HS_MULT 3
|
||||
#define CDNS3_EP_ISO_SS_BURST 3
|
||||
#define CDNS3_MAX_NUM_DESCMISS_BUF 32
|
||||
#define CDNS3_DESCMIS_BUF_SIZE 2048 /* Bytes */
|
||||
#define CDNS3_WA2_NUM_BUFFERS 128
|
||||
@@ -1333,6 +1333,9 @@ struct cdns3_device {
|
||||
/*in KB */
|
||||
u16 onchip_buffers;
|
||||
u16 onchip_used_size;
|
||||
|
||||
u16 ep_buf_size;
|
||||
u16 ep_iso_burst;
|
||||
};
|
||||
|
||||
void cdns3_set_register_bit(void __iomem *ptr, u32 mask);
|
||||
|
||||
Reference in New Issue
Block a user