Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

clk: qcom: Fully support apq8064 global clock control

Add in the handful of new clocks and introduce a new reset table
with the few new resets.

Signed-off-by: Stephen Boyd <sboyd@codeaurora.org>

+596 -4
+569 -4
drivers/clk/qcom/gcc-msm8960.c
··· 104 104 105 105 #define P_PXO 0 106 106 #define P_PLL8 1 107 + #define P_PLL3 2 107 108 #define P_CXO 2 108 109 109 110 static const u8 gcc_pxo_pll8_map[] = { ··· 127 126 "pxo", 128 127 "pll8_vote", 129 128 "cxo", 129 + }; 130 + 131 + static const u8 gcc_pxo_pll8_pll3_map[] = { 132 + [P_PXO] = 0, 133 + [P_PLL8] = 3, 134 + [P_PLL3] = 6, 135 + }; 136 + 137 + static const char *gcc_pxo_pll8_pll3[] = { 138 + "pxo", 139 + "pll8_vote", 140 + "pll3", 130 141 }; 131 142 132 143 static struct freq_tbl clk_tbl_gsbi_uart[] = { ··· 1941 1928 }, 1942 1929 }; 1943 1930 1931 + static struct clk_rcg usb_hs3_xcvr_src = { 1932 + .ns_reg = 0x370c, 1933 + .md_reg = 0x3708, 1934 + .mn = { 1935 + .mnctr_en_bit = 8, 1936 + .mnctr_reset_bit = 7, 1937 + .mnctr_mode_shift = 5, 1938 + .n_val_shift = 16, 1939 + .m_val_shift = 16, 1940 + .width = 8, 1941 + }, 1942 + .p = { 1943 + .pre_div_shift = 3, 1944 + .pre_div_width = 2, 1945 + }, 1946 + .s = { 1947 + .src_sel_shift = 0, 1948 + .parent_map = gcc_pxo_pll8_map, 1949 + }, 1950 + .freq_tbl = clk_tbl_usb, 1951 + .clkr = { 1952 + .enable_reg = 0x370c, 1953 + .enable_mask = BIT(11), 1954 + .hw.init = &(struct clk_init_data){ 1955 + .name = "usb_hs3_xcvr_src", 1956 + .parent_names = gcc_pxo_pll8, 1957 + .num_parents = 2, 1958 + .ops = &clk_rcg_ops, 1959 + .flags = CLK_SET_RATE_GATE, 1960 + }, 1961 + } 1962 + }; 1963 + 1964 + static struct clk_branch usb_hs3_xcvr_clk = { 1965 + .halt_reg = 0x2fc8, 1966 + .halt_bit = 30, 1967 + .clkr = { 1968 + .enable_reg = 0x370c, 1969 + .enable_mask = BIT(9), 1970 + .hw.init = &(struct clk_init_data){ 1971 + .name = "usb_hs3_xcvr_clk", 1972 + .parent_names = (const char *[]){ "usb_hs3_xcvr_src" }, 1973 + .num_parents = 1, 1974 + .ops = &clk_branch_ops, 1975 + .flags = CLK_SET_RATE_PARENT, 1976 + }, 1977 + }, 1978 + }; 1979 + 1980 + static struct clk_rcg usb_hs4_xcvr_src = { 1981 + .ns_reg = 0x372c, 1982 + .md_reg = 0x3728, 1983 + .mn = { 1984 + .mnctr_en_bit = 8, 1985 + .mnctr_reset_bit = 7, 1986 + .mnctr_mode_shift = 5, 1987 + .n_val_shift = 16, 1988 + .m_val_shift = 16, 1989 + .width = 8, 1990 + }, 1991 + .p = { 1992 + .pre_div_shift = 3, 1993 + .pre_div_width = 2, 1994 + }, 1995 + .s = { 1996 + .src_sel_shift = 0, 1997 + .parent_map = gcc_pxo_pll8_map, 1998 + }, 1999 + .freq_tbl = clk_tbl_usb, 2000 + .clkr = { 2001 + .enable_reg = 0x372c, 2002 + .enable_mask = BIT(11), 2003 + .hw.init = &(struct clk_init_data){ 2004 + .name = "usb_hs4_xcvr_src", 2005 + .parent_names = gcc_pxo_pll8, 2006 + .num_parents = 2, 2007 + .ops = &clk_rcg_ops, 2008 + .flags = CLK_SET_RATE_GATE, 2009 + }, 2010 + } 2011 + }; 2012 + 2013 + static struct clk_branch usb_hs4_xcvr_clk = { 2014 + .halt_reg = 0x2fc8, 2015 + .halt_bit = 2, 2016 + .clkr = { 2017 + .enable_reg = 0x372c, 2018 + .enable_mask = BIT(9), 2019 + .hw.init = &(struct clk_init_data){ 2020 + .name = "usb_hs4_xcvr_clk", 2021 + .parent_names = (const char *[]){ "usb_hs4_xcvr_src" }, 2022 + .num_parents = 1, 2023 + .ops = &clk_branch_ops, 2024 + .flags = CLK_SET_RATE_PARENT, 2025 + }, 2026 + }, 2027 + }; 2028 + 1944 2029 static struct clk_rcg usb_hsic_xcvr_fs_src = { 1945 2030 .ns_reg = 0x2928, 1946 2031 .md_reg = 0x2924, ··· 2567 2456 }, 2568 2457 }; 2569 2458 2459 + static struct clk_branch usb_hs3_h_clk = { 2460 + .halt_reg = 0x2fc8, 2461 + .halt_bit = 31, 2462 + .clkr = { 2463 + .enable_reg = 0x3700, 2464 + .enable_mask = BIT(4), 2465 + .hw.init = &(struct clk_init_data){ 2466 + .name = "usb_hs3_h_clk", 2467 + .ops = &clk_branch_ops, 2468 + .flags = CLK_IS_ROOT, 2469 + }, 2470 + }, 2471 + }; 2472 + 2473 + static struct clk_branch usb_hs4_h_clk = { 2474 + .halt_reg = 0x2fc8, 2475 + .halt_bit = 7, 2476 + .clkr = { 2477 + .enable_reg = 0x3720, 2478 + .enable_mask = BIT(4), 2479 + .hw.init = &(struct clk_init_data){ 2480 + .name = "usb_hs4_h_clk", 2481 + .ops = &clk_branch_ops, 2482 + .flags = CLK_IS_ROOT, 2483 + }, 2484 + }, 2485 + }; 2486 + 2570 2487 static struct clk_branch usb_hsic_h_clk = { 2571 2488 .halt_reg = 0x2fcc, 2572 2489 .halt_bit = 28, ··· 2715 2576 .enable_mask = BIT(3), 2716 2577 .hw.init = &(struct clk_init_data){ 2717 2578 .name = "adm0_pbus_clk", 2579 + .ops = &clk_branch_ops, 2580 + .flags = CLK_IS_ROOT, 2581 + }, 2582 + }, 2583 + }; 2584 + 2585 + static struct freq_tbl clk_tbl_ce3[] = { 2586 + { 48000000, P_PLL8, 8 }, 2587 + { 100000000, P_PLL3, 12 }, 2588 + { 120000000, P_PLL3, 10 }, 2589 + { } 2590 + }; 2591 + 2592 + static struct clk_rcg ce3_src = { 2593 + .ns_reg = 0x36c0, 2594 + .p = { 2595 + .pre_div_shift = 3, 2596 + .pre_div_width = 4, 2597 + }, 2598 + .s = { 2599 + .src_sel_shift = 0, 2600 + .parent_map = gcc_pxo_pll8_pll3_map, 2601 + }, 2602 + .freq_tbl = clk_tbl_ce3, 2603 + .clkr = { 2604 + .enable_reg = 0x2c08, 2605 + .enable_mask = BIT(7), 2606 + .hw.init = &(struct clk_init_data){ 2607 + .name = "ce3_src", 2608 + .parent_names = gcc_pxo_pll8_pll3, 2609 + .num_parents = 3, 2610 + .ops = &clk_rcg_ops, 2611 + .flags = CLK_SET_RATE_GATE, 2612 + }, 2613 + }, 2614 + }; 2615 + 2616 + static struct clk_branch ce3_core_clk = { 2617 + .halt_reg = 0x2fdc, 2618 + .halt_bit = 5, 2619 + .clkr = { 2620 + .enable_reg = 0x36c4, 2621 + .enable_mask = BIT(4), 2622 + .hw.init = &(struct clk_init_data){ 2623 + .name = "ce3_core_clk", 2624 + .parent_names = (const char *[]){ "ce3_src" }, 2625 + .num_parents = 1, 2626 + .ops = &clk_branch_ops, 2627 + .flags = CLK_SET_RATE_PARENT, 2628 + }, 2629 + }, 2630 + }; 2631 + 2632 + static struct clk_branch ce3_h_clk = { 2633 + .halt_reg = 0x2fc4, 2634 + .halt_bit = 16, 2635 + .clkr = { 2636 + .enable_reg = 0x36c4, 2637 + .enable_mask = BIT(4), 2638 + .hw.init = &(struct clk_init_data){ 2639 + .name = "ce3_h_clk", 2640 + .parent_names = (const char *[]){ "ce3_src" }, 2641 + .num_parents = 1, 2642 + .ops = &clk_branch_ops, 2643 + .flags = CLK_SET_RATE_PARENT, 2644 + }, 2645 + }, 2646 + }; 2647 + 2648 + static const struct freq_tbl clk_tbl_sata_ref[] = { 2649 + { 48000000, P_PLL8, 8, 0, 0 }, 2650 + { 100000000, P_PLL3, 12, 0, 0 }, 2651 + { } 2652 + }; 2653 + 2654 + static struct clk_rcg sata_clk_src = { 2655 + .ns_reg = 0x2c08, 2656 + .p = { 2657 + .pre_div_shift = 3, 2658 + .pre_div_width = 4, 2659 + }, 2660 + .s = { 2661 + .src_sel_shift = 0, 2662 + .parent_map = gcc_pxo_pll8_pll3_map, 2663 + }, 2664 + .freq_tbl = clk_tbl_sata_ref, 2665 + .clkr = { 2666 + .enable_reg = 0x2c08, 2667 + .enable_mask = BIT(7), 2668 + .hw.init = &(struct clk_init_data){ 2669 + .name = "sata_clk_src", 2670 + .parent_names = gcc_pxo_pll8_pll3, 2671 + .num_parents = 3, 2672 + .ops = &clk_rcg_ops, 2673 + .flags = CLK_SET_RATE_GATE, 2674 + }, 2675 + }, 2676 + }; 2677 + 2678 + static struct clk_branch sata_rxoob_clk = { 2679 + .halt_reg = 0x2fdc, 2680 + .halt_bit = 26, 2681 + .clkr = { 2682 + .enable_reg = 0x2c0c, 2683 + .enable_mask = BIT(4), 2684 + .hw.init = &(struct clk_init_data){ 2685 + .name = "sata_rxoob_clk", 2686 + .parent_names = (const char *[]){ "sata_clk_src" }, 2687 + .num_parents = 1, 2688 + .ops = &clk_branch_ops, 2689 + .flags = CLK_SET_RATE_PARENT, 2690 + }, 2691 + }, 2692 + }; 2693 + 2694 + static struct clk_branch sata_pmalive_clk = { 2695 + .halt_reg = 0x2fdc, 2696 + .halt_bit = 25, 2697 + .clkr = { 2698 + .enable_reg = 0x2c10, 2699 + .enable_mask = BIT(4), 2700 + .hw.init = &(struct clk_init_data){ 2701 + .name = "sata_pmalive_clk", 2702 + .parent_names = (const char *[]){ "sata_clk_src" }, 2703 + .num_parents = 1, 2704 + .ops = &clk_branch_ops, 2705 + .flags = CLK_SET_RATE_PARENT, 2706 + }, 2707 + }, 2708 + }; 2709 + 2710 + static struct clk_branch sata_phy_ref_clk = { 2711 + .halt_reg = 0x2fdc, 2712 + .halt_bit = 24, 2713 + .clkr = { 2714 + .enable_reg = 0x2c14, 2715 + .enable_mask = BIT(4), 2716 + .hw.init = &(struct clk_init_data){ 2717 + .name = "sata_phy_ref_clk", 2718 + .parent_names = (const char *[]){ "pxo" }, 2719 + .num_parents = 1, 2720 + .ops = &clk_branch_ops, 2721 + }, 2722 + }, 2723 + }; 2724 + 2725 + static struct clk_branch sata_a_clk = { 2726 + .halt_reg = 0x2fc0, 2727 + .halt_bit = 12, 2728 + .clkr = { 2729 + .enable_reg = 0x2c20, 2730 + .enable_mask = BIT(4), 2731 + .hw.init = &(struct clk_init_data){ 2732 + .name = "sata_a_clk", 2733 + .ops = &clk_branch_ops, 2734 + .flags = CLK_IS_ROOT, 2735 + }, 2736 + }, 2737 + }; 2738 + 2739 + static struct clk_branch sata_h_clk = { 2740 + .halt_reg = 0x2fdc, 2741 + .halt_bit = 27, 2742 + .clkr = { 2743 + .enable_reg = 0x2c00, 2744 + .enable_mask = BIT(4), 2745 + .hw.init = &(struct clk_init_data){ 2746 + .name = "sata_h_clk", 2747 + .ops = &clk_branch_ops, 2748 + .flags = CLK_IS_ROOT, 2749 + }, 2750 + }, 2751 + }; 2752 + 2753 + static struct clk_branch sfab_sata_s_h_clk = { 2754 + .halt_reg = 0x2fc4, 2755 + .halt_bit = 14, 2756 + .clkr = { 2757 + .enable_reg = 0x2480, 2758 + .enable_mask = BIT(4), 2759 + .hw.init = &(struct clk_init_data){ 2760 + .name = "sfab_sata_s_h_clk", 2761 + .ops = &clk_branch_ops, 2762 + .flags = CLK_IS_ROOT, 2763 + }, 2764 + }, 2765 + }; 2766 + 2767 + static struct clk_branch sata_phy_cfg_clk = { 2768 + .halt_reg = 0x2fcc, 2769 + .halt_bit = 12, 2770 + .clkr = { 2771 + .enable_reg = 0x2c40, 2772 + .enable_mask = BIT(4), 2773 + .hw.init = &(struct clk_init_data){ 2774 + .name = "sata_phy_cfg_clk", 2775 + .ops = &clk_branch_ops, 2776 + .flags = CLK_IS_ROOT, 2777 + }, 2778 + }, 2779 + }; 2780 + 2781 + static struct clk_branch pcie_phy_ref_clk = { 2782 + .halt_reg = 0x2fdc, 2783 + .halt_bit = 29, 2784 + .clkr = { 2785 + .enable_reg = 0x22d0, 2786 + .enable_mask = BIT(4), 2787 + .hw.init = &(struct clk_init_data){ 2788 + .name = "pcie_phy_ref_clk", 2789 + .ops = &clk_branch_ops, 2790 + .flags = CLK_IS_ROOT, 2791 + }, 2792 + }, 2793 + }; 2794 + 2795 + static struct clk_branch pcie_h_clk = { 2796 + .halt_reg = 0x2fd4, 2797 + .halt_bit = 8, 2798 + .clkr = { 2799 + .enable_reg = 0x22cc, 2800 + .enable_mask = BIT(4), 2801 + .hw.init = &(struct clk_init_data){ 2802 + .name = "pcie_h_clk", 2803 + .ops = &clk_branch_ops, 2804 + .flags = CLK_IS_ROOT, 2805 + }, 2806 + }, 2807 + }; 2808 + 2809 + static struct clk_branch pcie_a_clk = { 2810 + .halt_reg = 0x2fc0, 2811 + .halt_bit = 13, 2812 + .clkr = { 2813 + .enable_reg = 0x22c0, 2814 + .enable_mask = BIT(4), 2815 + .hw.init = &(struct clk_init_data){ 2816 + .name = "pcie_a_clk", 2718 2817 .ops = &clk_branch_ops, 2719 2818 .flags = CLK_IS_ROOT, 2720 2819 }, ··· 3246 2869 }; 3247 2870 3248 2871 static struct clk_regmap *gcc_apq8064_clks[] = { 2872 + [PLL3] = &pll3.clkr, 3249 2873 [PLL8] = &pll8.clkr, 3250 2874 [PLL8_VOTE] = &pll8_vote, 2875 + [PLL14] = &pll14.clkr, 2876 + [PLL14_VOTE] = &pll14_vote, 2877 + [GSBI1_UART_SRC] = &gsbi1_uart_src.clkr, 2878 + [GSBI1_UART_CLK] = &gsbi1_uart_clk.clkr, 2879 + [GSBI2_UART_SRC] = &gsbi2_uart_src.clkr, 2880 + [GSBI2_UART_CLK] = &gsbi2_uart_clk.clkr, 2881 + [GSBI3_UART_SRC] = &gsbi3_uart_src.clkr, 2882 + [GSBI3_UART_CLK] = &gsbi3_uart_clk.clkr, 2883 + [GSBI4_UART_SRC] = &gsbi4_uart_src.clkr, 2884 + [GSBI4_UART_CLK] = &gsbi4_uart_clk.clkr, 2885 + [GSBI5_UART_SRC] = &gsbi5_uart_src.clkr, 2886 + [GSBI5_UART_CLK] = &gsbi5_uart_clk.clkr, 2887 + [GSBI6_UART_SRC] = &gsbi6_uart_src.clkr, 2888 + [GSBI6_UART_CLK] = &gsbi6_uart_clk.clkr, 3251 2889 [GSBI7_UART_SRC] = &gsbi7_uart_src.clkr, 3252 2890 [GSBI7_UART_CLK] = &gsbi7_uart_clk.clkr, 2891 + [GSBI1_QUP_SRC] = &gsbi1_qup_src.clkr, 2892 + [GSBI1_QUP_CLK] = &gsbi1_qup_clk.clkr, 2893 + [GSBI2_QUP_SRC] = &gsbi2_qup_src.clkr, 2894 + [GSBI2_QUP_CLK] = &gsbi2_qup_clk.clkr, 2895 + [GSBI3_QUP_SRC] = &gsbi3_qup_src.clkr, 2896 + [GSBI3_QUP_CLK] = &gsbi3_qup_clk.clkr, 2897 + [GSBI4_QUP_SRC] = &gsbi4_qup_src.clkr, 2898 + [GSBI4_QUP_CLK] = &gsbi4_qup_clk.clkr, 2899 + [GSBI5_QUP_SRC] = &gsbi5_qup_src.clkr, 2900 + [GSBI5_QUP_CLK] = &gsbi5_qup_clk.clkr, 2901 + [GSBI6_QUP_SRC] = &gsbi6_qup_src.clkr, 2902 + [GSBI6_QUP_CLK] = &gsbi6_qup_clk.clkr, 3253 2903 [GSBI7_QUP_SRC] = &gsbi7_qup_src.clkr, 3254 2904 [GSBI7_QUP_CLK] = &gsbi7_qup_clk.clkr, 3255 - [GSBI7_H_CLK] = &gsbi7_h_clk.clkr, 2905 + [GP0_SRC] = &gp0_src.clkr, 2906 + [GP0_CLK] = &gp0_clk.clkr, 2907 + [GP1_SRC] = &gp1_src.clkr, 2908 + [GP1_CLK] = &gp1_clk.clkr, 2909 + [GP2_SRC] = &gp2_src.clkr, 2910 + [GP2_CLK] = &gp2_clk.clkr, 2911 + [PMEM_A_CLK] = &pmem_clk.clkr, 2912 + [PRNG_SRC] = &prng_src.clkr, 2913 + [PRNG_CLK] = &prng_clk.clkr, 3256 2914 [SDC1_SRC] = &sdc1_src.clkr, 3257 2915 [SDC1_CLK] = &sdc1_clk.clkr, 3258 2916 [SDC2_SRC] = &sdc2_src.clkr, ··· 3296 2884 [SDC3_CLK] = &sdc3_clk.clkr, 3297 2885 [SDC4_SRC] = &sdc4_src.clkr, 3298 2886 [SDC4_CLK] = &sdc4_clk.clkr, 2887 + [TSIF_REF_SRC] = &tsif_ref_src.clkr, 2888 + [TSIF_REF_CLK] = &tsif_ref_clk.clkr, 2889 + [USB_HS1_XCVR_SRC] = &usb_hs1_xcvr_src.clkr, 2890 + [USB_HS1_XCVR_CLK] = &usb_hs1_xcvr_clk.clkr, 2891 + [USB_HS3_XCVR_SRC] = &usb_hs3_xcvr_src.clkr, 2892 + [USB_HS3_XCVR_CLK] = &usb_hs3_xcvr_clk.clkr, 2893 + [USB_HS4_XCVR_SRC] = &usb_hs4_xcvr_src.clkr, 2894 + [USB_HS4_XCVR_CLK] = &usb_hs4_xcvr_clk.clkr, 2895 + [USB_HSIC_XCVR_FS_SRC] = &usb_hsic_xcvr_fs_src.clkr, 2896 + [USB_HSIC_XCVR_FS_CLK] = &usb_hsic_xcvr_fs_clk.clkr, 2897 + [USB_HSIC_SYSTEM_CLK] = &usb_hsic_system_clk.clkr, 2898 + [USB_HSIC_HSIC_CLK] = &usb_hsic_hsic_clk.clkr, 2899 + [USB_HSIC_HSIO_CAL_CLK] = &usb_hsic_hsio_cal_clk.clkr, 2900 + [USB_FS1_XCVR_FS_SRC] = &usb_fs1_xcvr_fs_src.clkr, 2901 + [USB_FS1_XCVR_FS_CLK] = &usb_fs1_xcvr_fs_clk.clkr, 2902 + [USB_FS1_SYSTEM_CLK] = &usb_fs1_system_clk.clkr, 2903 + [SATA_H_CLK] = &sata_h_clk.clkr, 2904 + [SATA_CLK_SRC] = &sata_clk_src.clkr, 2905 + [SATA_RXOOB_CLK] = &sata_rxoob_clk.clkr, 2906 + [SATA_PMALIVE_CLK] = &sata_pmalive_clk.clkr, 2907 + [SATA_PHY_REF_CLK] = &sata_phy_ref_clk.clkr, 2908 + [SATA_PHY_CFG_CLK] = &sata_phy_cfg_clk.clkr, 2909 + [SATA_A_CLK] = &sata_a_clk.clkr, 2910 + [SFAB_SATA_S_H_CLK] = &sfab_sata_s_h_clk.clkr, 2911 + [CE3_SRC] = &ce3_src.clkr, 2912 + [CE3_CORE_CLK] = &ce3_core_clk.clkr, 2913 + [CE3_H_CLK] = &ce3_h_clk.clkr, 2914 + [DMA_BAM_H_CLK] = &dma_bam_h_clk.clkr, 2915 + [GSBI1_H_CLK] = &gsbi1_h_clk.clkr, 2916 + [GSBI2_H_CLK] = &gsbi2_h_clk.clkr, 2917 + [GSBI3_H_CLK] = &gsbi3_h_clk.clkr, 2918 + [GSBI4_H_CLK] = &gsbi4_h_clk.clkr, 2919 + [GSBI5_H_CLK] = &gsbi5_h_clk.clkr, 2920 + [GSBI6_H_CLK] = &gsbi6_h_clk.clkr, 2921 + [GSBI7_H_CLK] = &gsbi7_h_clk.clkr, 2922 + [TSIF_H_CLK] = &tsif_h_clk.clkr, 2923 + [USB_FS1_H_CLK] = &usb_fs1_h_clk.clkr, 2924 + [USB_HS1_H_CLK] = &usb_hs1_h_clk.clkr, 2925 + [USB_HSIC_H_CLK] = &usb_hsic_h_clk.clkr, 2926 + [USB_HS3_H_CLK] = &usb_hs3_h_clk.clkr, 2927 + [USB_HS4_H_CLK] = &usb_hs4_h_clk.clkr, 3299 2928 [SDC1_H_CLK] = &sdc1_h_clk.clkr, 3300 2929 [SDC2_H_CLK] = &sdc2_h_clk.clkr, 3301 2930 [SDC3_H_CLK] = &sdc3_h_clk.clkr, 3302 2931 [SDC4_H_CLK] = &sdc4_h_clk.clkr, 2932 + [ADM0_CLK] = &adm0_clk.clkr, 2933 + [ADM0_PBUS_CLK] = &adm0_pbus_clk.clkr, 2934 + [PCIE_A_CLK] = &pcie_a_clk.clkr, 2935 + [PCIE_PHY_REF_CLK] = &pcie_phy_ref_clk.clkr, 2936 + [PCIE_H_CLK] = &pcie_h_clk.clkr, 2937 + [PMIC_ARB0_H_CLK] = &pmic_arb0_h_clk.clkr, 2938 + [PMIC_ARB1_H_CLK] = &pmic_arb1_h_clk.clkr, 2939 + [PMIC_SSBI2_CLK] = &pmic_ssbi2_clk.clkr, 2940 + [RPM_MSG_RAM_H_CLK] = &rpm_msg_ram_h_clk.clkr, 2941 + }; 2942 + 2943 + static const struct qcom_reset_map gcc_apq8064_resets[] = { 2944 + [QDSS_STM_RESET] = { 0x2060, 6 }, 2945 + [AFAB_SMPSS_S_RESET] = { 0x20b8, 2 }, 2946 + [AFAB_SMPSS_M1_RESET] = { 0x20b8, 1 }, 2947 + [AFAB_SMPSS_M0_RESET] = { 0x20b8 }, 2948 + [AFAB_EBI1_CH0_RESET] = { 0x20c0, 7 }, 2949 + [AFAB_EBI1_CH1_RESET] = { 0x20c4, 7}, 2950 + [SFAB_ADM0_M0_RESET] = { 0x21e0, 7 }, 2951 + [SFAB_ADM0_M1_RESET] = { 0x21e4, 7 }, 2952 + [SFAB_ADM0_M2_RESET] = { 0x21e8, 7 }, 2953 + [ADM0_C2_RESET] = { 0x220c, 4}, 2954 + [ADM0_C1_RESET] = { 0x220c, 3}, 2955 + [ADM0_C0_RESET] = { 0x220c, 2}, 2956 + [ADM0_PBUS_RESET] = { 0x220c, 1 }, 2957 + [ADM0_RESET] = { 0x220c }, 2958 + [QDSS_CLKS_SW_RESET] = { 0x2260, 5 }, 2959 + [QDSS_POR_RESET] = { 0x2260, 4 }, 2960 + [QDSS_TSCTR_RESET] = { 0x2260, 3 }, 2961 + [QDSS_HRESET_RESET] = { 0x2260, 2 }, 2962 + [QDSS_AXI_RESET] = { 0x2260, 1 }, 2963 + [QDSS_DBG_RESET] = { 0x2260 }, 2964 + [SFAB_PCIE_M_RESET] = { 0x22d8, 1 }, 2965 + [SFAB_PCIE_S_RESET] = { 0x22d8 }, 2966 + [PCIE_EXT_PCI_RESET] = { 0x22dc, 6 }, 2967 + [PCIE_PHY_RESET] = { 0x22dc, 5 }, 2968 + [PCIE_PCI_RESET] = { 0x22dc, 4 }, 2969 + [PCIE_POR_RESET] = { 0x22dc, 3 }, 2970 + [PCIE_HCLK_RESET] = { 0x22dc, 2 }, 2971 + [PCIE_ACLK_RESET] = { 0x22dc }, 2972 + [SFAB_USB3_M_RESET] = { 0x2360, 7 }, 2973 + [SFAB_RIVA_M_RESET] = { 0x2380, 7 }, 2974 + [SFAB_LPASS_RESET] = { 0x23a0, 7 }, 2975 + [SFAB_AFAB_M_RESET] = { 0x23e0, 7 }, 2976 + [AFAB_SFAB_M0_RESET] = { 0x2420, 7 }, 2977 + [AFAB_SFAB_M1_RESET] = { 0x2424, 7 }, 2978 + [SFAB_SATA_S_RESET] = { 0x2480, 7 }, 2979 + [SFAB_DFAB_M_RESET] = { 0x2500, 7 }, 2980 + [DFAB_SFAB_M_RESET] = { 0x2520, 7 }, 2981 + [DFAB_SWAY0_RESET] = { 0x2540, 7 }, 2982 + [DFAB_SWAY1_RESET] = { 0x2544, 7 }, 2983 + [DFAB_ARB0_RESET] = { 0x2560, 7 }, 2984 + [DFAB_ARB1_RESET] = { 0x2564, 7 }, 2985 + [PPSS_PROC_RESET] = { 0x2594, 1 }, 2986 + [PPSS_RESET] = { 0x2594}, 2987 + [DMA_BAM_RESET] = { 0x25c0, 7 }, 2988 + [SPS_TIC_H_RESET] = { 0x2600, 7 }, 2989 + [SFAB_CFPB_M_RESET] = { 0x2680, 7 }, 2990 + [SFAB_CFPB_S_RESET] = { 0x26c0, 7 }, 2991 + [TSIF_H_RESET] = { 0x2700, 7 }, 2992 + [CE1_H_RESET] = { 0x2720, 7 }, 2993 + [CE1_CORE_RESET] = { 0x2724, 7 }, 2994 + [CE1_SLEEP_RESET] = { 0x2728, 7 }, 2995 + [CE2_H_RESET] = { 0x2740, 7 }, 2996 + [CE2_CORE_RESET] = { 0x2744, 7 }, 2997 + [SFAB_SFPB_M_RESET] = { 0x2780, 7 }, 2998 + [SFAB_SFPB_S_RESET] = { 0x27a0, 7 }, 2999 + [RPM_PROC_RESET] = { 0x27c0, 7 }, 3000 + [PMIC_SSBI2_RESET] = { 0x280c, 12 }, 3001 + [SDC1_RESET] = { 0x2830 }, 3002 + [SDC2_RESET] = { 0x2850 }, 3003 + [SDC3_RESET] = { 0x2870 }, 3004 + [SDC4_RESET] = { 0x2890 }, 3005 + [USB_HS1_RESET] = { 0x2910 }, 3006 + [USB_HSIC_RESET] = { 0x2934 }, 3007 + [USB_FS1_XCVR_RESET] = { 0x2974, 1 }, 3008 + [USB_FS1_RESET] = { 0x2974 }, 3009 + [GSBI1_RESET] = { 0x29dc }, 3010 + [GSBI2_RESET] = { 0x29fc }, 3011 + [GSBI3_RESET] = { 0x2a1c }, 3012 + [GSBI4_RESET] = { 0x2a3c }, 3013 + [GSBI5_RESET] = { 0x2a5c }, 3014 + [GSBI6_RESET] = { 0x2a7c }, 3015 + [GSBI7_RESET] = { 0x2a9c }, 3016 + [SPDM_RESET] = { 0x2b6c }, 3017 + [TLMM_H_RESET] = { 0x2ba0, 7 }, 3018 + [SATA_SFAB_M_RESET] = { 0x2c18 }, 3019 + [SATA_RESET] = { 0x2c1c }, 3020 + [GSS_SLP_RESET] = { 0x2c60, 7 }, 3021 + [GSS_RESET] = { 0x2c64 }, 3022 + [TSSC_RESET] = { 0x2ca0, 7 }, 3023 + [PDM_RESET] = { 0x2cc0, 12 }, 3024 + [MPM_H_RESET] = { 0x2da0, 7 }, 3025 + [MPM_RESET] = { 0x2da4 }, 3026 + [SFAB_SMPSS_S_RESET] = { 0x2e00, 7 }, 3027 + [PRNG_RESET] = { 0x2e80, 12 }, 3028 + [RIVA_RESET] = { 0x35e0 }, 3029 + [CE3_H_RESET] = { 0x36c4, 7 }, 3030 + [SFAB_CE3_M_RESET] = { 0x36c8, 1 }, 3031 + [SFAB_CE3_S_RESET] = { 0x36c8 }, 3032 + [CE3_RESET] = { 0x36cc, 7 }, 3033 + [CE3_SLEEP_RESET] = { 0x36d0, 7 }, 3034 + [USB_HS3_RESET] = { 0x3710 }, 3035 + [USB_HS4_RESET] = { 0x3730 }, 3303 3036 }; 3304 3037 3305 3038 static const struct regmap_config gcc_msm8960_regmap_config = { ··· 3452 2895 .reg_stride = 4, 3453 2896 .val_bits = 32, 3454 2897 .max_register = 0x3660, 2898 + .fast_io = true, 2899 + }; 2900 + 2901 + static const struct regmap_config gcc_apq8064_regmap_config = { 2902 + .reg_bits = 32, 2903 + .reg_stride = 4, 2904 + .val_bits = 32, 2905 + .max_register = 0x3880, 3455 2906 .fast_io = true, 3456 2907 }; 3457 2908 ··· 3472 2907 }; 3473 2908 3474 2909 static const struct qcom_cc_desc gcc_apq8064_desc = { 3475 - .config = &gcc_msm8960_regmap_config, 2910 + .config = &gcc_apq8064_regmap_config, 3476 2911 .clks = gcc_apq8064_clks, 3477 2912 .num_clks = ARRAY_SIZE(gcc_apq8064_clks), 3478 - .resets = gcc_msm8960_resets, 3479 - .num_resets = ARRAY_SIZE(gcc_msm8960_resets), 2913 + .resets = gcc_apq8064_resets, 2914 + .num_resets = ARRAY_SIZE(gcc_apq8064_resets), 3480 2915 }; 3481 2916 3482 2917 static const struct of_device_id gcc_msm8960_match_table[] = {
+11
include/dt-bindings/clock/qcom,gcc-msm8960.h
··· 308 308 #define PLL13 292 309 309 #define PLL14 293 310 310 #define PLL14_VOTE 294 311 + #define USB_HS3_H_CLK 295 312 + #define USB_HS3_XCVR_SRC 296 313 + #define USB_HS3_XCVR_CLK 297 314 + #define USB_HS4_H_CLK 298 315 + #define USB_HS4_XCVR_SRC 299 316 + #define USB_HS4_XCVR_CLK 300 317 + #define SATA_PHY_CFG_CLK 301 318 + #define SATA_A_CLK 302 319 + #define CE3_SRC 303 320 + #define CE3_CORE_CLK 304 321 + #define CE3_H_CLK 305 311 322 312 323 #endif
+16
include/dt-bindings/reset/qcom,gcc-msm8960.h
··· 114 114 #define SFAB_SMPSS_S_RESET 97 115 115 #define PRNG_RESET 98 116 116 #define RIVA_RESET 99 117 + #define USB_HS3_RESET 100 118 + #define USB_HS4_RESET 101 119 + #define CE3_RESET 102 120 + #define PCIE_EXT_PCI_RESET 103 121 + #define PCIE_PHY_RESET 104 122 + #define PCIE_PCI_RESET 105 123 + #define PCIE_POR_RESET 106 124 + #define PCIE_HCLK_RESET 107 125 + #define PCIE_ACLK_RESET 108 126 + #define CE3_H_RESET 109 127 + #define SFAB_CE3_M_RESET 110 128 + #define SFAB_CE3_S_RESET 111 129 + #define SATA_RESET 112 130 + #define CE3_SLEEP_RESET 113 131 + #define GSS_SLP_RESET 114 132 + #define GSS_RESET 115 117 133 118 134 #endif