123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227 |
- /*
- * 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
|