xref: /rk3399_ARM-atf/plat/rockchip/rk3399/drivers/dram/dfs.h (revision 4bd1d3faed7893e8e7d74f82b4b5de7443f434bd)
1613038bcSCaesar Wang /*
2613038bcSCaesar Wang  * Copyright (c) 2016, ARM Limited and Contributors. All rights reserved.
3613038bcSCaesar Wang  *
4613038bcSCaesar Wang  * Redistribution and use in source and binary forms, with or without
5613038bcSCaesar Wang  * modification, are permitted provided that the following conditions are met:
6613038bcSCaesar Wang  *
7613038bcSCaesar Wang  * Redistributions of source code must retain the above copyright notice, this
8613038bcSCaesar Wang  * list of conditions and the following disclaimer.
9613038bcSCaesar Wang  *
10613038bcSCaesar Wang  * Redistributions in binary form must reproduce the above copyright notice,
11613038bcSCaesar Wang  * this list of conditions and the following disclaimer in the documentation
12613038bcSCaesar Wang  * and/or other materials provided with the distribution.
13613038bcSCaesar Wang  *
14613038bcSCaesar Wang  * Neither the name of ARM nor the names of its contributors may be used
15613038bcSCaesar Wang  * to endorse or promote products derived from this software without specific
16613038bcSCaesar Wang  * prior written permission.
17613038bcSCaesar Wang  *
18613038bcSCaesar Wang  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
19613038bcSCaesar Wang  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20613038bcSCaesar Wang  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21613038bcSCaesar Wang  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
22613038bcSCaesar Wang  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23613038bcSCaesar Wang  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24613038bcSCaesar Wang  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25613038bcSCaesar Wang  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26613038bcSCaesar Wang  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27613038bcSCaesar Wang  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28613038bcSCaesar Wang  * POSSIBILITY OF SUCH DAMAGE.
29613038bcSCaesar Wang  */
30613038bcSCaesar Wang 
31613038bcSCaesar Wang #ifndef __SOC_ROCKCHIP_RK3399_DFS_H__
32613038bcSCaesar Wang #define __SOC_ROCKCHIP_RK3399_DFS_H__
33613038bcSCaesar Wang 
34613038bcSCaesar Wang struct rk3399_sdram_default_config {
35613038bcSCaesar Wang 	unsigned char bl;
36613038bcSCaesar Wang 	/* 1:auto precharge, 0:never auto precharge */
37613038bcSCaesar Wang 	unsigned char ap;
38613038bcSCaesar Wang 	/* dram driver strength */
39613038bcSCaesar Wang 	unsigned char dramds;
40613038bcSCaesar Wang 	/* dram ODT, if odt=0, this parameter invalid */
41613038bcSCaesar Wang 	unsigned char dramodt;
42613038bcSCaesar Wang 	/* ca ODT, if odt=0, this parameter invalid
43613038bcSCaesar Wang 	 * only used by LPDDR4
44613038bcSCaesar Wang 	 */
45613038bcSCaesar Wang 	unsigned char caodt;
46613038bcSCaesar Wang 	unsigned char burst_ref_cnt;
47613038bcSCaesar Wang 	/* zqcs period, unit(s) */
48613038bcSCaesar Wang 	unsigned char zqcsi;
49613038bcSCaesar Wang };
50613038bcSCaesar Wang 
51613038bcSCaesar Wang struct drv_odt_lp_config {
52613038bcSCaesar Wang 	uint32_t pd_idle;
53613038bcSCaesar Wang 	uint32_t sr_idle;
54613038bcSCaesar Wang 	uint32_t sr_mc_gate_idle;
55613038bcSCaesar Wang 	uint32_t srpd_lite_idle;
56613038bcSCaesar Wang 	uint32_t standby_idle;
57f91b969cSDerek Basehore 	uint32_t odt_en;
58613038bcSCaesar Wang 
59613038bcSCaesar Wang 	uint32_t dram_side_drv;
60613038bcSCaesar Wang 	uint32_t dram_side_dq_odt;
61613038bcSCaesar Wang 	uint32_t dram_side_ca_odt;
62613038bcSCaesar Wang };
63613038bcSCaesar Wang 
64613038bcSCaesar Wang uint32_t ddr_set_rate(uint32_t hz);
65613038bcSCaesar Wang uint32_t ddr_round_rate(uint32_t hz);
66613038bcSCaesar Wang uint32_t ddr_get_rate(void);
67f91b969cSDerek Basehore uint32_t dram_set_odt_pd(uint32_t arg0, uint32_t arg1, uint32_t arg2);
68f91b969cSDerek Basehore void dram_dfs_init(void);
69*4bd1d3faSDerek Basehore void ddr_prepare_for_sys_suspend(void);
70*4bd1d3faSDerek Basehore void ddr_prepare_for_sys_resume(void);
71*4bd1d3faSDerek Basehore 
72613038bcSCaesar Wang #endif
73