Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 7fcd45f7 authored by Jaydeep Sen's avatar Jaydeep Sen
Browse files

clk: msm: clock-gcc-mdmfermium: Add support for gcc and rpm clocks



Add clock driver support for all gcc controlled clocks as well as rpm
clocks in mdmfermium.

Change-Id: I261b10908f099d385aa17e84091bc4bf32d9ca65
Signed-off-by: default avatarJaydeep Sen <jsen@codeaurora.org>
parent 40b49a34
Loading
Loading
Loading
Loading
+2 −0
Original line number Diff line number Diff line
@@ -51,6 +51,8 @@ Required properties:
			"qcom,gpucc-8996-v3"
			"qcom,gcc-californium"
			"qcom,cc-debug-californium"
			"qcom,gcc-mdmfermium"
			"qcom,cc-debug-mdmfermium"

- reg:			Pairs of physical base addresses and region sizes of
			memory mapped registers.
+3 −0
Original line number Diff line number Diff line
@@ -19,6 +19,9 @@ obj-$(CONFIG_ARCH_MSM8996) += clock-cpu-8996.o
# MDMCALIFORNIUM
obj-$(CONFIG_ARCH_MDMCALIFORNIUM)	+= clock-gcc-californium.o

# MDMFERMIUM
obj-$(CONFIG_ARCH_MDMFERMIUM)	+=clock-gcc-mdmfermium.o

# ACPU clock
obj-$(CONFIG_ARCH_MDM9640)      += clock-a7.o
obj-$(CONFIG_ARCH_MDMCALIFORNIUM)	+= clock-a7.o
+1744 −0

File added.

Preview size limit exceeded, changes collapsed.

+2 −7
Original line number Diff line number Diff line
@@ -44,12 +44,6 @@
#define clk_xo_pil_mss_clk					 0xe97a8354
#define clk_bb_clk1						 0xf5304268
#define clk_bb_clk1_pin						 0x6dd0a779
#define clk_bb_clk2						 0xfe15cb87
#define clk_bb_clk2_pin						 0x498938e5
#define clk_rf_clk1						 0xaabeea5a
#define clk_rf_clk1_pin						 0x8f463562
#define clk_rf_clk2						 0x24a30992
#define clk_rf_clk2_pin						 0xa7c5602a

/* SRCs */
#define clk_apss_ahb_clk_src					 0x36f8495f
@@ -142,7 +136,8 @@
#define clk_gcc_usb_hsic_io_cal_clk				 0xbc21f776
#define clk_gcc_usb_hsic_io_cal_sleep_clk			 0x20e09a22
#define clk_gcc_usb_hsic_system_clk				 0x145e9366

#define clk_gcc_usb2_hs_phy_only_clk				 0x0047179d
#define clk_gcc_qusb2_phy_clk					 0x996884d5
/* DEBUG */
#define clk_gcc_debug_mux					 0x8121ac15
#define clk_wcnss_m_clk						 0x709f430b
+214 −0
Original line number Diff line number Diff line
/*
 * Copyright (c) 2015, The Linux Foundation. All rights reserved.
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 and
 * only version 2 as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 */

#ifndef __MDM_CLOCKS_FERMIUM_HWIO_H
#define __MDM_CLOCKS_FERMIUM_HWIO_H

