usb: mtu3: add optional clock xhci_ck and frmcnt_ck
authorChunfeng Yun <chunfeng.yun@mediatek.com>
Mon, 17 Apr 2023 02:52:03 +0000 (10:52 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 20 Apr 2023 09:17:05 +0000 (11:17 +0200)
Add optional clock 'xhci_ck' which is usually the same as sys_ck, but
some SoC use two separated clocks when the controller supports dual
role mode;
Add optional clock 'frmcnt_ck' used on 4nm or advanced process SoC.

Signed-off-by: Chunfeng Yun <chunfeng.yun@mediatek.com>
Link: https://lore.kernel.org/r/20230417025203.18097-7-chunfeng.yun@mediatek.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/usb/mtu3/mtu3.h
drivers/usb/mtu3/mtu3_plat.c

index 2d7b57e07eee227fa56b142b30389d5dff900d95..b4a7662dded585178689eec269d3917ac2fa37d8 100644 (file)
@@ -90,7 +90,7 @@ struct mtu3_request;
  */
 #define EP0_RESPONSE_BUF  6
 
-#define BULK_CLKS_CNT  4
+#define BULK_CLKS_CNT  6
 
 /* device operated link and speed got from DEVICE_CONF register */
 enum mtu3_speed {
index d78ae52b4e2615eef0d90f3862598b933c1052d9..6f264b129243bb3e0413df716c4a71e827e49a36 100644 (file)
@@ -234,6 +234,8 @@ static int get_ssusb_rscs(struct platform_device *pdev, struct ssusb_mtk *ssusb)
        clks[1].id = "ref_ck";
        clks[2].id = "mcu_ck";
        clks[3].id = "dma_ck";
+       clks[4].id = "xhci_ck";
+       clks[5].id = "frmcnt_ck";
        ret = devm_clk_bulk_get_optional(dev, BULK_CLKS_CNT, clks);
        if (ret)
                return ret;