Blame view

kernel/linux-imx6_3.14.28/drivers/clk/versatile/clk-realview.c 2.54 KB
6b13f685e   김민수   BSP 최초 추가
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
  /*
   * Clock driver for the ARM RealView boards
   * Copyright (C) 2012 Linus Walleij
   *
   * This program is free software; you can redistribute it and/or modify
   * it under the terms of the GNU General Public License version 2 as
   * published by the Free Software Foundation.
   */
  #include <linux/clk.h>
  #include <linux/clkdev.h>
  #include <linux/err.h>
  #include <linux/io.h>
  #include <linux/clk-provider.h>
  
  #include <mach/hardware.h>
  #include <mach/platform.h>
  
  #include "clk-icst.h"
  
  /*
   * Implementation of the ARM RealView clock trees.
   */
  
  static const struct icst_params realview_oscvco_params = {
  	.ref		= 24000000,
  	.vco_max	= ICST307_VCO_MAX,
  	.vco_min	= ICST307_VCO_MIN,
  	.vd_min		= 4 + 8,
  	.vd_max		= 511 + 8,
  	.rd_min		= 1 + 2,
  	.rd_max		= 127 + 2,
  	.s2div		= icst307_s2div,
  	.idx2s		= icst307_idx2s,
  };
  
  static const struct clk_icst_desc __initdata realview_osc0_desc = {
  	.params = &realview_oscvco_params,
  	.vco_offset = REALVIEW_SYS_OSC0_OFFSET,
  	.lock_offset = REALVIEW_SYS_LOCK_OFFSET,
  };
  
  static const struct clk_icst_desc __initdata realview_osc4_desc = {
  	.params = &realview_oscvco_params,
  	.vco_offset = REALVIEW_SYS_OSC4_OFFSET,
  	.lock_offset = REALVIEW_SYS_LOCK_OFFSET,
  };
  
  /*
   * realview_clk_init() - set up the RealView clock tree
   */
  void __init realview_clk_init(void __iomem *sysbase, bool is_pb1176)
  {
  	struct clk *clk;
  
  	/* APB clock dummy */
  	clk = clk_register_fixed_rate(NULL, "apb_pclk", NULL, CLK_IS_ROOT, 0);
  	clk_register_clkdev(clk, "apb_pclk", NULL);
  
  	/* 24 MHz clock */
  	clk = clk_register_fixed_rate(NULL, "clk24mhz", NULL, CLK_IS_ROOT,
  				24000000);
  	clk_register_clkdev(clk, NULL, "dev:uart0");
  	clk_register_clkdev(clk, NULL, "dev:uart1");
  	clk_register_clkdev(clk, NULL, "dev:uart2");
  	clk_register_clkdev(clk, NULL, "fpga:kmi0");
  	clk_register_clkdev(clk, NULL, "fpga:kmi1");
  	clk_register_clkdev(clk, NULL, "fpga:mmc0");
  	clk_register_clkdev(clk, NULL, "dev:ssp0");
  	if (is_pb1176) {
  		/*
  		 * UART3 is on the dev chip in PB1176
  		 * UART4 only exists in PB1176
  		 */
  		clk_register_clkdev(clk, NULL, "dev:uart3");
  		clk_register_clkdev(clk, NULL, "dev:uart4");
  	} else
  		clk_register_clkdev(clk, NULL, "fpga:uart3");
  
  
  	/* 1 MHz clock */
  	clk = clk_register_fixed_rate(NULL, "clk1mhz", NULL, CLK_IS_ROOT,
  				      1000000);
  	clk_register_clkdev(clk, NULL, "sp804");
  
  	/* ICST VCO clock */
  	if (is_pb1176)
  		clk = icst_clk_register(NULL, &realview_osc0_desc,
  					"osc0", sysbase);
  	else
  		clk = icst_clk_register(NULL, &realview_osc4_desc,
  					"osc4", sysbase);
  
  	clk_register_clkdev(clk, NULL, "dev:clcd");
  	clk_register_clkdev(clk, NULL, "issp:clcd");
  }