clk.c 925 B

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. *
  4. * Copyright (C) 2011 Gabor Juhos <[email protected]>
  5. * Copyright (C) 2013 John Crispin <[email protected]>
  6. */
  7. #include <linux/kernel.h>
  8. #include <linux/init.h>
  9. #include <linux/export.h>
  10. #include <linux/clkdev.h>
  11. #include <linux/clk.h>
  12. #include <linux/clk-provider.h>
  13. #include <asm/time.h>
  14. #include "common.h"
  15. void ralink_clk_add(const char *dev, unsigned long rate)
  16. {
  17. struct clk *clk = clk_register_fixed_rate(NULL, dev, NULL, 0, rate);
  18. if (!clk)
  19. panic("failed to add clock");
  20. clkdev_create(clk, NULL, "%s", dev);
  21. }
  22. void __init plat_time_init(void)
  23. {
  24. struct clk *clk;
  25. ralink_of_remap();
  26. ralink_clk_init();
  27. clk = clk_get_sys("cpu", NULL);
  28. if (IS_ERR(clk))
  29. panic("unable to get CPU clock, err=%ld", PTR_ERR(clk));
  30. pr_info("CPU Clock: %ldMHz\n", clk_get_rate(clk) / 1000000);
  31. mips_hpt_frequency = clk_get_rate(clk) / 2;
  32. clk_put(clk);
  33. timer_probe();
  34. }