123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185 |
- /**
- * \file
- *
- * \brief Oscillator management
- *
- * Copyright (c) 2010-2015 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
- *
- */
- /*
- * Support and FAQ: visit <a href="http://www.atmel.com/design-support/">Atmel Support</a>
- */
- #ifndef OSC_H_INCLUDED
- #define OSC_H_INCLUDED
- #include "parts.h"
- #include "conf_clock.h"
- #if SAM3S
- # include "sam3s/osc.h"
- #elif SAM3XA
- # include "sam3x/osc.h"
- #elif SAM3U
- # include "sam3u/osc.h"
- #elif SAM3N
- # include "sam3n/osc.h"
- #elif SAM4S
- # include "sam4s/osc.h"
- #elif SAM4E
- # include "sam4e/osc.h"
- #elif SAM4C
- # include "sam4c/osc.h"
- #elif SAM4CM
- # include "sam4cm/osc.h"
- #elif SAM4CP
- # include "sam4cp/osc.h"
- #elif SAM4L
- # include "sam4l/osc.h"
- #elif SAM4N
- # include "sam4n/osc.h"
- #elif SAMG
- # include "samg/osc.h"
- #elif SAMV71
- # include "samv71/osc.h"
- #elif SAMV70
- # include "samv70/osc.h"
- #elif SAME70
- # include "same70/osc.h"
- #elif SAMS70
- # include "sams70/osc.h"
- #elif (UC3A0 || UC3A1)
- # include "uc3a0_a1/osc.h"
- #elif UC3A3
- # include "uc3a3_a4/osc.h"
- #elif UC3B
- # include "uc3b0_b1/osc.h"
- #elif UC3C
- # include "uc3c/osc.h"
- #elif UC3D
- # include "uc3d/osc.h"
- #elif UC3L
- # include "uc3l/osc.h"
- #elif XMEGA
- # include "xmega/osc.h"
- #else
- # error Unsupported chip type
- #endif
- /**
- * \ingroup clk_group
- * \defgroup osc_group Oscillator Management
- *
- * This group contains functions and definitions related to configuring
- * and enabling/disabling on-chip oscillators. Internal RC-oscillators,
- * external crystal oscillators and external clock generators are
- * supported by this module. What all of these have in common is that
- * they swing at a fixed, nominal frequency which is normally not
- * adjustable.
- *
- * \par Example: Enabling an oscillator
- *
- * The following example demonstrates how to enable the external
- * oscillator on XMEGA A and wait for it to be ready to use. The
- * oscillator identifiers are platform-specific, so while the same
- * procedure is used on all platforms, the parameter to osc_enable()
- * will be different from device to device.
- * \code
- osc_enable(OSC_ID_XOSC);
- osc_wait_ready(OSC_ID_XOSC); \endcode
- *
- * \section osc_group_board Board-specific Definitions
- * If external oscillators are used, the board code must provide the
- * following definitions for each of those:
- * - \b BOARD_<osc name>_HZ: The nominal frequency of the oscillator.
- * - \b BOARD_<osc name>_STARTUP_US: The startup time of the
- * oscillator in microseconds.
- * - \b BOARD_<osc name>_TYPE: The type of oscillator connected, i.e.
- * whether it's a crystal or external clock, and sometimes what kind
- * of crystal it is. The meaning of this value is platform-specific.
- *
- * @{
- */
- //! \name Oscillator Management
- //@{
- /**
- * \fn void osc_enable(uint8_t id)
- * \brief Enable oscillator \a id
- *
- * The startup time and mode value is automatically determined based on
- * definitions in the board code.
- */
- /**
- * \fn void osc_disable(uint8_t id)
- * \brief Disable oscillator \a id
- */
- /**
- * \fn osc_is_ready(uint8_t id)
- * \brief Determine whether oscillator \a id is ready.
- * \retval true Oscillator \a id is running and ready to use as a clock
- * source.
- * \retval false Oscillator \a id is not running.
- */
- /**
- * \fn uint32_t osc_get_rate(uint8_t id)
- * \brief Return the frequency of oscillator \a id in Hz
- */
- #ifndef __ASSEMBLY__
- /**
- * \brief Wait until the oscillator identified by \a id is ready
- *
- * This function will busy-wait for the oscillator identified by \a id
- * to become stable and ready to use as a clock source.
- *
- * \param id A number identifying the oscillator to wait for.
- */
- static inline void osc_wait_ready(uint8_t id)
- {
- while (!osc_is_ready(id)) {
- /* Do nothing */
- }
- }
- #endif /* __ASSEMBLY__ */
- //@}
- //! @}
- #endif /* OSC_H_INCLUDED */
|