This thread has been locked.

If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.

AM3356: How to keep the sdio clock always alive for wifi modules ?

Part Number: AM3356

Tool/software:

We used the chip am3356, and we connected a wifi module through the SDIO interface. In the process of speed measurement, we found that the rates of 11a and 11n were very poor. The manufacturer of the wifi module required our SDIO clock to keep alive all the time, so that the wifi module could be used normally. We measured the CLK of SDIO through the oscilloscope, which is not always alive as shown in the figure below. We tried to modify the following registers of am3356, but found that the clock of SDIO was still the same as before after setting. We need to find a way to keep sdio's clock always running.

In addition, the kernel versions we use are as follows

Linux 2010150827 4.19.94-gbe5389fd85 #48 PREEMPT Fri Jun 7 16:12:43 CST 2024 armv7l GNU/Linux

  • It looks like the bit you may want to update is this one here...

    Can you try setting this bit and see if this makes a difference. Then, to make the change permanent, you can patch the driver at drivers/mmc/host/sdhci-omap.c to include a section like the below in the driver's sdhci_omap_probe() function (towards the end of that function, before the return 0; statement)...

    reg = sdhci_omap_readl(omap_host, SDHCI_OMAP_CON);
    reg |= CON_CLKEXTFREE;
    sdhci_omap_writel(omap_host, SDHCI_OMAP_CON, reg);

    Regards, Andreas