2 * Copyright (c) 2013-2014, The Linux Foundation. All rights reserved.
3 * Copyright (c) BayLibre, SAS.
4 * Author : Neil Armstrong <narmstrong@baylibre.com>
6 * This software is licensed under the terms of the GNU General Public
7 * License version 2, as published by the Free Software Foundation, and
8 * may be copied, distributed, and modified under those terms.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
16 #include <linux/kernel.h>
17 #include <linux/bitops.h>
18 #include <linux/err.h>
19 #include <linux/platform_device.h>
20 #include <linux/module.h>
22 #include <linux/of_device.h>
23 #include <linux/clk-provider.h>
24 #include <linux/regmap.h>
25 #include <linux/reset-controller.h>
27 #include <dt-bindings/clock/qcom,gcc-mdm9615.h>
28 #include <dt-bindings/reset/qcom,gcc-mdm9615.h>
31 #include "clk-regmap.h"
34 #include "clk-branch.h"
37 static struct clk_fixed_factor cxo
= {
40 .hw
.init
= &(struct clk_init_data
){
42 .parent_names
= (const char *[]){ "cxo_board" },
44 .ops
= &clk_fixed_factor_ops
,
48 static struct clk_pll pll0
= {
56 .clkr
.hw
.init
= &(struct clk_init_data
){
58 .parent_names
= (const char *[]){ "cxo" },
64 static struct clk_regmap pll0_vote
= {
66 .enable_mask
= BIT(0),
67 .hw
.init
= &(struct clk_init_data
){
69 .parent_names
= (const char *[]){ "pll8" },
71 .ops
= &clk_pll_vote_ops
,
75 static struct clk_regmap pll4_vote
= {
77 .enable_mask
= BIT(4),
78 .hw
.init
= &(struct clk_init_data
){
80 .parent_names
= (const char *[]){ "pll4" },
82 .ops
= &clk_pll_vote_ops
,
86 static struct clk_pll pll8
= {
94 .clkr
.hw
.init
= &(struct clk_init_data
){
96 .parent_names
= (const char *[]){ "cxo" },
102 static struct clk_regmap pll8_vote
= {
103 .enable_reg
= 0x34c0,
104 .enable_mask
= BIT(8),
105 .hw
.init
= &(struct clk_init_data
){
107 .parent_names
= (const char *[]){ "pll8" },
109 .ops
= &clk_pll_vote_ops
,
113 static struct clk_pll pll14
= {
117 .config_reg
= 0x31d4,
119 .status_reg
= 0x31d8,
121 .clkr
.hw
.init
= &(struct clk_init_data
){
123 .parent_names
= (const char *[]){ "cxo" },
129 static struct clk_regmap pll14_vote
= {
130 .enable_reg
= 0x34c0,
131 .enable_mask
= BIT(11),
132 .hw
.init
= &(struct clk_init_data
){
133 .name
= "pll14_vote",
134 .parent_names
= (const char *[]){ "pll14" },
136 .ops
= &clk_pll_vote_ops
,
146 static const struct parent_map gcc_cxo_pll8_map
[] = {
151 static const char * const gcc_cxo_pll8
[] = {
156 static const struct parent_map gcc_cxo_pll14_map
[] = {
161 static const char * const gcc_cxo_pll14
[] = {
166 static const struct parent_map gcc_cxo_map
[] = {
170 static const char * const gcc_cxo
[] = {
174 static struct freq_tbl clk_tbl_gsbi_uart
[] = {
175 { 1843200, P_PLL8
, 2, 6, 625 },
176 { 3686400, P_PLL8
, 2, 12, 625 },
177 { 7372800, P_PLL8
, 2, 24, 625 },
178 { 14745600, P_PLL8
, 2, 48, 625 },
179 { 16000000, P_PLL8
, 4, 1, 6 },
180 { 24000000, P_PLL8
, 4, 1, 4 },
181 { 32000000, P_PLL8
, 4, 1, 3 },
182 { 40000000, P_PLL8
, 1, 5, 48 },
183 { 46400000, P_PLL8
, 1, 29, 240 },
184 { 48000000, P_PLL8
, 4, 1, 2 },
185 { 51200000, P_PLL8
, 1, 2, 15 },
186 { 56000000, P_PLL8
, 1, 7, 48 },
187 { 58982400, P_PLL8
, 1, 96, 625 },
188 { 64000000, P_PLL8
, 2, 1, 3 },
192 static struct clk_rcg gsbi1_uart_src
= {
197 .mnctr_reset_bit
= 7,
198 .mnctr_mode_shift
= 5,
209 .parent_map
= gcc_cxo_pll8_map
,
211 .freq_tbl
= clk_tbl_gsbi_uart
,
213 .enable_reg
= 0x29d4,
214 .enable_mask
= BIT(11),
215 .hw
.init
= &(struct clk_init_data
){
216 .name
= "gsbi1_uart_src",
217 .parent_names
= gcc_cxo_pll8
,
220 .flags
= CLK_SET_PARENT_GATE
,
225 static struct clk_branch gsbi1_uart_clk
= {
229 .enable_reg
= 0x29d4,
230 .enable_mask
= BIT(9),
231 .hw
.init
= &(struct clk_init_data
){
232 .name
= "gsbi1_uart_clk",
233 .parent_names
= (const char *[]){
237 .ops
= &clk_branch_ops
,
238 .flags
= CLK_SET_RATE_PARENT
,
243 static struct clk_rcg gsbi2_uart_src
= {
248 .mnctr_reset_bit
= 7,
249 .mnctr_mode_shift
= 5,
260 .parent_map
= gcc_cxo_pll8_map
,
262 .freq_tbl
= clk_tbl_gsbi_uart
,
264 .enable_reg
= 0x29f4,
265 .enable_mask
= BIT(11),
266 .hw
.init
= &(struct clk_init_data
){
267 .name
= "gsbi2_uart_src",
268 .parent_names
= gcc_cxo_pll8
,
271 .flags
= CLK_SET_PARENT_GATE
,
276 static struct clk_branch gsbi2_uart_clk
= {
280 .enable_reg
= 0x29f4,
281 .enable_mask
= BIT(9),
282 .hw
.init
= &(struct clk_init_data
){
283 .name
= "gsbi2_uart_clk",
284 .parent_names
= (const char *[]){
288 .ops
= &clk_branch_ops
,
289 .flags
= CLK_SET_RATE_PARENT
,
294 static struct clk_rcg gsbi3_uart_src
= {
299 .mnctr_reset_bit
= 7,
300 .mnctr_mode_shift
= 5,
311 .parent_map
= gcc_cxo_pll8_map
,
313 .freq_tbl
= clk_tbl_gsbi_uart
,
315 .enable_reg
= 0x2a14,
316 .enable_mask
= BIT(11),
317 .hw
.init
= &(struct clk_init_data
){
318 .name
= "gsbi3_uart_src",
319 .parent_names
= gcc_cxo_pll8
,
322 .flags
= CLK_SET_PARENT_GATE
,
327 static struct clk_branch gsbi3_uart_clk
= {
331 .enable_reg
= 0x2a14,
332 .enable_mask
= BIT(9),
333 .hw
.init
= &(struct clk_init_data
){
334 .name
= "gsbi3_uart_clk",
335 .parent_names
= (const char *[]){
339 .ops
= &clk_branch_ops
,
340 .flags
= CLK_SET_RATE_PARENT
,
345 static struct clk_rcg gsbi4_uart_src
= {
350 .mnctr_reset_bit
= 7,
351 .mnctr_mode_shift
= 5,
362 .parent_map
= gcc_cxo_pll8_map
,
364 .freq_tbl
= clk_tbl_gsbi_uart
,
366 .enable_reg
= 0x2a34,
367 .enable_mask
= BIT(11),
368 .hw
.init
= &(struct clk_init_data
){
369 .name
= "gsbi4_uart_src",
370 .parent_names
= gcc_cxo_pll8
,
373 .flags
= CLK_SET_PARENT_GATE
,
378 static struct clk_branch gsbi4_uart_clk
= {
382 .enable_reg
= 0x2a34,
383 .enable_mask
= BIT(9),
384 .hw
.init
= &(struct clk_init_data
){
385 .name
= "gsbi4_uart_clk",
386 .parent_names
= (const char *[]){
390 .ops
= &clk_branch_ops
,
391 .flags
= CLK_SET_RATE_PARENT
,
396 static struct clk_rcg gsbi5_uart_src
= {
401 .mnctr_reset_bit
= 7,
402 .mnctr_mode_shift
= 5,
413 .parent_map
= gcc_cxo_pll8_map
,
415 .freq_tbl
= clk_tbl_gsbi_uart
,
417 .enable_reg
= 0x2a54,
418 .enable_mask
= BIT(11),
419 .hw
.init
= &(struct clk_init_data
){
420 .name
= "gsbi5_uart_src",
421 .parent_names
= gcc_cxo_pll8
,
424 .flags
= CLK_SET_PARENT_GATE
,
429 static struct clk_branch gsbi5_uart_clk
= {
433 .enable_reg
= 0x2a54,
434 .enable_mask
= BIT(9),
435 .hw
.init
= &(struct clk_init_data
){
436 .name
= "gsbi5_uart_clk",
437 .parent_names
= (const char *[]){
441 .ops
= &clk_branch_ops
,
442 .flags
= CLK_SET_RATE_PARENT
,
447 static struct freq_tbl clk_tbl_gsbi_qup
[] = {
448 { 960000, P_CXO
, 4, 1, 5 },
449 { 4800000, P_CXO
, 4, 0, 1 },
450 { 9600000, P_CXO
, 2, 0, 1 },
451 { 15060000, P_PLL8
, 1, 2, 51 },
452 { 24000000, P_PLL8
, 4, 1, 4 },
453 { 25600000, P_PLL8
, 1, 1, 15 },
454 { 48000000, P_PLL8
, 4, 1, 2 },
455 { 51200000, P_PLL8
, 1, 2, 15 },
459 static struct clk_rcg gsbi1_qup_src
= {
464 .mnctr_reset_bit
= 7,
465 .mnctr_mode_shift
= 5,
476 .parent_map
= gcc_cxo_pll8_map
,
478 .freq_tbl
= clk_tbl_gsbi_qup
,
480 .enable_reg
= 0x29cc,
481 .enable_mask
= BIT(11),
482 .hw
.init
= &(struct clk_init_data
){
483 .name
= "gsbi1_qup_src",
484 .parent_names
= gcc_cxo_pll8
,
487 .flags
= CLK_SET_PARENT_GATE
,
492 static struct clk_branch gsbi1_qup_clk
= {
496 .enable_reg
= 0x29cc,
497 .enable_mask
= BIT(9),
498 .hw
.init
= &(struct clk_init_data
){
499 .name
= "gsbi1_qup_clk",
500 .parent_names
= (const char *[]){ "gsbi1_qup_src" },
502 .ops
= &clk_branch_ops
,
503 .flags
= CLK_SET_RATE_PARENT
,
508 static struct clk_rcg gsbi2_qup_src
= {
513 .mnctr_reset_bit
= 7,
514 .mnctr_mode_shift
= 5,
525 .parent_map
= gcc_cxo_pll8_map
,
527 .freq_tbl
= clk_tbl_gsbi_qup
,
529 .enable_reg
= 0x29ec,
530 .enable_mask
= BIT(11),
531 .hw
.init
= &(struct clk_init_data
){
532 .name
= "gsbi2_qup_src",
533 .parent_names
= gcc_cxo_pll8
,
536 .flags
= CLK_SET_PARENT_GATE
,
541 static struct clk_branch gsbi2_qup_clk
= {
545 .enable_reg
= 0x29ec,
546 .enable_mask
= BIT(9),
547 .hw
.init
= &(struct clk_init_data
){
548 .name
= "gsbi2_qup_clk",
549 .parent_names
= (const char *[]){ "gsbi2_qup_src" },
551 .ops
= &clk_branch_ops
,
552 .flags
= CLK_SET_RATE_PARENT
,
557 static struct clk_rcg gsbi3_qup_src
= {
562 .mnctr_reset_bit
= 7,
563 .mnctr_mode_shift
= 5,
574 .parent_map
= gcc_cxo_pll8_map
,
576 .freq_tbl
= clk_tbl_gsbi_qup
,
578 .enable_reg
= 0x2a0c,
579 .enable_mask
= BIT(11),
580 .hw
.init
= &(struct clk_init_data
){
581 .name
= "gsbi3_qup_src",
582 .parent_names
= gcc_cxo_pll8
,
585 .flags
= CLK_SET_PARENT_GATE
,
590 static struct clk_branch gsbi3_qup_clk
= {
594 .enable_reg
= 0x2a0c,
595 .enable_mask
= BIT(9),
596 .hw
.init
= &(struct clk_init_data
){
597 .name
= "gsbi3_qup_clk",
598 .parent_names
= (const char *[]){ "gsbi3_qup_src" },
600 .ops
= &clk_branch_ops
,
601 .flags
= CLK_SET_RATE_PARENT
,
606 static struct clk_rcg gsbi4_qup_src
= {
611 .mnctr_reset_bit
= 7,
612 .mnctr_mode_shift
= 5,
623 .parent_map
= gcc_cxo_pll8_map
,
625 .freq_tbl
= clk_tbl_gsbi_qup
,
627 .enable_reg
= 0x2a2c,
628 .enable_mask
= BIT(11),
629 .hw
.init
= &(struct clk_init_data
){
630 .name
= "gsbi4_qup_src",
631 .parent_names
= gcc_cxo_pll8
,
634 .flags
= CLK_SET_PARENT_GATE
,
639 static struct clk_branch gsbi4_qup_clk
= {
643 .enable_reg
= 0x2a2c,
644 .enable_mask
= BIT(9),
645 .hw
.init
= &(struct clk_init_data
){
646 .name
= "gsbi4_qup_clk",
647 .parent_names
= (const char *[]){ "gsbi4_qup_src" },
649 .ops
= &clk_branch_ops
,
650 .flags
= CLK_SET_RATE_PARENT
,
655 static struct clk_rcg gsbi5_qup_src
= {
660 .mnctr_reset_bit
= 7,
661 .mnctr_mode_shift
= 5,
672 .parent_map
= gcc_cxo_pll8_map
,
674 .freq_tbl
= clk_tbl_gsbi_qup
,
676 .enable_reg
= 0x2a4c,
677 .enable_mask
= BIT(11),
678 .hw
.init
= &(struct clk_init_data
){
679 .name
= "gsbi5_qup_src",
680 .parent_names
= gcc_cxo_pll8
,
683 .flags
= CLK_SET_PARENT_GATE
,
688 static struct clk_branch gsbi5_qup_clk
= {
692 .enable_reg
= 0x2a4c,
693 .enable_mask
= BIT(9),
694 .hw
.init
= &(struct clk_init_data
){
695 .name
= "gsbi5_qup_clk",
696 .parent_names
= (const char *[]){ "gsbi5_qup_src" },
698 .ops
= &clk_branch_ops
,
699 .flags
= CLK_SET_RATE_PARENT
,
704 static const struct freq_tbl clk_tbl_gp
[] = {
705 { 9600000, P_CXO
, 2, 0, 0 },
706 { 19200000, P_CXO
, 1, 0, 0 },
710 static struct clk_rcg gp0_src
= {
715 .mnctr_reset_bit
= 7,
716 .mnctr_mode_shift
= 5,
727 .parent_map
= gcc_cxo_map
,
729 .freq_tbl
= clk_tbl_gp
,
731 .enable_reg
= 0x2d24,
732 .enable_mask
= BIT(11),
733 .hw
.init
= &(struct clk_init_data
){
735 .parent_names
= gcc_cxo
,
738 .flags
= CLK_SET_PARENT_GATE
,
743 static struct clk_branch gp0_clk
= {
747 .enable_reg
= 0x2d24,
748 .enable_mask
= BIT(9),
749 .hw
.init
= &(struct clk_init_data
){
751 .parent_names
= (const char *[]){ "gp0_src" },
753 .ops
= &clk_branch_ops
,
754 .flags
= CLK_SET_RATE_PARENT
,
759 static struct clk_rcg gp1_src
= {
764 .mnctr_reset_bit
= 7,
765 .mnctr_mode_shift
= 5,
776 .parent_map
= gcc_cxo_map
,
778 .freq_tbl
= clk_tbl_gp
,
780 .enable_reg
= 0x2d44,
781 .enable_mask
= BIT(11),
782 .hw
.init
= &(struct clk_init_data
){
784 .parent_names
= gcc_cxo
,
787 .flags
= CLK_SET_RATE_GATE
,
792 static struct clk_branch gp1_clk
= {
796 .enable_reg
= 0x2d44,
797 .enable_mask
= BIT(9),
798 .hw
.init
= &(struct clk_init_data
){
800 .parent_names
= (const char *[]){ "gp1_src" },
802 .ops
= &clk_branch_ops
,
803 .flags
= CLK_SET_RATE_PARENT
,
808 static struct clk_rcg gp2_src
= {
813 .mnctr_reset_bit
= 7,
814 .mnctr_mode_shift
= 5,
825 .parent_map
= gcc_cxo_map
,
827 .freq_tbl
= clk_tbl_gp
,
829 .enable_reg
= 0x2d64,
830 .enable_mask
= BIT(11),
831 .hw
.init
= &(struct clk_init_data
){
833 .parent_names
= gcc_cxo
,
836 .flags
= CLK_SET_RATE_GATE
,
841 static struct clk_branch gp2_clk
= {
845 .enable_reg
= 0x2d64,
846 .enable_mask
= BIT(9),
847 .hw
.init
= &(struct clk_init_data
){
849 .parent_names
= (const char *[]){ "gp2_src" },
851 .ops
= &clk_branch_ops
,
852 .flags
= CLK_SET_RATE_PARENT
,
857 static struct clk_branch pmem_clk
= {
863 .enable_reg
= 0x25a0,
864 .enable_mask
= BIT(4),
865 .hw
.init
= &(struct clk_init_data
){
867 .ops
= &clk_branch_ops
,
872 static struct clk_rcg prng_src
= {
880 .parent_map
= gcc_cxo_pll8_map
,
883 .hw
.init
= &(struct clk_init_data
){
885 .parent_names
= gcc_cxo_pll8
,
892 static struct clk_branch prng_clk
= {
894 .halt_check
= BRANCH_HALT_VOTED
,
897 .enable_reg
= 0x3080,
898 .enable_mask
= BIT(10),
899 .hw
.init
= &(struct clk_init_data
){
901 .parent_names
= (const char *[]){ "prng_src" },
903 .ops
= &clk_branch_ops
,
908 static const struct freq_tbl clk_tbl_sdc
[] = {
909 { 144000, P_CXO
, 1, 1, 133 },
910 { 400000, P_PLL8
, 4, 1, 240 },
911 { 16000000, P_PLL8
, 4, 1, 6 },
912 { 17070000, P_PLL8
, 1, 2, 45 },
913 { 20210000, P_PLL8
, 1, 1, 19 },
914 { 24000000, P_PLL8
, 4, 1, 4 },
915 { 38400000, P_PLL8
, 2, 1, 5 },
916 { 48000000, P_PLL8
, 4, 1, 2 },
917 { 64000000, P_PLL8
, 3, 1, 2 },
918 { 76800000, P_PLL8
, 1, 1, 5 },
922 static struct clk_rcg sdc1_src
= {
927 .mnctr_reset_bit
= 7,
928 .mnctr_mode_shift
= 5,
939 .parent_map
= gcc_cxo_pll8_map
,
941 .freq_tbl
= clk_tbl_sdc
,
943 .enable_reg
= 0x282c,
944 .enable_mask
= BIT(11),
945 .hw
.init
= &(struct clk_init_data
){
947 .parent_names
= gcc_cxo_pll8
,
950 .flags
= CLK_SET_RATE_GATE
,
955 static struct clk_branch sdc1_clk
= {
959 .enable_reg
= 0x282c,
960 .enable_mask
= BIT(9),
961 .hw
.init
= &(struct clk_init_data
){
963 .parent_names
= (const char *[]){ "sdc1_src" },
965 .ops
= &clk_branch_ops
,
966 .flags
= CLK_SET_RATE_PARENT
,
971 static struct clk_rcg sdc2_src
= {
976 .mnctr_reset_bit
= 7,
977 .mnctr_mode_shift
= 5,
988 .parent_map
= gcc_cxo_pll8_map
,
990 .freq_tbl
= clk_tbl_sdc
,
992 .enable_reg
= 0x284c,
993 .enable_mask
= BIT(11),
994 .hw
.init
= &(struct clk_init_data
){
996 .parent_names
= gcc_cxo_pll8
,
999 .flags
= CLK_SET_RATE_GATE
,
1004 static struct clk_branch sdc2_clk
= {
1008 .enable_reg
= 0x284c,
1009 .enable_mask
= BIT(9),
1010 .hw
.init
= &(struct clk_init_data
){
1012 .parent_names
= (const char *[]){ "sdc2_src" },
1014 .ops
= &clk_branch_ops
,
1015 .flags
= CLK_SET_RATE_PARENT
,
1020 static const struct freq_tbl clk_tbl_usb
[] = {
1021 { 60000000, P_PLL8
, 1, 5, 32 },
1025 static struct clk_rcg usb_hs1_xcvr_src
= {
1030 .mnctr_reset_bit
= 7,
1031 .mnctr_mode_shift
= 5,
1042 .parent_map
= gcc_cxo_pll8_map
,
1044 .freq_tbl
= clk_tbl_usb
,
1046 .enable_reg
= 0x290c,
1047 .enable_mask
= BIT(11),
1048 .hw
.init
= &(struct clk_init_data
){
1049 .name
= "usb_hs1_xcvr_src",
1050 .parent_names
= gcc_cxo_pll8
,
1052 .ops
= &clk_rcg_ops
,
1053 .flags
= CLK_SET_RATE_GATE
,
1058 static struct clk_branch usb_hs1_xcvr_clk
= {
1062 .enable_reg
= 0x290c,
1063 .enable_mask
= BIT(9),
1064 .hw
.init
= &(struct clk_init_data
){
1065 .name
= "usb_hs1_xcvr_clk",
1066 .parent_names
= (const char *[]){ "usb_hs1_xcvr_src" },
1068 .ops
= &clk_branch_ops
,
1069 .flags
= CLK_SET_RATE_PARENT
,
1074 static struct clk_rcg usb_hsic_xcvr_fs_src
= {
1079 .mnctr_reset_bit
= 7,
1080 .mnctr_mode_shift
= 5,
1091 .parent_map
= gcc_cxo_pll8_map
,
1093 .freq_tbl
= clk_tbl_usb
,
1095 .enable_reg
= 0x2928,
1096 .enable_mask
= BIT(11),
1097 .hw
.init
= &(struct clk_init_data
){
1098 .name
= "usb_hsic_xcvr_fs_src",
1099 .parent_names
= gcc_cxo_pll8
,
1101 .ops
= &clk_rcg_ops
,
1102 .flags
= CLK_SET_RATE_GATE
,
1107 static struct clk_branch usb_hsic_xcvr_fs_clk
= {
1111 .enable_reg
= 0x2928,
1112 .enable_mask
= BIT(9),
1113 .hw
.init
= &(struct clk_init_data
){
1114 .name
= "usb_hsic_xcvr_fs_clk",
1116 (const char *[]){ "usb_hsic_xcvr_fs_src" },
1118 .ops
= &clk_branch_ops
,
1119 .flags
= CLK_SET_RATE_PARENT
,
1124 static const struct freq_tbl clk_tbl_usb_hs1_system
[] = {
1125 { 60000000, P_PLL8
, 1, 5, 32 },
1129 static struct clk_rcg usb_hs1_system_src
= {
1134 .mnctr_reset_bit
= 7,
1135 .mnctr_mode_shift
= 5,
1146 .parent_map
= gcc_cxo_pll8_map
,
1148 .freq_tbl
= clk_tbl_usb_hs1_system
,
1150 .enable_reg
= 0x36a4,
1151 .enable_mask
= BIT(11),
1152 .hw
.init
= &(struct clk_init_data
){
1153 .name
= "usb_hs1_system_src",
1154 .parent_names
= gcc_cxo_pll8
,
1156 .ops
= &clk_rcg_ops
,
1157 .flags
= CLK_SET_RATE_GATE
,
1162 static struct clk_branch usb_hs1_system_clk
= {
1166 .enable_reg
= 0x36a4,
1167 .enable_mask
= BIT(9),
1168 .hw
.init
= &(struct clk_init_data
){
1170 (const char *[]){ "usb_hs1_system_src" },
1172 .name
= "usb_hs1_system_clk",
1173 .ops
= &clk_branch_ops
,
1174 .flags
= CLK_SET_RATE_PARENT
| CLK_IGNORE_UNUSED
,
1179 static const struct freq_tbl clk_tbl_usb_hsic_system
[] = {
1180 { 64000000, P_PLL8
, 1, 1, 6 },
1184 static struct clk_rcg usb_hsic_system_src
= {
1189 .mnctr_reset_bit
= 7,
1190 .mnctr_mode_shift
= 5,
1201 .parent_map
= gcc_cxo_pll8_map
,
1203 .freq_tbl
= clk_tbl_usb_hsic_system
,
1205 .enable_reg
= 0x2b58,
1206 .enable_mask
= BIT(11),
1207 .hw
.init
= &(struct clk_init_data
){
1208 .name
= "usb_hsic_system_src",
1209 .parent_names
= gcc_cxo_pll8
,
1211 .ops
= &clk_rcg_ops
,
1212 .flags
= CLK_SET_RATE_GATE
,
1217 static struct clk_branch usb_hsic_system_clk
= {
1221 .enable_reg
= 0x2b58,
1222 .enable_mask
= BIT(9),
1223 .hw
.init
= &(struct clk_init_data
){
1225 (const char *[]){ "usb_hsic_system_src" },
1227 .name
= "usb_hsic_system_clk",
1228 .ops
= &clk_branch_ops
,
1229 .flags
= CLK_SET_RATE_PARENT
,
1234 static const struct freq_tbl clk_tbl_usb_hsic_hsic
[] = {
1235 { 48000000, P_PLL14
, 1, 0, 0 },
1239 static struct clk_rcg usb_hsic_hsic_src
= {
1244 .mnctr_reset_bit
= 7,
1245 .mnctr_mode_shift
= 5,
1256 .parent_map
= gcc_cxo_pll14_map
,
1258 .freq_tbl
= clk_tbl_usb_hsic_hsic
,
1260 .enable_reg
= 0x2b50,
1261 .enable_mask
= BIT(11),
1262 .hw
.init
= &(struct clk_init_data
){
1263 .name
= "usb_hsic_hsic_src",
1264 .parent_names
= gcc_cxo_pll14
,
1266 .ops
= &clk_rcg_ops
,
1267 .flags
= CLK_SET_RATE_GATE
,
1272 static struct clk_branch usb_hsic_hsic_clk
= {
1273 .halt_check
= BRANCH_HALT_DELAY
,
1275 .enable_reg
= 0x2b50,
1276 .enable_mask
= BIT(9),
1277 .hw
.init
= &(struct clk_init_data
){
1278 .parent_names
= (const char *[]){ "usb_hsic_hsic_src" },
1280 .name
= "usb_hsic_hsic_clk",
1281 .ops
= &clk_branch_ops
,
1282 .flags
= CLK_SET_RATE_PARENT
,
1287 static struct clk_branch usb_hsic_hsio_cal_clk
= {
1291 .enable_reg
= 0x2b48,
1292 .enable_mask
= BIT(0),
1293 .hw
.init
= &(struct clk_init_data
){
1294 .parent_names
= (const char *[]){ "cxo" },
1296 .name
= "usb_hsic_hsio_cal_clk",
1297 .ops
= &clk_branch_ops
,
1302 static struct clk_branch ce1_core_clk
= {
1308 .enable_reg
= 0x2724,
1309 .enable_mask
= BIT(4),
1310 .hw
.init
= &(struct clk_init_data
){
1311 .name
= "ce1_core_clk",
1312 .ops
= &clk_branch_ops
,
1317 static struct clk_branch ce1_h_clk
= {
1321 .enable_reg
= 0x2720,
1322 .enable_mask
= BIT(4),
1323 .hw
.init
= &(struct clk_init_data
){
1324 .name
= "ce1_h_clk",
1325 .ops
= &clk_branch_ops
,
1330 static struct clk_branch dma_bam_h_clk
= {
1336 .enable_reg
= 0x25c0,
1337 .enable_mask
= BIT(4),
1338 .hw
.init
= &(struct clk_init_data
){
1339 .name
= "dma_bam_h_clk",
1340 .ops
= &clk_branch_ops
,
1345 static struct clk_branch gsbi1_h_clk
= {
1351 .enable_reg
= 0x29c0,
1352 .enable_mask
= BIT(4),
1353 .hw
.init
= &(struct clk_init_data
){
1354 .name
= "gsbi1_h_clk",
1355 .ops
= &clk_branch_ops
,
1360 static struct clk_branch gsbi2_h_clk
= {
1366 .enable_reg
= 0x29e0,
1367 .enable_mask
= BIT(4),
1368 .hw
.init
= &(struct clk_init_data
){
1369 .name
= "gsbi2_h_clk",
1370 .ops
= &clk_branch_ops
,
1375 static struct clk_branch gsbi3_h_clk
= {
1381 .enable_reg
= 0x2a00,
1382 .enable_mask
= BIT(4),
1383 .hw
.init
= &(struct clk_init_data
){
1384 .name
= "gsbi3_h_clk",
1385 .ops
= &clk_branch_ops
,
1390 static struct clk_branch gsbi4_h_clk
= {
1396 .enable_reg
= 0x2a20,
1397 .enable_mask
= BIT(4),
1398 .hw
.init
= &(struct clk_init_data
){
1399 .name
= "gsbi4_h_clk",
1400 .ops
= &clk_branch_ops
,
1405 static struct clk_branch gsbi5_h_clk
= {
1411 .enable_reg
= 0x2a40,
1412 .enable_mask
= BIT(4),
1413 .hw
.init
= &(struct clk_init_data
){
1414 .name
= "gsbi5_h_clk",
1415 .ops
= &clk_branch_ops
,
1420 static struct clk_branch usb_hs1_h_clk
= {
1426 .enable_reg
= 0x2900,
1427 .enable_mask
= BIT(4),
1428 .hw
.init
= &(struct clk_init_data
){
1429 .name
= "usb_hs1_h_clk",
1430 .ops
= &clk_branch_ops
,
1435 static struct clk_branch usb_hsic_h_clk
= {
1439 .enable_reg
= 0x2920,
1440 .enable_mask
= BIT(4),
1441 .hw
.init
= &(struct clk_init_data
){
1442 .name
= "usb_hsic_h_clk",
1443 .ops
= &clk_branch_ops
,
1448 static struct clk_branch sdc1_h_clk
= {
1454 .enable_reg
= 0x2820,
1455 .enable_mask
= BIT(4),
1456 .hw
.init
= &(struct clk_init_data
){
1457 .name
= "sdc1_h_clk",
1458 .ops
= &clk_branch_ops
,
1463 static struct clk_branch sdc2_h_clk
= {
1469 .enable_reg
= 0x2840,
1470 .enable_mask
= BIT(4),
1471 .hw
.init
= &(struct clk_init_data
){
1472 .name
= "sdc2_h_clk",
1473 .ops
= &clk_branch_ops
,
1478 static struct clk_branch adm0_clk
= {
1480 .halt_check
= BRANCH_HALT_VOTED
,
1483 .enable_reg
= 0x3080,
1484 .enable_mask
= BIT(2),
1485 .hw
.init
= &(struct clk_init_data
){
1487 .ops
= &clk_branch_ops
,
1492 static struct clk_branch adm0_pbus_clk
= {
1496 .halt_check
= BRANCH_HALT_VOTED
,
1499 .enable_reg
= 0x3080,
1500 .enable_mask
= BIT(3),
1501 .hw
.init
= &(struct clk_init_data
){
1502 .name
= "adm0_pbus_clk",
1503 .ops
= &clk_branch_ops
,
1508 static struct clk_branch pmic_arb0_h_clk
= {
1510 .halt_check
= BRANCH_HALT_VOTED
,
1513 .enable_reg
= 0x3080,
1514 .enable_mask
= BIT(8),
1515 .hw
.init
= &(struct clk_init_data
){
1516 .name
= "pmic_arb0_h_clk",
1517 .ops
= &clk_branch_ops
,
1522 static struct clk_branch pmic_arb1_h_clk
= {
1524 .halt_check
= BRANCH_HALT_VOTED
,
1527 .enable_reg
= 0x3080,
1528 .enable_mask
= BIT(9),
1529 .hw
.init
= &(struct clk_init_data
){
1530 .name
= "pmic_arb1_h_clk",
1531 .ops
= &clk_branch_ops
,
1536 static struct clk_branch pmic_ssbi2_clk
= {
1538 .halt_check
= BRANCH_HALT_VOTED
,
1541 .enable_reg
= 0x3080,
1542 .enable_mask
= BIT(7),
1543 .hw
.init
= &(struct clk_init_data
){
1544 .name
= "pmic_ssbi2_clk",
1545 .ops
= &clk_branch_ops
,
1550 static struct clk_branch rpm_msg_ram_h_clk
= {
1554 .halt_check
= BRANCH_HALT_VOTED
,
1557 .enable_reg
= 0x3080,
1558 .enable_mask
= BIT(6),
1559 .hw
.init
= &(struct clk_init_data
){
1560 .name
= "rpm_msg_ram_h_clk",
1561 .ops
= &clk_branch_ops
,
1566 static struct clk_hw
*gcc_mdm9615_hws
[] = {
1570 static struct clk_regmap
*gcc_mdm9615_clks
[] = {
1571 [PLL0
] = &pll0
.clkr
,
1572 [PLL0_VOTE
] = &pll0_vote
,
1573 [PLL4_VOTE
] = &pll4_vote
,
1574 [PLL8
] = &pll8
.clkr
,
1575 [PLL8_VOTE
] = &pll8_vote
,
1576 [PLL14
] = &pll14
.clkr
,
1577 [PLL14_VOTE
] = &pll14_vote
,
1578 [GSBI1_UART_SRC
] = &gsbi1_uart_src
.clkr
,
1579 [GSBI1_UART_CLK
] = &gsbi1_uart_clk
.clkr
,
1580 [GSBI2_UART_SRC
] = &gsbi2_uart_src
.clkr
,
1581 [GSBI2_UART_CLK
] = &gsbi2_uart_clk
.clkr
,
1582 [GSBI3_UART_SRC
] = &gsbi3_uart_src
.clkr
,
1583 [GSBI3_UART_CLK
] = &gsbi3_uart_clk
.clkr
,
1584 [GSBI4_UART_SRC
] = &gsbi4_uart_src
.clkr
,
1585 [GSBI4_UART_CLK
] = &gsbi4_uart_clk
.clkr
,
1586 [GSBI5_UART_SRC
] = &gsbi5_uart_src
.clkr
,
1587 [GSBI5_UART_CLK
] = &gsbi5_uart_clk
.clkr
,
1588 [GSBI1_QUP_SRC
] = &gsbi1_qup_src
.clkr
,
1589 [GSBI1_QUP_CLK
] = &gsbi1_qup_clk
.clkr
,
1590 [GSBI2_QUP_SRC
] = &gsbi2_qup_src
.clkr
,
1591 [GSBI2_QUP_CLK
] = &gsbi2_qup_clk
.clkr
,
1592 [GSBI3_QUP_SRC
] = &gsbi3_qup_src
.clkr
,
1593 [GSBI3_QUP_CLK
] = &gsbi3_qup_clk
.clkr
,
1594 [GSBI4_QUP_SRC
] = &gsbi4_qup_src
.clkr
,
1595 [GSBI4_QUP_CLK
] = &gsbi4_qup_clk
.clkr
,
1596 [GSBI5_QUP_SRC
] = &gsbi5_qup_src
.clkr
,
1597 [GSBI5_QUP_CLK
] = &gsbi5_qup_clk
.clkr
,
1598 [GP0_SRC
] = &gp0_src
.clkr
,
1599 [GP0_CLK
] = &gp0_clk
.clkr
,
1600 [GP1_SRC
] = &gp1_src
.clkr
,
1601 [GP1_CLK
] = &gp1_clk
.clkr
,
1602 [GP2_SRC
] = &gp2_src
.clkr
,
1603 [GP2_CLK
] = &gp2_clk
.clkr
,
1604 [PMEM_A_CLK
] = &pmem_clk
.clkr
,
1605 [PRNG_SRC
] = &prng_src
.clkr
,
1606 [PRNG_CLK
] = &prng_clk
.clkr
,
1607 [SDC1_SRC
] = &sdc1_src
.clkr
,
1608 [SDC1_CLK
] = &sdc1_clk
.clkr
,
1609 [SDC2_SRC
] = &sdc2_src
.clkr
,
1610 [SDC2_CLK
] = &sdc2_clk
.clkr
,
1611 [USB_HS1_XCVR_SRC
] = &usb_hs1_xcvr_src
.clkr
,
1612 [USB_HS1_XCVR_CLK
] = &usb_hs1_xcvr_clk
.clkr
,
1613 [USB_HS1_SYSTEM_CLK_SRC
] = &usb_hs1_system_src
.clkr
,
1614 [USB_HS1_SYSTEM_CLK
] = &usb_hs1_system_clk
.clkr
,
1615 [USB_HSIC_XCVR_FS_SRC
] = &usb_hsic_xcvr_fs_src
.clkr
,
1616 [USB_HSIC_XCVR_FS_CLK
] = &usb_hsic_xcvr_fs_clk
.clkr
,
1617 [USB_HSIC_SYSTEM_CLK_SRC
] = &usb_hsic_system_src
.clkr
,
1618 [USB_HSIC_SYSTEM_CLK
] = &usb_hsic_system_clk
.clkr
,
1619 [USB_HSIC_HSIC_CLK_SRC
] = &usb_hsic_hsic_src
.clkr
,
1620 [USB_HSIC_HSIC_CLK
] = &usb_hsic_hsic_clk
.clkr
,
1621 [USB_HSIC_HSIO_CAL_CLK
] = &usb_hsic_hsio_cal_clk
.clkr
,
1622 [CE1_CORE_CLK
] = &ce1_core_clk
.clkr
,
1623 [CE1_H_CLK
] = &ce1_h_clk
.clkr
,
1624 [DMA_BAM_H_CLK
] = &dma_bam_h_clk
.clkr
,
1625 [GSBI1_H_CLK
] = &gsbi1_h_clk
.clkr
,
1626 [GSBI2_H_CLK
] = &gsbi2_h_clk
.clkr
,
1627 [GSBI3_H_CLK
] = &gsbi3_h_clk
.clkr
,
1628 [GSBI4_H_CLK
] = &gsbi4_h_clk
.clkr
,
1629 [GSBI5_H_CLK
] = &gsbi5_h_clk
.clkr
,
1630 [USB_HS1_H_CLK
] = &usb_hs1_h_clk
.clkr
,
1631 [USB_HSIC_H_CLK
] = &usb_hsic_h_clk
.clkr
,
1632 [SDC1_H_CLK
] = &sdc1_h_clk
.clkr
,
1633 [SDC2_H_CLK
] = &sdc2_h_clk
.clkr
,
1634 [ADM0_CLK
] = &adm0_clk
.clkr
,
1635 [ADM0_PBUS_CLK
] = &adm0_pbus_clk
.clkr
,
1636 [PMIC_ARB0_H_CLK
] = &pmic_arb0_h_clk
.clkr
,
1637 [PMIC_ARB1_H_CLK
] = &pmic_arb1_h_clk
.clkr
,
1638 [PMIC_SSBI2_CLK
] = &pmic_ssbi2_clk
.clkr
,
1639 [RPM_MSG_RAM_H_CLK
] = &rpm_msg_ram_h_clk
.clkr
,
1642 static const struct qcom_reset_map gcc_mdm9615_resets
[] = {
1643 [DMA_BAM_RESET
] = { 0x25c0, 7 },
1644 [CE1_H_RESET
] = { 0x2720, 7 },
1645 [CE1_CORE_RESET
] = { 0x2724, 7 },
1646 [SDC1_RESET
] = { 0x2830 },
1647 [SDC2_RESET
] = { 0x2850 },
1648 [ADM0_C2_RESET
] = { 0x220c, 4 },
1649 [ADM0_C1_RESET
] = { 0x220c, 3 },
1650 [ADM0_C0_RESET
] = { 0x220c, 2 },
1651 [ADM0_PBUS_RESET
] = { 0x220c, 1 },
1652 [ADM0_RESET
] = { 0x220c },
1653 [USB_HS1_RESET
] = { 0x2910 },
1654 [USB_HSIC_RESET
] = { 0x2934 },
1655 [GSBI1_RESET
] = { 0x29dc },
1656 [GSBI2_RESET
] = { 0x29fc },
1657 [GSBI3_RESET
] = { 0x2a1c },
1658 [GSBI4_RESET
] = { 0x2a3c },
1659 [GSBI5_RESET
] = { 0x2a5c },
1660 [PDM_RESET
] = { 0x2CC0, 12 },
1663 static const struct regmap_config gcc_mdm9615_regmap_config
= {
1667 .max_register
= 0x3660,
1671 static const struct qcom_cc_desc gcc_mdm9615_desc
= {
1672 .config
= &gcc_mdm9615_regmap_config
,
1673 .clks
= gcc_mdm9615_clks
,
1674 .num_clks
= ARRAY_SIZE(gcc_mdm9615_clks
),
1675 .resets
= gcc_mdm9615_resets
,
1676 .num_resets
= ARRAY_SIZE(gcc_mdm9615_resets
),
1679 static const struct of_device_id gcc_mdm9615_match_table
[] = {
1680 { .compatible
= "qcom,gcc-mdm9615" },
1683 MODULE_DEVICE_TABLE(of
, gcc_mdm9615_match_table
);
1685 static int gcc_mdm9615_probe(struct platform_device
*pdev
)
1687 struct device
*dev
= &pdev
->dev
;
1688 struct regmap
*regmap
;
1692 regmap
= qcom_cc_map(pdev
, &gcc_mdm9615_desc
);
1694 return PTR_ERR(regmap
);
1696 for (i
= 0; i
< ARRAY_SIZE(gcc_mdm9615_hws
); i
++) {
1697 ret
= devm_clk_hw_register(dev
, gcc_mdm9615_hws
[i
]);
1702 return qcom_cc_really_probe(pdev
, &gcc_mdm9615_desc
, regmap
);
1705 static struct platform_driver gcc_mdm9615_driver
= {
1706 .probe
= gcc_mdm9615_probe
,
1708 .name
= "gcc-mdm9615",
1709 .of_match_table
= gcc_mdm9615_match_table
,
1713 static int __init
gcc_mdm9615_init(void)
1715 return platform_driver_register(&gcc_mdm9615_driver
);
1717 core_initcall(gcc_mdm9615_init
);
1719 static void __exit
gcc_mdm9615_exit(void)
1721 platform_driver_unregister(&gcc_mdm9615_driver
);
1723 module_exit(gcc_mdm9615_exit
);
1725 MODULE_DESCRIPTION("QCOM GCC MDM9615 Driver");
1726 MODULE_LICENSE("GPL v2");
1727 MODULE_ALIAS("platform:gcc-mdm9615");