#define GPLL0_MODE				0x21000
#define GPLL0_STATUS				0x21024
#define GPLL1_MODE				0x20000
#define GPLL1_STATUS				0x2001C
#define GPLL2_MODE				0x25000
#define GPLL2_STATUS				0x25024
#define APCS_GPLL_ENA_VOTE			0x45000
#define APSS_AHB_CMD_RCGR			0x46000
#define PRNG_AHB_CBCR				0x13004
#define EMAC_0_125M_CMD_RCGR			0x4E028
#define BLSP1_QUP1_I2C_APPS_CMD_RCGR		 0x200C
#define BLSP1_QUP1_SPI_APPS_CMD_RCGR		 0x2024
#define BLSP1_QUP2_I2C_APPS_CMD_RCGR		 0x3000
#define BLSP1_QUP2_SPI_APPS_CMD_RCGR		 0x3014
#define BLSP1_QUP3_I2C_APPS_CMD_RCGR		 0x4000
#define BLSP1_QUP3_SPI_APPS_CMD_RCGR		 0x4024
#define BLSP1_QUP4_I2C_APPS_CMD_RCGR		 0x5000
#define BLSP1_QUP4_SPI_APPS_CMD_RCGR		 0x5024
#define BLSP1_QUP5_I2C_APPS_CMD_RCGR		 0x6000
#define BLSP1_QUP5_SPI_APPS_CMD_RCGR		 0x6024
#define BLSP1_QUP6_I2C_APPS_CMD_RCGR		 0x7000
#define BLSP1_QUP6_SPI_APPS_CMD_RCGR		 0x7024
#define BLSP1_UART1_APPS_CMD_RCGR		 0x2044
#define BLSP1_UART2_APPS_CMD_RCGR		 0x3034
#define BLSP1_UART3_APPS_CMD_RCGR		 0x4044
#define BLSP1_UART4_APPS_CMD_RCGR		 0x5044
#define BLSP1_UART5_APPS_CMD_RCGR		 0x6044
#define BLSP1_UART6_APPS_CMD_RCGR		 0x7044
#define CRYPTO_CMD_RCGR			0x16004
#define GP1_CMD_RCGR				 0x8004
#define GP2_CMD_RCGR				 0x9004
#define GP3_CMD_RCGR				 0xA004
#define PDM2_CMD_RCGR				0x44010
#define QPIC_CMD_RCGR				0x3F004
#define SDCC1_APPS_CMD_RCGR			0x42004
#define SDCC2_APPS_CMD_RCGR			0x43004
#define EMAC_0_SYS_25M_CMD_RCGR		0x4E03C
#define EMAC_0_TX_CMD_RCGR			0x4E014
#define USB_HS_SYSTEM_CMD_RCGR			0x41010
#define USB_HSIC_CMD_RCGR			0x3D018
#define USB_HSIC_IO_CAL_CMD_RCGR		0x3D030
#define USB_HSIC_SYSTEM_CMD_RCGR		0x3D000
#define BIMC_PCNOC_AXI_CBCR			0x31024
#define BLSP1_AHB_CBCR				 0x1008
#define APCS_CLOCK_BRANCH_ENA_VOTE		0x45004
#define BLSP1_QUP1_I2C_APPS_CBCR		 0x2008
#define BLSP1_QUP1_SPI_APPS_CBCR		 0x2004
#define BLSP1_QUP2_I2C_APPS_CBCR		 0x3010
#define BLSP1_QUP2_SPI_APPS_CBCR		 0x300C
#define BLSP1_QUP3_I2C_APPS_CBCR		 0x4020
#define BLSP1_QUP3_SPI_APPS_CBCR		 0x401C
#define BLSP1_QUP4_I2C_APPS_CBCR		 0x5020
#define BLSP1_QUP4_SPI_APPS_CBCR		 0x501C
#define BLSP1_QUP5_I2C_APPS_CBCR		 0x6020
#define BLSP1_QUP5_SPI_APPS_CBCR		 0x601C
#define BLSP1_QUP6_I2C_APPS_CBCR		 0x7020
#define BLSP1_QUP6_SPI_APPS_CBCR		 0x701C
#define BLSP1_UART1_APPS_CBCR			 0x203C
#define BLSP1_UART2_APPS_CBCR			 0x302C
#define BLSP1_UART3_APPS_CBCR			 0x403C
#define BLSP1_UART4_APPS_CBCR			 0x503C
#define BLSP1_UART5_APPS_CBCR			 0x603C
#define BLSP1_UART6_APPS_CBCR			 0x703C
#define APSS_AHB_CBCR				0x4601C
#define APSS_AXI_CBCR				0x46020
#define BOOT_ROM_AHB_CBCR			0x1300C
#define CRYPTO_AHB_CBCR			0x16024
#define CRYPTO_AXI_CBCR			0x16020
#define CRYPTO_CBCR				0x1601C
#define GP1_CBCR				 0x8000
#define GP2_CBCR				 0x9000
#define GP3_CBCR				 0xA000
#define MSS_CFG_AHB_CBCR			0x49000
#define MSS_Q6_BIMC_AXI_CBCR			0x49004
#define PCNOC_APSS_AHB_CBCR			0x27030
#define PDM2_CBCR				0x4400C
#define PDM_AHB_CBCR				0x44004
#define QPIC_AHB_CBCR				0x3F01C
#define QPIC_CBCR				0x3F018
#define QPIC_SYSTEM_CBCR			0x3F020
#define SDCC1_AHB_CBCR				0x4201C
#define SDCC1_APPS_CBCR			0x42018
#define SDCC2_AHB_CBCR				0x4301C
#define SDCC2_APPS_CBCR			0x43018
#define EMAC_0_125M_CBCR			0x4E010
#define EMAC_0_AHB_CBCR			0x4E000
#define EMAC_0_AXI_CBCR			0x4E008
#define EMAC_0_RX_CBCR				0x4E030
#define EMAC_0_SYS_25M_CBCR			0x4E038
#define EMAC_0_SYS_CBCR			0x4E034
#define EMAC_0_TX_CBCR				0x4E00C
#define APSS_TCU_CBCR				0x12018
#define SMMU_CFG_CBCR				0x12038
#define APCS_SMMU_CLOCK_BRANCH_ENA_VOTE		0x4500C
#define USB2A_PHY_SLEEP_CBCR			0x4102C
#define USB_HS_PHY_CFG_AHB_CBCR		0x41030
#define USB_HS_AHB_CBCR			0x41008
#define USB_HS_SYSTEM_CBCR			0x41004
#define USB_HSIC_AHB_CBCR			0x3D04C
#define USB_HSIC_CBCR				0x3D050
#define USB_HSIC_IO_CAL_CBCR			0x3D054
#define USB_HSIC_IO_CAL_SLEEP_CBCR		0x3D058
#define USB_HSIC_SYSTEM_CBCR			0x3D048
#define USB2_HS_PHY_ONLY_BCR			0x41034
#define QUSB2_PHY_BCR				0x4103C
#define GCC_DEBUG_CLK_CTL			0x74000
#define CLOCK_FRQ_MEASURE_CTL			0x74004
#define CLOCK_FRQ_MEASURE_STATUS		0x74008
#define PLLTEST_PAD_CFG			0x7400C
#define GCC_XO_DIV4_CBCR			0x30034

