> -----Original Message----- > From: Thinh Nguyen <Thinh.Nguyen@xxxxxxxxxxxx> > Sent: Saturday, February 24, 2024 4:38 AM > To: Pandey, Radhey Shyam <radhey.shyam.pandey@xxxxxxx> > Cc: gregkh@xxxxxxxxxxxxxxxxxxx; linux-usb@xxxxxxxxxxxxxxx; linux- > kernel@xxxxxxxxxxxxxxx; git (AMD-Xilinx) <git@xxxxxxx> > Subject: Re: [PATCH v2] usb: dwc3: core: enable CCI support for AMD-xilinx > DWC3 controller > > On Fri, Feb 23, 2024, Thinh Nguyen wrote: > > On Sat, Feb 24, 2024, Radhey Shyam Pandey wrote: > > > From: Piyush Mehta <piyush.mehta@xxxxxxx> > > > > > > The GSBUSCFG0 register bits [31:16] are used to configure the cache type > > > settings of the descriptor and data write/read transfers (Cacheable, > > > Bufferable/ Posted). When CCI is enabled in the design, DWC3 core > GSBUSCFG0 > > > cache bits must be updated to support CCI enabled transfers in USB. > > > > > > Signed-off-by: Piyush Mehta <piyush.mehta@xxxxxxx> > > > Signed-off-by: Radhey Shyam Pandey > <radhey.shyam.pandey@xxxxxxx> > > > ---- > > > changes for v2: > > > Make GSBUSCFG0 configuration specific to AMD-xilinx platform. > > > Taken reference from existing commit ec5eb43813a4 ("usb: dwc3: core: > > > add support for realtek SoCs custom's global register start address") > > Regarding that change from Realtek, it's a special case. I want to avoid > doing platform specific checks in the core.c if possible. Eventually, I > want to move that logic from Realtek to its glue driver. > > BR, > Thinh Thanks. As you suggested I tried "temporarily memory map and update this register in your Xilinx glue driver. Its value should retain after soft reset". Did ioremap for core register space once again in glue driver but it resulted in below error: dwc3 fe200000.usb: can't request region for resource [mem 0xfe200000-0xfe23ffff] dwc3-xilinx ff9d0000.usb: error -EBUSY: failed to map DWC3 registers So to avoid remapping, now get the struct dwc3 platform data handle in glue driver and pass it to dwc3_readl/writel() like the below sequence. Is that fine? If yes I will respin v3 with these changes and also do some more sanity tests. drivers/usb/dwc3/dwc3-xilinx.c #include "io.h" <snip> ret = of_platform_populate(np, NULL, NULL, dev); if (ret) { dev_err(dev, "failed to register dwc3 core - %d\n", ret); goto err_clk_put; } dwc3_np = of_get_compatible_child(np, "snps,dwc3"); priv_data->dwc3 = of_find_device_by_node(dwc3_np); dwc = platform_get_drvdata(priv_data->dwc3); if (of_dma_is_coherent(dev->of_node)) { reg = dwc3_readl(dwc->regs , DWC3_GSBUSCFG0); reg |= DWC3_GSBUSCFG0_DATRDREQINFO_MASK | DWC3_GSBUSCFG0_DESRDREQINFO_MASK | DWC3_GSBUSCFG0_DATWRREQINFO_MASK | DWC3_GSBUSCFG0_DESWRREQINFO_MASK; dwc3_writel(dwc->regs , DWC3_GSBUSCFG0, reg); } Thanks, Radhey