00001 #ifndef _STM32_CLK_H_ 00002 #define _STM32_CLK_H_ 00003 00004 /* 00005 * Copyright (C) 2010 by Ulrich Prinz (uprinz2@netscape.net) 00006 * 00007 * All rights reserved. 00008 * 00009 * Redistribution and use in source and binary forms, with or without 00010 * modification, are permitted provided that the following conditions 00011 * are met: 00012 * 00013 * 1. Redistributions of source code must retain the above copyright 00014 * notice, this list of conditions and the following disclaimer. 00015 * 2. Redistributions in binary form must reproduce the above copyright 00016 * notice, this list of conditions and the following disclaimer in the 00017 * documentation and/or other materials provided with the distribution. 00018 * 3. Neither the name of the copyright holders nor the names of 00019 * contributors may be used to endorse or promote products derived 00020 * from this software without specific prior written permission. 00021 * 00022 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 00023 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 00024 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 00025 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE 00026 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 00027 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 00028 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS 00029 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED 00030 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 00031 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF 00032 * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 00033 * SUCH DAMAGE. 00034 * 00035 * For additional information see http://www.ethernut.de/ 00036 */ 00037 00038 /* 00039 * \verbatim 00040 * $Id: stm32_gpio.c 3182 2010-10-17 21:46:04Z Astralix $ 00041 * \endverbatim 00042 */ 00043 00044 /* STM32F Clock source selectors */ 00045 #define SYSCLK_HSI 0 00046 #define SYSCLK_PLL 1 00047 #define SYSCLK_HSE 2 00048 #define PLLCLK_HSI 3 00049 #define PLLCLK_HSE 4 00050 00051 /* The systems core clock frequency in Hz. */ 00052 extern uint32_t SystemCoreClock; 00053 00054 /* Control functions for the separate clocks */ 00055 extern int CtlHseClock( uint8_t ena); 00056 extern int CtlHsiClock( uint8_t ena); 00057 extern int CtlPllClock( uint8_t ena); 00058 00059 /* Selection functions for the clock sources */ 00060 extern int SetPllClock( int src); 00061 extern int SetPllClockSource( int src); 00062 extern int SetSysClock(void); 00063 extern uint32_t SysCtlClockGet(void); 00064 00065 #endif /* _STM32_CLK_H_ */