blob: e8bb4e057ef2c34469cab599a23507ec8eca08a6 [file] [log] [blame]
/*
* Copyright (c) 2015-2016, 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_9607_HWIO_H
#define __MDM_CLOCKS_9607_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 APCS_MODE 0x00018
#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 QDSS_DAP_CBCR 0x29084
#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_HS_BCR 0x41000
#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 USB_HS_HSIC_BCR 0x3D05C
#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 emac_0_tx_clk_source_val 2
#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 VDD_STROMER_FMAX_MAP1(l1, f1) \
.vdd_class = &vdd_stromer_pll, \
.fmax = (unsigned long[VDD_DIG_NUM]) { \
[VDD_DIG_##l1] = (f1), \
}, \
.num_fmax = VDD_DIG_NUM
#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