1.add the function of configure ddr timing such us sr_idle, pd_idle, odt
disable frequency, dll bypass frequency, odt strength, driver strength in dts.
2.make sure commit 8be554a502 ("rk3368 dts: add ddr timing node in
rk3368.dtsi" add ddr timing node in dts that user can configure ddr timing in
dts file.) was merged.
3.bl30 must update to rk3368bl30_v2.11.bin.
Change-Id: Ie8ae559c8128eb01788271a4333c465e21954ab1
Signed-off-by: Tang Yun ping <typ@rock-chips.com>
54 lines
1.7 KiB
C
54 lines
1.7 KiB
C
/*
|
|
* SCPI Message Protocol driver header
|
|
*
|
|
* Copyright (C) 2014 ARM Ltd.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
* under the terms and conditions of the GNU General Public License,
|
|
* version 2, as published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope 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.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along with
|
|
* this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
#include <linux/types.h>
|
|
#include <linux/rockchip/common.h>
|
|
|
|
struct scpi_opp_entry {
|
|
u32 freq_hz;
|
|
u32 volt_mv;
|
|
} __packed;
|
|
|
|
struct scpi_opp {
|
|
struct scpi_opp_entry *opp;
|
|
u32 latency; /* in usecs */
|
|
int count;
|
|
} __packed;
|
|
|
|
unsigned long scpi_clk_get_val(u16 clk_id);
|
|
int scpi_clk_set_val(u16 clk_id, unsigned long rate);
|
|
int scpi_dvfs_get_idx(u8 domain);
|
|
int scpi_dvfs_set_idx(u8 domain, u8 idx);
|
|
struct scpi_opp *scpi_dvfs_get_opps(u8 domain);
|
|
int scpi_get_sensor(char *name);
|
|
int scpi_get_sensor_value(u16 sensor, u32 *val);
|
|
|
|
int scpi_sys_set_mcu_state_suspend(void);
|
|
int scpi_sys_set_mcu_state_resume(void);
|
|
|
|
int scpi_ddr_init(u32 dram_speed_bin, u32 freq, u32 lcdc_type,
|
|
u32 addr_mcu_el3);
|
|
int scpi_ddr_set_clk_rate(u32 rate, u32 lcdc_type);
|
|
int scpi_ddr_send_timing(u32 *p, u32 size);
|
|
int scpi_ddr_round_rate(u32 m_hz);
|
|
int scpi_ddr_set_auto_self_refresh(u32 en);
|
|
int scpi_ddr_bandwidth_get(struct ddr_bw_info *ddr_bw_ch0,
|
|
struct ddr_bw_info *ddr_bw_ch1);
|
|
int scpi_ddr_get_clk_rate(void);
|
|
int scpi_thermal_get_temperature(void);
|
|
int scpi_thermal_set_clk_cycle(u32 cycle);
|