]> git.sur5r.net Git - freertos/blob - FreeRTOS/Demo/T-HEAD_CB2201_CDK/csi/csi_driver/csky/hobbit1_2/include/ck_sys_freq.h
Introduce a port for T-HEAD CK802. A simple demo for T-HEAD CB2201 is also included.
[freertos] / FreeRTOS / Demo / T-HEAD_CB2201_CDK / csi / csi_driver / csky / hobbit1_2 / include / ck_sys_freq.h
1 /*
2  * Copyright (C) 2017 C-SKY Microsystems Co., Ltd. All rights reserved.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *   http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 /******************************************************************************
17  * @file     ck_sys_freq.h
18  * @brief    header file for setting system frequency.
19  * @version  V1.0
20  * @date     18. July 2017
21  ******************************************************************************/
22 #ifndef _CK_SYS_FREQ_H_
23 #define _CK_SYS_FREQ_H_
24
25 #include <stdint.h>
26 #include "soc.h"
27
28 #define PMU_MCLK_SEL  (CSKY_CLKGEN_BASE + 0x4)
29 #define MCLK_REG_VAL  0x8UL
30
31 #define PMU_CLK_STABLE  (CSKY_CLKGEN_BASE + 0x18)
32 #define PMU_PLL_CTRL  (CSKY_CLKGEN_BASE + 0x2c)
33
34 #define TRC_ADDR (CSKY_OTP_BASE + 0x20)
35 #define TRC_REG_VAL  0x1UL
36
37 #define EXTERNAL_CLK_SOURCE  0x8UL
38 #define EXTERNAL_CLK_16M     (EXTERNAL_CLK_SOURCE * 2)
39 #define EXTERNAL_CLK_24M     (EXTERNAL_CLK_SOURCE * 3)
40 #define EXTERNAL_CLK_32M     (EXTERNAL_CLK_SOURCE * 4)
41 #define EXTERNAL_CLK_40M     (EXTERNAL_CLK_SOURCE * 5)
42 #define EXTERNAL_CLK_48M     (EXTERNAL_CLK_SOURCE * 6)
43
44 #define CLK_8M_REG_VAL        0xc0202UL
45 #define CLK_16M_REG_VAL       0xc0204UL
46 #define CLK_24M_REG_VAL       0xc0206UL
47 #define CLK_32M_REG_VAL       0xc0208UL
48 #define CLK_40M_REG_VAL       0xc020aUL
49 #define CLK_48M_REG_VAL       0xc020cUL
50
51 typedef enum {
52     IHS_CLK       = 0,          //internal high speed clock
53     EHS_CLK       = 1          //external high speed clock
54 } clk_gen_t;
55
56 typedef enum {
57     CLK_8M       = 0,
58     CLK_16M      = 1,
59     CLK_24M      = 2,
60     CLK_32M      = 3,
61     CLK_40M      = 4,
62     CLK_48M      = 5
63 } clk_val_t;
64
65 void ck_set_sys_freq (clk_gen_t source, clk_val_t val);
66
67 #endif /* _CK_SYS_FREQ_H_ */
68