Lines Matching refs:emc
561 struct tegra210_emc *emc = from_timer(emc, timer, training); in tegra210_emc_train() local
564 if (!emc->last) in tegra210_emc_train()
567 spin_lock_irqsave(&emc->lock, flags); in tegra210_emc_train()
569 if (emc->sequence->periodic_compensation) in tegra210_emc_train()
570 emc->sequence->periodic_compensation(emc); in tegra210_emc_train()
572 spin_unlock_irqrestore(&emc->lock, flags); in tegra210_emc_train()
574 mod_timer(&emc->training, in tegra210_emc_train()
575 jiffies + msecs_to_jiffies(emc->training_interval)); in tegra210_emc_train()
578 static void tegra210_emc_training_start(struct tegra210_emc *emc) in tegra210_emc_training_start() argument
580 mod_timer(&emc->training, in tegra210_emc_training_start()
581 jiffies + msecs_to_jiffies(emc->training_interval)); in tegra210_emc_training_start()
584 static void tegra210_emc_training_stop(struct tegra210_emc *emc) in tegra210_emc_training_stop() argument
586 del_timer(&emc->training); in tegra210_emc_training_stop()
589 static unsigned int tegra210_emc_get_temperature(struct tegra210_emc *emc) in tegra210_emc_get_temperature() argument
595 spin_lock_irqsave(&emc->lock, flags); in tegra210_emc_get_temperature()
597 for (i = 0; i < emc->num_devices; i++) { in tegra210_emc_get_temperature()
598 value = tegra210_emc_mrr_read(emc, i, 4); in tegra210_emc_get_temperature()
601 dev_dbg(emc->dev, in tegra210_emc_get_temperature()
610 spin_unlock_irqrestore(&emc->lock, flags); in tegra210_emc_get_temperature()
617 struct tegra210_emc *emc = from_timer(emc, timer, refresh_timer); in tegra210_emc_poll_refresh() local
620 if (!emc->debugfs.temperature) in tegra210_emc_poll_refresh()
621 temperature = tegra210_emc_get_temperature(emc); in tegra210_emc_poll_refresh()
623 temperature = emc->debugfs.temperature; in tegra210_emc_poll_refresh()
625 if (temperature == emc->temperature) in tegra210_emc_poll_refresh()
631 dev_dbg(emc->dev, "switching to nominal refresh...\n"); in tegra210_emc_poll_refresh()
632 tegra210_emc_set_refresh(emc, TEGRA210_EMC_REFRESH_NOMINAL); in tegra210_emc_poll_refresh()
636 dev_dbg(emc->dev, "switching to 2x refresh...\n"); in tegra210_emc_poll_refresh()
637 tegra210_emc_set_refresh(emc, TEGRA210_EMC_REFRESH_2X); in tegra210_emc_poll_refresh()
641 dev_dbg(emc->dev, "switching to 4x refresh...\n"); in tegra210_emc_poll_refresh()
642 tegra210_emc_set_refresh(emc, TEGRA210_EMC_REFRESH_4X); in tegra210_emc_poll_refresh()
646 dev_dbg(emc->dev, "switching to throttle refresh...\n"); in tegra210_emc_poll_refresh()
647 tegra210_emc_set_refresh(emc, TEGRA210_EMC_REFRESH_THROTTLE); in tegra210_emc_poll_refresh()
655 emc->temperature = temperature; in tegra210_emc_poll_refresh()
658 if (atomic_read(&emc->refresh_poll) > 0) { in tegra210_emc_poll_refresh()
659 unsigned int interval = emc->refresh_poll_interval; in tegra210_emc_poll_refresh()
662 mod_timer(&emc->refresh_timer, jiffies + timeout); in tegra210_emc_poll_refresh()
666 static void tegra210_emc_poll_refresh_stop(struct tegra210_emc *emc) in tegra210_emc_poll_refresh_stop() argument
668 atomic_set(&emc->refresh_poll, 0); in tegra210_emc_poll_refresh_stop()
669 del_timer_sync(&emc->refresh_timer); in tegra210_emc_poll_refresh_stop()
672 static void tegra210_emc_poll_refresh_start(struct tegra210_emc *emc) in tegra210_emc_poll_refresh_start() argument
674 atomic_set(&emc->refresh_poll, 1); in tegra210_emc_poll_refresh_start()
676 mod_timer(&emc->refresh_timer, in tegra210_emc_poll_refresh_start()
677 jiffies + msecs_to_jiffies(emc->refresh_poll_interval)); in tegra210_emc_poll_refresh_start()
691 struct tegra210_emc *emc = cd->devdata; in tegra210_emc_cd_get_state() local
693 *state = atomic_read(&emc->refresh_poll); in tegra210_emc_cd_get_state()
701 struct tegra210_emc *emc = cd->devdata; in tegra210_emc_cd_set_state() local
703 if (state == atomic_read(&emc->refresh_poll)) in tegra210_emc_cd_set_state()
707 tegra210_emc_poll_refresh_start(emc); in tegra210_emc_cd_set_state()
709 tegra210_emc_poll_refresh_stop(emc); in tegra210_emc_cd_set_state()
720 static void tegra210_emc_set_clock(struct tegra210_emc *emc, u32 clksrc) in tegra210_emc_set_clock() argument
722 emc->sequence->set_clock(emc, clksrc); in tegra210_emc_set_clock()
724 if (emc->next->periodic_training) in tegra210_emc_set_clock()
725 tegra210_emc_training_start(emc); in tegra210_emc_set_clock()
727 tegra210_emc_training_stop(emc); in tegra210_emc_set_clock()
730 static void tegra210_change_dll_src(struct tegra210_emc *emc, in tegra210_change_dll_src() argument
733 u32 dll_setting = emc->next->dll_clk_src; in tegra210_change_dll_src()
760 if (emc->next->clk_out_enb_x_0_clk_enb_emc_dll) in tegra210_change_dll_src()
766 int tegra210_emc_set_refresh(struct tegra210_emc *emc, in tegra210_emc_set_refresh() argument
772 if ((emc->dram_type != DRAM_TYPE_LPDDR2 && in tegra210_emc_set_refresh()
773 emc->dram_type != DRAM_TYPE_LPDDR4) || in tegra210_emc_set_refresh()
774 !emc->last) in tegra210_emc_set_refresh()
780 if (refresh == emc->refresh) in tegra210_emc_set_refresh()
783 spin_lock_irqsave(&emc->lock, flags); in tegra210_emc_set_refresh()
785 if (refresh == TEGRA210_EMC_REFRESH_THROTTLE && emc->derated) in tegra210_emc_set_refresh()
786 timings = emc->derated; in tegra210_emc_set_refresh()
788 timings = emc->nominal; in tegra210_emc_set_refresh()
790 if (timings != emc->timings) { in tegra210_emc_set_refresh()
791 unsigned int index = emc->last - emc->timings; in tegra210_emc_set_refresh()
794 clksrc = emc->provider.configs[index].value | in tegra210_emc_set_refresh()
797 emc->next = &timings[index]; in tegra210_emc_set_refresh()
798 emc->timings = timings; in tegra210_emc_set_refresh()
800 tegra210_emc_set_clock(emc, clksrc); in tegra210_emc_set_refresh()
802 tegra210_emc_adjust_timing(emc, emc->last); in tegra210_emc_set_refresh()
803 tegra210_emc_timing_update(emc); in tegra210_emc_set_refresh()
806 emc_writel(emc, EMC_REF_REF_CMD, EMC_REF); in tegra210_emc_set_refresh()
809 spin_unlock_irqrestore(&emc->lock, flags); in tegra210_emc_set_refresh()
814 u32 tegra210_emc_mrr_read(struct tegra210_emc *emc, unsigned int chip, in tegra210_emc_mrr_read() argument
822 emc_writel(emc, value, EMC_MRR); in tegra210_emc_mrr_read()
824 for (i = 0; i < emc->num_channels; i++) in tegra210_emc_mrr_read()
825 WARN(tegra210_emc_wait_for_update(emc, i, EMC_EMC_STATUS, in tegra210_emc_mrr_read()
829 for (i = 0; i < emc->num_channels; i++) { in tegra210_emc_mrr_read()
830 value = emc_channel_readl(emc, i, EMC_MRR); in tegra210_emc_mrr_read()
839 void tegra210_emc_do_clock_change(struct tegra210_emc *emc, u32 clksrc) in tegra210_emc_do_clock_change() argument
843 mc_readl(emc->mc, MC_EMEM_ADR_CFG); in tegra210_emc_do_clock_change()
844 emc_readl(emc, EMC_INTSTATUS); in tegra210_emc_do_clock_change()
848 err = tegra210_emc_wait_for_update(emc, 0, EMC_INTSTATUS, in tegra210_emc_do_clock_change()
852 dev_warn(emc->dev, "clock change completion error: %d\n", err); in tegra210_emc_do_clock_change()
855 struct tegra210_emc_timing *tegra210_emc_find_timing(struct tegra210_emc *emc, in tegra210_emc_find_timing() argument
860 for (i = 0; i < emc->num_timings; i++) in tegra210_emc_find_timing()
861 if (emc->timings[i].rate * 1000UL == rate) in tegra210_emc_find_timing()
862 return &emc->timings[i]; in tegra210_emc_find_timing()
867 int tegra210_emc_wait_for_update(struct tegra210_emc *emc, unsigned int channel, in tegra210_emc_wait_for_update() argument
874 value = emc_channel_readl(emc, channel, offset); in tegra210_emc_wait_for_update()
884 void tegra210_emc_set_shadow_bypass(struct tegra210_emc *emc, int set) in tegra210_emc_set_shadow_bypass() argument
886 u32 emc_dbg = emc_readl(emc, EMC_DBG); in tegra210_emc_set_shadow_bypass()
889 emc_writel(emc, emc_dbg | EMC_DBG_WRITE_MUX_ACTIVE, EMC_DBG); in tegra210_emc_set_shadow_bypass()
891 emc_writel(emc, emc_dbg & ~EMC_DBG_WRITE_MUX_ACTIVE, EMC_DBG); in tegra210_emc_set_shadow_bypass()
902 void tegra210_emc_timing_update(struct tegra210_emc *emc) in tegra210_emc_timing_update() argument
907 emc_writel(emc, 0x1, EMC_TIMING_CONTROL); in tegra210_emc_timing_update()
909 for (i = 0; i < emc->num_channels; i++) { in tegra210_emc_timing_update()
910 err |= tegra210_emc_wait_for_update(emc, i, EMC_EMC_STATUS, in tegra210_emc_timing_update()
916 dev_warn(emc->dev, "timing update error: %d\n", err); in tegra210_emc_timing_update()
931 void tegra210_emc_start_periodic_compensation(struct tegra210_emc *emc) in tegra210_emc_start_periodic_compensation() argument
935 emc_writel(emc, mpc_req, EMC_MPC); in tegra210_emc_start_periodic_compensation()
936 mpc_req = emc_readl(emc, EMC_MPC); in tegra210_emc_start_periodic_compensation()
1139 u32 tegra210_emc_dll_prelock(struct tegra210_emc *emc, u32 clksrc) in tegra210_emc_dll_prelock() argument
1144 value = emc_readl(emc, EMC_CFG_DIG_DLL); in tegra210_emc_dll_prelock()
1153 emc_writel(emc, value, EMC_CFG_DIG_DLL); in tegra210_emc_dll_prelock()
1154 emc_writel(emc, 1, EMC_TIMING_CONTROL); in tegra210_emc_dll_prelock()
1156 for (i = 0; i < emc->num_channels; i++) in tegra210_emc_dll_prelock()
1157 tegra210_emc_wait_for_update(emc, i, EMC_EMC_STATUS, in tegra210_emc_dll_prelock()
1161 for (i = 0; i < emc->num_channels; i++) { in tegra210_emc_dll_prelock()
1163 value = emc_channel_readl(emc, i, EMC_CFG_DIG_DLL); in tegra210_emc_dll_prelock()
1169 value = emc->next->burst_regs[EMC_DLL_CFG_0_INDEX]; in tegra210_emc_dll_prelock()
1170 emc_writel(emc, value, EMC_DLL_CFG_0); in tegra210_emc_dll_prelock()
1172 value = emc_readl(emc, EMC_DLL_CFG_1); in tegra210_emc_dll_prelock()
1175 if (emc->next->rate >= 400000 && emc->next->rate < 600000) in tegra210_emc_dll_prelock()
1177 else if (emc->next->rate >= 600000 && emc->next->rate < 800000) in tegra210_emc_dll_prelock()
1179 else if (emc->next->rate >= 800000 && emc->next->rate < 1000000) in tegra210_emc_dll_prelock()
1181 else if (emc->next->rate >= 1000000 && emc->next->rate < 1200000) in tegra210_emc_dll_prelock()
1186 emc_writel(emc, value, EMC_DLL_CFG_1); in tegra210_emc_dll_prelock()
1188 tegra210_change_dll_src(emc, clksrc); in tegra210_emc_dll_prelock()
1190 value = emc_readl(emc, EMC_CFG_DIG_DLL); in tegra210_emc_dll_prelock()
1192 emc_writel(emc, value, EMC_CFG_DIG_DLL); in tegra210_emc_dll_prelock()
1194 tegra210_emc_timing_update(emc); in tegra210_emc_dll_prelock()
1196 for (i = 0; i < emc->num_channels; i++) { in tegra210_emc_dll_prelock()
1198 value = emc_channel_readl(emc, 0, EMC_CFG_DIG_DLL); in tegra210_emc_dll_prelock()
1205 value = emc_readl(emc, EMC_DIG_DLL_STATUS); in tegra210_emc_dll_prelock()
1216 value = emc_readl(emc, EMC_DIG_DLL_STATUS); in tegra210_emc_dll_prelock()
1221 u32 tegra210_emc_dvfs_power_ramp_up(struct tegra210_emc *emc, u32 clk, in tegra210_emc_dvfs_power_ramp_up() argument
1228 timing = emc->last; in tegra210_emc_dvfs_power_ramp_up()
1230 timing = emc->next; in tegra210_emc_dvfs_power_ramp_up()
1241 ccfifo_writel(emc, common_tx & 0xa, in tegra210_emc_dvfs_power_ramp_up()
1243 ccfifo_writel(emc, common_tx & 0xf, in tegra210_emc_dvfs_power_ramp_up()
1248 ccfifo_writel(emc, common_tx | 0x8, in tegra210_emc_dvfs_power_ramp_up()
1260 ccfifo_writel(emc, cmd_pad, in tegra210_emc_dvfs_power_ramp_up()
1271 ccfifo_writel(emc, dq_pad, in tegra210_emc_dvfs_power_ramp_up()
1273 ccfifo_writel(emc, rfu1 & 0xfe40fe40, in tegra210_emc_dvfs_power_ramp_up()
1276 ccfifo_writel(emc, rfu1 & 0xfe40fe40, in tegra210_emc_dvfs_power_ramp_up()
1282 ccfifo_writel(emc, rfu1 & 0xfeedfeed, in tegra210_emc_dvfs_power_ramp_up()
1292 ccfifo_writel(emc, cmd_pad, in tegra210_emc_dvfs_power_ramp_up()
1302 ccfifo_writel(emc, dq_pad, in tegra210_emc_dvfs_power_ramp_up()
1304 ccfifo_writel(emc, rfu1, in tegra210_emc_dvfs_power_ramp_up()
1307 ccfifo_writel(emc, rfu1, in tegra210_emc_dvfs_power_ramp_up()
1313 ccfifo_writel(emc, cfg5 & ~EMC_FBIO_CFG5_CMD_TX_DIS, in tegra210_emc_dvfs_power_ramp_up()
1317 ccfifo_writel(emc, rfu1 | 0x06000600, in tegra210_emc_dvfs_power_ramp_up()
1319 ccfifo_writel(emc, cfg5 & ~EMC_FBIO_CFG5_CMD_TX_DIS, in tegra210_emc_dvfs_power_ramp_up()
1323 ccfifo_writel(emc, rfu1 | 0x00000600, in tegra210_emc_dvfs_power_ramp_up()
1325 ccfifo_writel(emc, cfg5 & ~EMC_FBIO_CFG5_CMD_TX_DIS, in tegra210_emc_dvfs_power_ramp_up()
1331 ccfifo_writel(emc, cmd_pad, EMC_PMACRO_CMD_PAD_TX_CTRL, 5); in tegra210_emc_dvfs_power_ramp_up()
1336 u32 tegra210_emc_dvfs_power_ramp_down(struct tegra210_emc *emc, u32 clk, in tegra210_emc_dvfs_power_ramp_down() argument
1344 entry = emc->next; in tegra210_emc_dvfs_power_ramp_down()
1346 entry = emc->last; in tegra210_emc_dvfs_power_ramp_down()
1356 ccfifo_writel(emc, cmd_pad, EMC_PMACRO_CMD_PAD_TX_CTRL, 0); in tegra210_emc_dvfs_power_ramp_down()
1357 ccfifo_writel(emc, cfg5 | EMC_FBIO_CFG5_CMD_TX_DIS, in tegra210_emc_dvfs_power_ramp_down()
1371 ccfifo_writel(emc, cmd_pad, in tegra210_emc_dvfs_power_ramp_down()
1381 ccfifo_writel(emc, dq_pad, in tegra210_emc_dvfs_power_ramp_down()
1383 ccfifo_writel(emc, rfu1 & ~0x01120112, in tegra210_emc_dvfs_power_ramp_down()
1386 ccfifo_writel(emc, rfu1 & ~0x01120112, in tegra210_emc_dvfs_power_ramp_down()
1391 ccfifo_writel(emc, rfu1 & ~0x01bf01bf, in tegra210_emc_dvfs_power_ramp_down()
1401 ccfifo_writel(emc, cmd_pad, in tegra210_emc_dvfs_power_ramp_down()
1410 ccfifo_writel(emc, dq_pad, in tegra210_emc_dvfs_power_ramp_down()
1412 ccfifo_writel(emc, rfu1 & ~0x07ff07ff, in tegra210_emc_dvfs_power_ramp_down()
1415 ccfifo_writel(emc, rfu1 & ~0x07ff07ff, in tegra210_emc_dvfs_power_ramp_down()
1420 ccfifo_writel(emc, rfu1 & ~0xffff07ff, in tegra210_emc_dvfs_power_ramp_down()
1427 ccfifo_writel(emc, common_tx & ~0x5, in tegra210_emc_dvfs_power_ramp_down()
1430 ccfifo_writel(emc, common_tx & ~0xf, in tegra210_emc_dvfs_power_ramp_down()
1433 ccfifo_writel(emc, 0, 0, seq_wait); in tegra210_emc_dvfs_power_ramp_down()
1436 ccfifo_writel(emc, common_tx & ~0xf, in tegra210_emc_dvfs_power_ramp_down()
1459 static void update_dll_control(struct tegra210_emc *emc, u32 value, bool state) in update_dll_control() argument
1463 emc_writel(emc, value, EMC_CFG_DIG_DLL); in update_dll_control()
1464 tegra210_emc_timing_update(emc); in update_dll_control()
1466 for (i = 0; i < emc->num_channels; i++) in update_dll_control()
1467 tegra210_emc_wait_for_update(emc, i, EMC_CFG_DIG_DLL, in update_dll_control()
1472 void tegra210_emc_dll_disable(struct tegra210_emc *emc) in tegra210_emc_dll_disable() argument
1476 value = emc_readl(emc, EMC_CFG_DIG_DLL); in tegra210_emc_dll_disable()
1479 update_dll_control(emc, value, false); in tegra210_emc_dll_disable()
1482 void tegra210_emc_dll_enable(struct tegra210_emc *emc) in tegra210_emc_dll_enable() argument
1486 value = emc_readl(emc, EMC_CFG_DIG_DLL); in tegra210_emc_dll_enable()
1489 update_dll_control(emc, value, true); in tegra210_emc_dll_enable()
1492 void tegra210_emc_adjust_timing(struct tegra210_emc *emc, in tegra210_emc_adjust_timing() argument
1499 switch (emc->refresh) { in tegra210_emc_adjust_timing()
1517 dev_warn(emc->dev, "failed to set refresh: %d\n", emc->refresh); in tegra210_emc_adjust_timing()
1521 emc_writel(emc, ref, emc->offsets->burst[EMC_REFRESH_INDEX]); in tegra210_emc_adjust_timing()
1522 emc_writel(emc, pre_ref, in tegra210_emc_adjust_timing()
1523 emc->offsets->burst[EMC_PRE_REFRESH_REQ_CNT_INDEX]); in tegra210_emc_adjust_timing()
1524 emc_writel(emc, dsr_cntrl, in tegra210_emc_adjust_timing()
1525 emc->offsets->burst[EMC_DYN_SELF_REF_CONTROL_INDEX]); in tegra210_emc_adjust_timing()
1531 struct tegra210_emc *emc = dev_get_drvdata(dev); in tegra210_emc_set_rate() local
1538 if (rate == emc->last->rate * 1000UL) in tegra210_emc_set_rate()
1541 for (i = 0; i < emc->num_timings; i++) { in tegra210_emc_set_rate()
1542 if (emc->timings[i].rate * 1000UL == rate) { in tegra210_emc_set_rate()
1543 timing = &emc->timings[i]; in tegra210_emc_set_rate()
1554 emc->next = timing; in tegra210_emc_set_rate()
1555 last_change_delay = ktime_us_delta(ktime_get(), emc->clkchange_time); in tegra210_emc_set_rate()
1559 (last_change_delay < emc->clkchange_delay)) in tegra210_emc_set_rate()
1560 udelay(emc->clkchange_delay - (int)last_change_delay); in tegra210_emc_set_rate()
1562 spin_lock_irqsave(&emc->lock, flags); in tegra210_emc_set_rate()
1563 tegra210_emc_set_clock(emc, config->value); in tegra210_emc_set_rate()
1564 emc->clkchange_time = ktime_get(); in tegra210_emc_set_rate()
1565 emc->last = timing; in tegra210_emc_set_rate()
1566 spin_unlock_irqrestore(&emc->lock, flags); in tegra210_emc_set_rate()
1596 static bool tegra210_emc_validate_rate(struct tegra210_emc *emc, in tegra210_emc_validate_rate() argument
1601 for (i = 0; i < emc->num_timings; i++) in tegra210_emc_validate_rate()
1602 if (rate == emc->timings[i].rate * 1000UL) in tegra210_emc_validate_rate()
1611 struct tegra210_emc *emc = s->private; in tegra210_emc_debug_available_rates_show() local
1615 for (i = 0; i < emc->num_timings; i++) { in tegra210_emc_debug_available_rates_show()
1616 seq_printf(s, "%s%u", prefix, emc->timings[i].rate * 1000); in tegra210_emc_debug_available_rates_show()
1641 struct tegra210_emc *emc = data; in tegra210_emc_debug_min_rate_get() local
1643 *rate = emc->debugfs.min_rate; in tegra210_emc_debug_min_rate_get()
1650 struct tegra210_emc *emc = data; in tegra210_emc_debug_min_rate_set() local
1653 if (!tegra210_emc_validate_rate(emc, rate)) in tegra210_emc_debug_min_rate_set()
1656 err = clk_set_min_rate(emc->clk, rate); in tegra210_emc_debug_min_rate_set()
1660 emc->debugfs.min_rate = rate; in tegra210_emc_debug_min_rate_set()
1671 struct tegra210_emc *emc = data; in tegra210_emc_debug_max_rate_get() local
1673 *rate = emc->debugfs.max_rate; in tegra210_emc_debug_max_rate_get()
1680 struct tegra210_emc *emc = data; in tegra210_emc_debug_max_rate_set() local
1683 if (!tegra210_emc_validate_rate(emc, rate)) in tegra210_emc_debug_max_rate_set()
1686 err = clk_set_max_rate(emc->clk, rate); in tegra210_emc_debug_max_rate_set()
1690 emc->debugfs.max_rate = rate; in tegra210_emc_debug_max_rate_set()
1701 struct tegra210_emc *emc = data; in tegra210_emc_debug_temperature_get() local
1704 if (!emc->debugfs.temperature) in tegra210_emc_debug_temperature_get()
1705 value = tegra210_emc_get_temperature(emc); in tegra210_emc_debug_temperature_get()
1707 value = emc->debugfs.temperature; in tegra210_emc_debug_temperature_get()
1716 struct tegra210_emc *emc = data; in tegra210_emc_debug_temperature_set() local
1721 emc->debugfs.temperature = temperature; in tegra210_emc_debug_temperature_set()
1730 static void tegra210_emc_debugfs_init(struct tegra210_emc *emc) in tegra210_emc_debugfs_init() argument
1732 struct device *dev = emc->dev; in tegra210_emc_debugfs_init()
1736 emc->debugfs.min_rate = ULONG_MAX; in tegra210_emc_debugfs_init()
1737 emc->debugfs.max_rate = 0; in tegra210_emc_debugfs_init()
1739 for (i = 0; i < emc->num_timings; i++) { in tegra210_emc_debugfs_init()
1740 if (emc->timings[i].rate * 1000UL < emc->debugfs.min_rate) in tegra210_emc_debugfs_init()
1741 emc->debugfs.min_rate = emc->timings[i].rate * 1000UL; in tegra210_emc_debugfs_init()
1743 if (emc->timings[i].rate * 1000UL > emc->debugfs.max_rate) in tegra210_emc_debugfs_init()
1744 emc->debugfs.max_rate = emc->timings[i].rate * 1000UL; in tegra210_emc_debugfs_init()
1747 if (!emc->num_timings) { in tegra210_emc_debugfs_init()
1748 emc->debugfs.min_rate = clk_get_rate(emc->clk); in tegra210_emc_debugfs_init()
1749 emc->debugfs.max_rate = emc->debugfs.min_rate; in tegra210_emc_debugfs_init()
1752 err = clk_set_rate_range(emc->clk, emc->debugfs.min_rate, in tegra210_emc_debugfs_init()
1753 emc->debugfs.max_rate); in tegra210_emc_debugfs_init()
1756 emc->debugfs.min_rate, emc->debugfs.max_rate, in tegra210_emc_debugfs_init()
1757 emc->clk); in tegra210_emc_debugfs_init()
1761 emc->debugfs.root = debugfs_create_dir("emc", NULL); in tegra210_emc_debugfs_init()
1763 debugfs_create_file("available_rates", 0444, emc->debugfs.root, emc, in tegra210_emc_debugfs_init()
1765 debugfs_create_file("min_rate", 0644, emc->debugfs.root, emc, in tegra210_emc_debugfs_init()
1767 debugfs_create_file("max_rate", 0644, emc->debugfs.root, emc, in tegra210_emc_debugfs_init()
1769 debugfs_create_file("temperature", 0644, emc->debugfs.root, emc, in tegra210_emc_debugfs_init()
1773 static void tegra210_emc_detect(struct tegra210_emc *emc) in tegra210_emc_detect() argument
1778 value = mc_readl(emc->mc, MC_EMEM_ADR_CFG); in tegra210_emc_detect()
1781 emc->num_devices = 2; in tegra210_emc_detect()
1783 emc->num_devices = 1; in tegra210_emc_detect()
1786 value = emc_readl(emc, EMC_FBIO_CFG5); in tegra210_emc_detect()
1787 emc->dram_type = value & 0x3; in tegra210_emc_detect()
1790 value = emc_readl(emc, EMC_FBIO_CFG7); in tegra210_emc_detect()
1794 emc->num_channels = 2; in tegra210_emc_detect()
1796 emc->num_channels = 1; in tegra210_emc_detect()
1799 static int tegra210_emc_validate_timings(struct tegra210_emc *emc, in tegra210_emc_validate_timings() argument
1827 struct tegra210_emc *emc; in tegra210_emc_probe() local
1832 emc = devm_kzalloc(&pdev->dev, sizeof(*emc), GFP_KERNEL); in tegra210_emc_probe()
1833 if (!emc) in tegra210_emc_probe()
1836 emc->clk = devm_clk_get(&pdev->dev, "emc"); in tegra210_emc_probe()
1837 if (IS_ERR(emc->clk)) in tegra210_emc_probe()
1838 return PTR_ERR(emc->clk); in tegra210_emc_probe()
1840 platform_set_drvdata(pdev, emc); in tegra210_emc_probe()
1841 spin_lock_init(&emc->lock); in tegra210_emc_probe()
1842 emc->dev = &pdev->dev; in tegra210_emc_probe()
1844 emc->mc = devm_tegra_memory_controller_get(&pdev->dev); in tegra210_emc_probe()
1845 if (IS_ERR(emc->mc)) in tegra210_emc_probe()
1846 return PTR_ERR(emc->mc); in tegra210_emc_probe()
1848 emc->regs = devm_platform_ioremap_resource(pdev, 0); in tegra210_emc_probe()
1849 if (IS_ERR(emc->regs)) in tegra210_emc_probe()
1850 return PTR_ERR(emc->regs); in tegra210_emc_probe()
1853 emc->channel[i] = devm_platform_ioremap_resource(pdev, 1 + i); in tegra210_emc_probe()
1854 if (IS_ERR(emc->channel[i])) in tegra210_emc_probe()
1855 return PTR_ERR(emc->channel[i]); in tegra210_emc_probe()
1859 tegra210_emc_detect(emc); in tegra210_emc_probe()
1863 err = of_reserved_mem_device_init_by_name(emc->dev, np, "nominal"); in tegra210_emc_probe()
1865 dev_err(emc->dev, "failed to get nominal EMC table: %d\n", err); in tegra210_emc_probe()
1869 err = of_reserved_mem_device_init_by_name(emc->dev, np, "derated"); in tegra210_emc_probe()
1871 dev_err(emc->dev, "failed to get derated EMC table: %d\n", err); in tegra210_emc_probe()
1876 if (emc->nominal) { in tegra210_emc_probe()
1877 err = tegra210_emc_validate_timings(emc, emc->nominal, in tegra210_emc_probe()
1878 emc->num_timings); in tegra210_emc_probe()
1883 if (emc->derated) { in tegra210_emc_probe()
1884 err = tegra210_emc_validate_timings(emc, emc->derated, in tegra210_emc_probe()
1885 emc->num_timings); in tegra210_emc_probe()
1891 emc->timings = emc->nominal; in tegra210_emc_probe()
1894 current_rate = clk_get_rate(emc->clk) / 1000; in tegra210_emc_probe()
1896 for (i = 0; i < emc->num_timings; i++) { in tegra210_emc_probe()
1897 if (emc->timings[i].rate == current_rate) { in tegra210_emc_probe()
1898 emc->last = &emc->timings[i]; in tegra210_emc_probe()
1903 if (i == emc->num_timings) { in tegra210_emc_probe()
1904 dev_err(emc->dev, "no EMC table entry found for %lu kHz\n", in tegra210_emc_probe()
1915 if (emc->timings[0].revision == sequence->revision) { in tegra210_emc_probe()
1916 emc->sequence = sequence; in tegra210_emc_probe()
1921 if (!emc->sequence) { in tegra210_emc_probe()
1923 emc->timings[0].revision); in tegra210_emc_probe()
1928 emc->offsets = &tegra210_emc_table_register_offsets; in tegra210_emc_probe()
1929 emc->refresh = TEGRA210_EMC_REFRESH_NOMINAL; in tegra210_emc_probe()
1931 emc->provider.owner = THIS_MODULE; in tegra210_emc_probe()
1932 emc->provider.dev = &pdev->dev; in tegra210_emc_probe()
1933 emc->provider.set_rate = tegra210_emc_set_rate; in tegra210_emc_probe()
1935 emc->provider.configs = devm_kcalloc(&pdev->dev, emc->num_timings, in tegra210_emc_probe()
1936 sizeof(*emc->provider.configs), in tegra210_emc_probe()
1938 if (!emc->provider.configs) { in tegra210_emc_probe()
1943 emc->provider.num_configs = emc->num_timings; in tegra210_emc_probe()
1945 for (i = 0; i < emc->provider.num_configs; i++) { in tegra210_emc_probe()
1946 struct tegra210_emc_timing *timing = &emc->timings[i]; in tegra210_emc_probe()
1948 &emc->provider.configs[i]; in tegra210_emc_probe()
1962 err = tegra210_clk_emc_attach(emc->clk, &emc->provider); in tegra210_emc_probe()
1968 emc->clkchange_delay = 100; in tegra210_emc_probe()
1969 emc->training_interval = 100; in tegra210_emc_probe()
1970 dev_set_drvdata(emc->dev, emc); in tegra210_emc_probe()
1972 timer_setup(&emc->refresh_timer, tegra210_emc_poll_refresh, in tegra210_emc_probe()
1974 atomic_set(&emc->refresh_poll, 0); in tegra210_emc_probe()
1975 emc->refresh_poll_interval = 1000; in tegra210_emc_probe()
1977 timer_setup(&emc->training, tegra210_emc_train, 0); in tegra210_emc_probe()
1979 tegra210_emc_debugfs_init(emc); in tegra210_emc_probe()
1981 cd = devm_thermal_of_cooling_device_register(emc->dev, np, "emc", emc, in tegra210_emc_probe()
1985 dev_err(emc->dev, "failed to register cooling device: %d\n", in tegra210_emc_probe()
1993 debugfs_remove_recursive(emc->debugfs.root); in tegra210_emc_probe()
1994 tegra210_clk_emc_detach(emc->clk); in tegra210_emc_probe()
1996 of_reserved_mem_device_release(emc->dev); in tegra210_emc_probe()
2003 struct tegra210_emc *emc = platform_get_drvdata(pdev); in tegra210_emc_remove() local
2005 debugfs_remove_recursive(emc->debugfs.root); in tegra210_emc_remove()
2006 tegra210_clk_emc_detach(emc->clk); in tegra210_emc_remove()
2007 of_reserved_mem_device_release(emc->dev); in tegra210_emc_remove()
2014 struct tegra210_emc *emc = dev_get_drvdata(dev); in tegra210_emc_suspend() local
2017 err = clk_rate_exclusive_get(emc->clk); in tegra210_emc_suspend()
2019 dev_err(emc->dev, "failed to acquire clock: %d\n", err); in tegra210_emc_suspend()
2023 emc->resume_rate = clk_get_rate(emc->clk); in tegra210_emc_suspend()
2025 clk_set_rate(emc->clk, 204000000); in tegra210_emc_suspend()
2026 tegra210_clk_emc_detach(emc->clk); in tegra210_emc_suspend()
2028 dev_dbg(dev, "suspending at %lu Hz\n", clk_get_rate(emc->clk)); in tegra210_emc_suspend()
2035 struct tegra210_emc *emc = dev_get_drvdata(dev); in tegra210_emc_resume() local
2038 err = tegra210_clk_emc_attach(emc->clk, &emc->provider); in tegra210_emc_resume()
2044 clk_set_rate(emc->clk, emc->resume_rate); in tegra210_emc_resume()
2045 clk_rate_exclusive_put(emc->clk); in tegra210_emc_resume()
2047 dev_dbg(dev, "resuming at %lu Hz\n", clk_get_rate(emc->clk)); in tegra210_emc_resume()