#define xo_source_val				0
#define xo_a_source_val			0
#define gpll0_source_val			1
#define gpll2_source_val			1
#define emac_0_125m_clk_source_val		1

#define F(f, s, div, m, n) \
	{ \
		.freq_hz = (f), \
		.src_clk = &s##_clk_src.c, \
		.m_val = (m), \
		.n_val = ~((n)-(m)) * !!(n), \
		.d_val = ~(n),\
		.div_src_val = BVAL(4, 0, (int)(2*(div) - 1)) \
			| BVAL(10, 8, s##_source_val), \
	}

#define F_EXT(f, s, div, m, n) \
	{ \
		.freq_hz = (f), \
		.m_val = (m), \
		.n_val = ~((n)-(m)) * !!(n), \
		.d_val = ~(n),\
		.div_src_val = BVAL(4, 0, (int)(2*(div) - 1)) \
			| BVAL(10, 8, s##_source_val), \
		}

#define VDD_DIG_FMAX_MAP1(l1, f1) \
	.vdd_class = &vdd_dig, \
	.fmax = (unsigned long[VDD_DIG_NUM]) {  \
		[VDD_DIG_##l1] = (f1),          \
	},                                      \
	.num_fmax = VDD_DIG_NUM

#define VDD_DIG_FMAX_MAP2(l1, f1, l2, f2) \
	.vdd_class = &vdd_dig, \
	.fmax = (unsigned long[VDD_DIG_NUM]) {  \
		[VDD_DIG_##l1] = (f1),          \
		[VDD_DIG_##l2] = (f2),          \
	},                                      \
	.num_fmax = VDD_DIG_NUM

#define VDD_DIG_FMAX_MAP3(l1, f1, l2, f2, l3, f3) \
	.vdd_class = &vdd_dig, \
	.fmax = (unsigned long[VDD_DIG_NUM]) {  \
		[VDD_DIG_##l1] = (f1),          \
		[VDD_DIG_##l2] = (f2),          \
		[VDD_DIG_##l3] = (f3),          \
	},                                      \
	.num_fmax = VDD_DIG_NUM


enum vdd_dig_levels {
	VDD_DIG_NONE,
	VDD_DIG_LOWER,
	VDD_DIG_LOW,
	VDD_DIG_NOMINAL,
	VDD_DIG_HIGH,
	VDD_DIG_NUM
};

static int vdd_corner[] = {
	RPM_REGULATOR_LEVEL_NONE,              /* VDD_DIG_NONE */
	RPM_REGULATOR_LEVEL_SVS,		/* VDD_DIG_LOWER */
	RPM_REGULATOR_LEVEL_SVS_PLUS,		/*VDD_DIG_LOW*/
	RPM_REGULATOR_LEVEL_NOM,            /* VDD_DIG_NOMINAL */
	RPM_REGULATOR_LEVEL_TURBO,		/* VDD_DIG_HIGH */
};

static DEFINE_VDD_REGULATORS(vdd_dig, VDD_DIG_NUM, 1, vdd_corner, NULL);

#define RPM_MISC_CLK_TYPE			0x306b6c63
#define RPM_BUS_CLK_TYPE			0x316b6c63
#define RPM_MEM_CLK_TYPE			0x326b6c63
#define RPM_SMD_KEY_ENABLE			0x62616E45
#define RPM_QPIC_CLK_TYPE			0x63697071

#define XO_ID					0x0
#define QDSS_ID				0x1
#define PCNOC_ID				0x0
#define BIMC_ID				0x0
#define QPIC_ID				0x0

/* XO clock */
#define BB_CLK1_ID				1
#define RF_CLK2_ID				5

#endif