speed.c 731 B

1234567891011121314151617181920212223242526272829303132333435363738
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. *
  4. * (C) Copyright 2000-2003
  5. * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
  6. *
  7. * Copyright (C) 2004-2007, 2012 Freescale Semiconductor, Inc.
  8. * TsiChung Liew (Tsi-Chung.Liew@freescale.com)
  9. */
  10. #include <common.h>
  11. #include <asm/processor.h>
  12. #include <asm/immap.h>
  13. #include <asm/io.h>
  14. DECLARE_GLOBAL_DATA_PTR;
  15. /*
  16. * get_clocks() fills in gd->cpu_clock and gd->bus_clk
  17. */
  18. int get_clocks(void)
  19. {
  20. pll_t *pll = (pll_t *)(MMAP_PLL);
  21. out_be32(&pll->syncr, PLL_SYNCR_MFD(1));
  22. while (!(in_be32(&pll->synsr) & PLL_SYNSR_LOCK))
  23. ;
  24. gd->bus_clk = CONFIG_SYS_CLK;
  25. gd->cpu_clk = (gd->bus_clk * 2);
  26. #ifdef CONFIG_SYS_I2C_FSL
  27. gd->arch.i2c1_clk = gd->bus_clk;
  28. #endif
  29. return (0);
  30. }