/** | |
* \file | |
* | |
* \brief Chip-specific oscillator management functions. | |
* | |
* Copyright (c) 2011-2012 Atmel Corporation. All rights reserved. | |
* | |
* \asf_license_start | |
* | |
* \page License | |
* | |
* Redistribution and use in source and binary forms, with or without | |
* modification, are permitted provided that the following conditions are met: | |
* | |
* 1. Redistributions of source code must retain the above copyright notice, | |
* this list of conditions and the following disclaimer. | |
* | |
* 2. Redistributions in binary form must reproduce the above copyright notice, | |
* this list of conditions and the following disclaimer in the documentation | |
* and/or other materials provided with the distribution. | |
* | |
* 3. The name of Atmel may not be used to endorse or promote products derived | |
* from this software without specific prior written permission. | |
* | |
* 4. This software may only be redistributed and used in connection with an | |
* Atmel microcontroller product. | |
* | |
* THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR IMPLIED | |
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF | |
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE | |
* EXPRESSLY AND SPECIFICALLY DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR | |
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | |
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS | |
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) | |
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, | |
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN | |
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE | |
* POSSIBILITY OF SUCH DAMAGE. | |
* | |
* \asf_license_stop | |
* | |
*/ | |
#ifndef CHIP_OSC_H_INCLUDED | |
#define CHIP_OSC_H_INCLUDED | |
#include "board.h" | |
#include "pmc.h" | |
/// @cond 0 | |
/**INDENT-OFF**/ | |
#ifdef __cplusplus | |
extern "C" { | |
#endif | |
/**INDENT-ON**/ | |
/// @endcond | |
/** | |
* \weakgroup osc_group | |
* @{ | |
*/ | |
//! \name Oscillator identifiers | |
//@{ | |
#define OSC_SLCK_32K_RC 0 //!< Internal 32kHz RC oscillator. | |
#define OSC_SLCK_32K_XTAL 1 //!< External 32kHz crystal oscillator. | |
#define OSC_SLCK_32K_BYPASS 2 //!< External 32kHz bypass oscillator. | |
#define OSC_MAINCK_4M_RC 3 //!< Internal 4MHz RC oscillator. | |
#define OSC_MAINCK_8M_RC 4 //!< Internal 8MHz RC oscillator. | |
#define OSC_MAINCK_12M_RC 5 //!< Internal 12MHz RC oscillator. | |
#define OSC_MAINCK_XTAL 6 //!< External crystal oscillator. | |
#define OSC_MAINCK_BYPASS 7 //!< External bypass oscillator. | |
//@} | |
//! \name Oscillator clock speed in hertz | |
//@{ | |
#define OSC_SLCK_32K_RC_HZ CHIP_FREQ_SLCK_RC //!< Internal 32kHz RC oscillator. | |
#define OSC_SLCK_32K_XTAL_HZ BOARD_FREQ_SLCK_XTAL //!< External 32kHz crystal oscillator. | |
#define OSC_SLCK_32K_BYPASS_HZ BOARD_FREQ_SLCK_BYPASS //!< External 32kHz bypass oscillator. | |
#define OSC_MAINCK_4M_RC_HZ CHIP_FREQ_MAINCK_RC_4MHZ //!< Internal 4MHz RC oscillator. | |
#define OSC_MAINCK_8M_RC_HZ CHIP_FREQ_MAINCK_RC_8MHZ //!< Internal 8MHz RC oscillator. | |
#define OSC_MAINCK_12M_RC_HZ CHIP_FREQ_MAINCK_RC_12MHZ //!< Internal 12MHz RC oscillator. | |
#define OSC_MAINCK_XTAL_HZ BOARD_FREQ_MAINCK_XTAL //!< External crystal oscillator. | |
#define OSC_MAINCK_BYPASS_HZ BOARD_FREQ_MAINCK_BYPASS //!< External bypass oscillator. | |
//@} | |
static inline void osc_enable(uint32_t ul_id) | |
{ | |
switch (ul_id) { | |
case OSC_SLCK_32K_RC: | |
break; | |
case OSC_SLCK_32K_XTAL: | |
pmc_switch_sclk_to_32kxtal(PMC_OSC_XTAL); | |
break; | |
case OSC_SLCK_32K_BYPASS: | |
pmc_switch_sclk_to_32kxtal(PMC_OSC_BYPASS); | |
break; | |
case OSC_MAINCK_4M_RC: | |
pmc_switch_mainck_to_fastrc(CKGR_MOR_MOSCRCF_4_MHz); | |
break; | |
case OSC_MAINCK_8M_RC: | |
pmc_switch_mainck_to_fastrc(CKGR_MOR_MOSCRCF_8_MHz); | |
break; | |
case OSC_MAINCK_12M_RC: | |
pmc_switch_mainck_to_fastrc(CKGR_MOR_MOSCRCF_12_MHz); | |
break; | |
case OSC_MAINCK_XTAL: | |
pmc_switch_mainck_to_xtal(PMC_OSC_XTAL); | |
break; | |
case OSC_MAINCK_BYPASS: | |
pmc_switch_mainck_to_xtal(PMC_OSC_BYPASS); | |
break; | |
} | |
} | |
static inline void osc_disable(uint32_t ul_id) | |
{ | |
switch (ul_id) { | |
case OSC_SLCK_32K_RC: | |
case OSC_SLCK_32K_XTAL: | |
case OSC_SLCK_32K_BYPASS: | |
break; | |
case OSC_MAINCK_4M_RC: | |
case OSC_MAINCK_8M_RC: | |
case OSC_MAINCK_12M_RC: | |
pmc_osc_disable_fastrc(); | |
break; | |
case OSC_MAINCK_XTAL: | |
pmc_osc_disable_xtal(PMC_OSC_XTAL); | |
break; | |
case OSC_MAINCK_BYPASS: | |
pmc_osc_disable_xtal(PMC_OSC_BYPASS); | |
break; | |
} | |
} | |
static inline bool osc_is_ready(uint32_t ul_id) | |
{ | |
switch (ul_id) { | |
case OSC_SLCK_32K_RC: | |
return 1; | |
case OSC_SLCK_32K_XTAL: | |
case OSC_SLCK_32K_BYPASS: | |
return pmc_osc_is_ready_32kxtal(); | |
case OSC_MAINCK_4M_RC: | |
case OSC_MAINCK_8M_RC: | |
case OSC_MAINCK_12M_RC: | |
case OSC_MAINCK_XTAL: | |
case OSC_MAINCK_BYPASS: | |
return pmc_osc_is_ready_mainck(); | |
} | |
return 0; | |
} | |
static inline uint32_t osc_get_rate(uint32_t ul_id) | |
{ | |
switch (ul_id) { | |
case OSC_SLCK_32K_RC: | |
return OSC_SLCK_32K_RC_HZ; | |
#ifdef BOARD_FREQ_SLCK_XTAL | |
case OSC_SLCK_32K_XTAL: | |
return BOARD_FREQ_SLCK_XTAL; | |
#endif | |
#ifdef BOARD_FREQ_SLCK_BYPASS | |
case OSC_SLCK_32K_BYPASS: | |
return BOARD_FREQ_SLCK_BYPASS; | |
#endif | |
case OSC_MAINCK_4M_RC: | |
return OSC_MAINCK_4M_RC_HZ; | |
case OSC_MAINCK_8M_RC: | |
return OSC_MAINCK_8M_RC_HZ; | |
case OSC_MAINCK_12M_RC: | |
return OSC_MAINCK_12M_RC_HZ; | |
#ifdef BOARD_FREQ_MAINCK_XTAL | |
case OSC_MAINCK_XTAL: | |
return BOARD_FREQ_MAINCK_XTAL; | |
#endif | |
#ifdef BOARD_FREQ_MAINCK_BYPASS | |
case OSC_MAINCK_BYPASS: | |
return BOARD_FREQ_MAINCK_BYPASS; | |
#endif | |
} | |
return 0; | |
} | |
//! @} | |
/// @cond 0 | |
/**INDENT-OFF**/ | |
#ifdef __cplusplus | |
} | |
#endif | |
/**INDENT-ON**/ | |
/// @endcond | |
#endif /* CHIP_OSC_H_INCLUDED */ |