]> git.sur5r.net Git - freertos/blob - FreeRTOS/Demo/CORTEX_A5_SAMA5D4x_EK_IAR/AtmelFiles/libchip_sama5d4x/include/pmc.h
Core kernel files:
[freertos] / FreeRTOS / Demo / CORTEX_A5_SAMA5D4x_EK_IAR / AtmelFiles / libchip_sama5d4x / include / pmc.h
1 /* ----------------------------------------------------------------------------\r
2  *         SAM Software Package License \r
3  * ----------------------------------------------------------------------------\r
4  * Copyright (c) 2011, Atmel Corporation\r
5  *\r
6  * All rights reserved.\r
7  *\r
8  * Redistribution and use in source and binary forms, with or without\r
9  * modification, are permitted provided that the following conditions are met:\r
10  *\r
11  * - Redistributions of source code must retain the above copyright notice,\r
12  * this list of conditions and the disclaimer below.\r
13  *\r
14  * Atmel's name may not be used to endorse or promote products derived from\r
15  * this software without specific prior written permission.\r
16  *\r
17  * DISCLAIMER: THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR\r
18  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF\r
19  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE\r
20  * DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT,\r
21  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\r
22  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\r
23  * OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\r
24  * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\r
25  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\r
26  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\r
27  * ----------------------------------------------------------------------------\r
28  */\r
29 \r
30 #ifndef _PMC_\r
31 #define _PMC_\r
32 \r
33 /*----------------------------------------------------------------------------\r
34  *        Headers\r
35  *----------------------------------------------------------------------------*/\r
36 #include <stdint.h>\r
37 \r
38 \r
39 /*----------------------------------------------------------------------------\r
40  *        Types\r
41  *----------------------------------------------------------------------------*/\r
42 \r
43 /** Peripheral clock maxinum frequency */\r
44 typedef struct _PeripheralClockMaxFreq {\r
45     uint32_t bPeriphID;             /**< Peripheral ID */\r
46     uint32_t bMaxFrequency;         /**< Max frequency*/\r
47 } PeripheralClockMaxFreq;\r
48 \r
49 /*----------------------------------------------------------------------------\r
50  *        Exported functions\r
51  *----------------------------------------------------------------------------*/\r
52 \r
53 #ifdef __cplusplus\r
54  extern "C" {\r
55 #endif\r
56 \r
57 extern void PMC_EnablePeripheral( uint32_t dwId ) ;\r
58 extern void PMC_DisablePeripheral( uint32_t dwId ) ;\r
59 \r
60 extern void PMC_EnableAllPeripherals( void ) ;\r
61 extern void PMC_DisableAllPeripherals( void ) ;\r
62 \r
63 extern uint32_t PMC_IsPeriphEnabled( uint32_t dwId ) ;\r
64 \r
65 extern void PMC_SelectExt32KCrystal(void);\r
66 extern void PMC_SelectInt32kCrystal(void);\r
67 extern void PMC_SelectExt12M_Osc(void);\r
68 extern void PMC_SelectInt12M_Osc(void);\r
69 extern void PMC_SwitchMck2Pll(void);\r
70 extern void PMC_SwitchMck2Main(void);\r
71 extern uint32_t PMC_SwitchMck2Slck(void);\r
72 extern void PMC_SetPllA(uint32_t pll, uint32_t cpcr);\r
73 extern void PMC_SetMckPrescaler(uint32_t prescaler);\r
74 extern void PMC_SetMckDivider(uint32_t divider);\r
75 extern void PMC_SetMckPllaDiv(uint32_t divider);\r
76 extern void PMC_DisablePllA(void);\r
77 extern uint32_t PMC_GetPeriMaxFreq( uint32_t dwId );\r
78 extern uint32_t PMC_SetPeriMaxClock( uint32_t dwId, uint32_t mck);\r
79 #ifdef __cplusplus\r
80 }\r
81 #endif\r
82 \r
83 #endif /* #ifndef _PMC_ */\r
84 \r