On 10/7/21 1:36 PM, Christian Hewitt wrote: >> >> On 7 Oct 2021, at 2:16 am, Jaehoon Chung <jh80.chung@xxxxxxxxxxx> wrote: >> >> Hi, >> >> On 10/1/21 10:41 PM, Christian Hewitt wrote: >>> >>>> On 1 Oct 2021, at 4:40 am, Jaehoon Chung <jh80.chung@xxxxxxxxxxx> wrote: >>>> >>>> On 9/27/21 8:09 PM, Krzysztof Kozlowski wrote: >>>>> On Mon, 13 Sept 2021 at 06:32, Christian Hewitt >>>>> <christianshewitt@xxxxxxxxx> wrote: >>>>>> >>>>>> https://protect2.fireeye.com/v1/url?k=6f7d4070-30e6793d-6f7ccb3f-0cc47aa8f5ba-2c8976d4b015314f&q=1&e=776d64d2-22f3-400a-a241-42af8b5f60d0&u=https%3A%2F%2Fgithub.com%2Fchewitt%2Flinux%2Fcommit%2F8a4ebfb43a394e5dc5e9fafc92a50d5e81a4f258 >>>>>> >>>>>> If I boot any recent kernel without the above patch, the emmc module on the XU4 is not detected, see: >>>>>> >>>>>> Without: >>>>>> >>>>>> [ 3.227837] mmc0: tuning execution failed: -5 >>>>>> [ 3.231229] mmc0: error -5 whilst initialising MMC card >>>>>> [ 3.536450] mmc0: tuning execution failed: -5 >>>>>> [ 3.539680] mmc0: error -5 whilst initialising MMC card >>>>>> [ 3.794056] mmc0: tuning execution failed: -5 >>>>>> [ 3.794212] mmc0: error -5 whilst initialising MMC card >>>>>> [ 4.111097] mmc0: tuning execution failed: -5 >>>>>> [ 4.115356] mmc0: error -5 whilst initialising MMC card >>>>>> [ 4.426164] mmc0: tuning execution failed: -5 >>>>>> [ 4.429678] mmc0: error -5 whilst initialising MMC card >>>>>> [ 4.756226] mmc0: tuning execution failed: -5 >>>>>> [ 4.760641] mmc0: error -5 whilst initialising MMC card >>>>>> >>>>>> With: >>>>>> >>>>>> [ 3.305461] mmc0: new HS400 MMC card at address 0001 >>>>>> [ 3.307444] mmcblk0: mmc0:0001 8GME4R 7.28 GiB >>>>>> [ 3.308132] mmcblk0boot0: mmc0:0001 8GME4R 4.00 MiB >>>>>> [ 3.309172] mmcblk0boot1: mmc0:0001 8GME4R 4.00 MiB >>>>>> [ 3.310255] mmcblk0rpmb: mmc0:0001 8GME4R 512 KiB, chardev (246:0) >>>>>> [ 3.315963] mmcblk0: p1 p2 >>>>>> >>>>>> The patch is sourced from a Linux 5.4 patchset used by several retro gaming distros for XU4 images shared in the HardKernel forums. I would be happy to submit it, but the original patch has no description in the commit message. Not being a coding developer myself I cannot explain whether it is correct or what it’s doing to add one. All I can do is confirm that it works, and is needed. SD card boot is not an issue. >>>>>> >>>>>> I’ve CC’d the original author (Marian) in case he remembers the patch and can comment. It would be good to get this upstream. >>>>> >>>>> The patch might have sense but would require describing conditions - >>>>> what MMC input and output clock settings work and which do not work. >>>>> Also someone would need to test other Exynos5422 boards and other >>>>> Exynos with HS200 and HS400 support (Exynos5433, Exynos7). I think >>>>> this should not affect SD cards. >>>> >>>> >>>> Thanks for adding me. >>>> I didn't see XU4 booting fail with linux-5.15-rc1 kernel. >>>> >>>> [ 4.561934] mmc1: new HS400 MMC card at address 0001 >>>> [ 4.572401] mmcblk1: mmc1:0001 SDW16G 14.7 GiB >>>> [ 4.602555] mmcblk1: p1 p2 p3 p4 < p5 p6 p7 > >>>> [ 4.623201] mmcblk1boot0: mmc1:0001 SDW16G 4.00 MiB >>>> [ 4.640465] mmcblk1boot1: mmc1:0001 SDW16G 4.00 MiB >>>> >>>> Which kernel version did you use? >>> >>> The original report is against 5.14.0, but I see the same with 5.15-rc3 >>> >>> dmesg: https://protect2.fireeye.com/v1/url?k=703ee5f5-2fa5dcb3-703f6eba-0cc47a3003e8-ad25e9061be78bbb&q=1&e=df3dbd0f-ccc7-40e0-b96a-1d47883a7f71&u=http%3A%2F%2Fix.io%2F3AuL >>> dmesg | grep mmc: https://protect2.fireeye.com/v1/url?k=5d2277f1-02b94eb7-5d23fcbe-0cc47a3003e8-b778cb8e233bbe4b&q=1&e=df3dbd0f-ccc7-40e0-b96a-1d47883a7f71&u=http%3A%2F%2Fix.io%2F3AuO >>> >>> And if I pick that patch to my kernel branch all is good: >>> >>> dmesg: https://protect2.fireeye.com/v1/url?k=8bcf7900-d4544046-8bcef24f-0cc47a3003e8-6124ad41dd642d56&q=1&e=df3dbd0f-ccc7-40e0-b96a-1d47883a7f71&u=http%3A%2F%2Fix.io%2F3Avf >>> dmesg | grep mmc: https://protect2.fireeye.com/v1/url?k=66ce5f96-395566d0-66cfd4d9-0cc47a3003e8-b9768331cc0e4416&q=1&e=df3dbd0f-ccc7-40e0-b96a-1d47883a7f71&u=http%3A%2F%2Fix.io%2F3Ave >>> >>> Here’s an SD (or eMMC) bootable image for an XU4 that exhibits the problem. You need to run “systemctl stop kodi” once the UART console is available else it attempts to run Kodi and Panfrost (the image is created for some Panfrost poking) currently wedges the board. Once the Kodi service is stopped “systemctl mask kodi” will prevent it from running again. >>> >>> https://protect2.fireeye.com/v1/url?k=b114ca54-ee8ff369-b115411b-0cc47a31309a-d8858f2897ed5521&q=1&e=addfcceb-9c68-4d7e-828c-344dd51262c2&u=https%3A%2F%2Fchewitt.libreelec.tv%2Ftesting%2FLibreELEC-Exynos.arm-10.0.0-odroid-xu4.img.gz >>> >>> Kernel defconfig for the image: https://protect2.fireeye.com/v1/url?k=806156b6-dffa6ff0-8060ddf9-0cc47a3003e8-b2bec8fd0863dc1b&q=1&e=df3dbd0f-ccc7-40e0-b96a-1d47883a7f71&u=http%3A%2F%2Fsprunge.us%2FG6uxty - basically the exynos config but with a wide variety of not-needed drivers (other SoCs, network cards, etc.) disabled. >>> >>> The board is booting from u-boot 2020.04 in case that matters. >> >> Thanks for sharing information. Sorry for replying late. I will check this problem on this week. >> It needs to satisfy all exynos5 SoCs. I just wonder why not working fine according to eMMC modules. > > No problem, I’ve been watching the thread :) > > This is the module I’m using https://protect2.fireeye.com/v1/url?k=991de2ef-c686dbd2-991c69a0-0cc47a31309a-1b07f48d5f69f8e8&q=1&e=addfcceb-9c68-4d7e-828c-344dd51262c2&u=https%3A%2F%2Fwww.hardkernel.com%2Fshop%2F8gb-emmc-module-h2%2F .. I can probably organise one to be shipped to you if needed. Thanks for sharing eMMC module information. I will order it. https://protect2.fireeye.com/v1/url?k=6f7d4070-30e6793d-6f7ccb3f-0cc47aa8f5ba-2c8976d4b015314f&q=1&e=776d64d2-22f3-400a-a241-42af8b5f60d0&u=https%3A%2F%2Fgithub.com%2Fchewitt%2Flinux%2Fcommit%2F8a4ebfb43a394e5dc5e9fafc92a50d5e81a4f258 And When I have been checked the code, it seems that changing CLK_DIV value to 2 is not correct. (It's workaround to just work.) Maybe, it seems that phase is not a proper value about its eMMC. (After getting eMMC module, I can check in more detail.) Best Regards, Jaehoon Chung > > Christian >