* arch/arm/src/samd2l2/hardware/saml_oscctrl.h
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
* "Atmel SAM L21E / SAM L21G / SAM L21J Smart ARM-Based Microcontroller
* Datasheet", Atmel-42385C-SAML21_Datasheet_Preliminary-03/20/15
*/
#ifndef __ARCH_ARM_SRC_SAMD2L2_HARDWARE_SAML_OSCCTRL_H
#define __ARCH_ARM_SRC_SAMD2L2_HARDWARE_SAML_OSCCTRL_H
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#include "chip.h"
#ifdef CONFIG_ARCH_FAMILY_SAML21
* Pre-processor Definitions
****************************************************************************/
#define SAM_OSCCTRL_INTENCLR_OFFSET 0x0000
#define SAM_OSCCTRL_INTENSET_OFFSET 0x0004
#define SAM_OSCCTRL_INTFLAG_OFFSET 0x0008
#define SAM_OSCCTRL_STATUS_OFFSET 0x000c
#define SAM_OSCCTRL_XOSCCTRL_OFFSET 0x0010
#define SAM_OSCCTRL_OSC16MCTRL_OFFSET 0x0014
#define SAM_OSCCTRL_DFLLCTRL_OFFSET 0x0018
#define SAM_OSCCTRL_DFLLVAL_OFFSET 0x001c
#define SAM_OSCCTRL_DFLLMUL_OFFSET 0x0020
#define SAM_OSCCTRL_DFLLSYNC_OFFSET 0x0024
#define SAM_OSCCTRL_DPLLCTRLA_OFFSET 0x0028
#define SAM_OSCCTRL_DPLLRATIO_OFFSET 0x002c
#define SAM_OSCCTRL_DPLLCTRLB_OFFSET 0x0030
#define SAM_OSCCTRL_DPLLPRESC_OFFSET 0x0034
#define SAM_OSCCTRL_DPLLSYNCBUSY_OFFSET 0x0038
#define SAM_OSCCTRL_DPLLSTATUS_OFFSET 0x003c
#define SAM_OSCCTRL_INTENCLR (SAM_OSCCTRL_BASE+SAM_OSCCTRL_INTENCLR_OFFSET)
#define SAM_OSCCTRL_INTENSET (SAM_OSCCTRL_BASE+SAM_OSCCTRL_INTENSET_OFFSET)
#define SAM_OSCCTRL_INTFLAG (SAM_OSCCTRL_BASE+SAM_OSCCTRL_INTFLAG_OFFSET)
#define SAM_OSCCTRL_STATUS (SAM_OSCCTRL_BASE+SAM_OSCCTRL_STATUS_OFFSET)
#define SAM_OSCCTRL_XOSCCTRL (SAM_OSCCTRL_BASE+SAM_OSCCTRL_XOSCCTRL_OFFSET)
#define SAM_OSCCTRL_OSC16MCTRL (SAM_OSCCTRL_BASE+SAM_OSCCTRL_OSC16MCTRL_OFFSET)
#define SAM_OSCCTRL_DFLLCTRL (SAM_OSCCTRL_BASE+SAM_OSCCTRL_DFLLCTRL_OFFSET)
#define SAM_OSCCTRL_DFLLVAL (SAM_OSCCTRL_BASE+SAM_OSCCTRL_DFLLVAL_OFFSET)
#define SAM_OSCCTRL_DFLLMUL (SAM_OSCCTRL_BASE+SAM_OSCCTRL_DFLLMUL_OFFSET)
#define SAM_OSCCTRL_DFLLSYNC (SAM_OSCCTRL_BASE+SAM_OSCCTRL_DFLLSYNC_OFFSET)
#define SAM_OSCCTRL_DPLLCTRLA (SAM_OSCCTRL_BASE+SAM_OSCCTRL_DPLLCTRLA_OFFSET)
#define SAM_OSCCTRL_DPLLRATIO (SAM_OSCCTRL_BASE+SAM_OSCCTRL_DPLLRATIO_OFFSET)
#define SAM_OSCCTRL_DPLLCTRLB (SAM_OSCCTRL_BASE+SAM_OSCCTRL_DPLLCTRLB_OFFSET)
#define SAM_OSCCTRL_DPLLPRESC (SAM_OSCCTRL_BASE+SAM_OSCCTRL_DPLLPRESC_OFFSET)
#define SAM_OSCCTRL_DPLLSYNCBUSY (SAM_OSCCTRL_BASE+SAM_OSCCTRL_DPLLSYNCBUSY_OFFSET)
#define SAM_OSCCTRL_DPLLSTATUS (SAM_OSCCTRL_BASE+SAM_OSCCTRL_DPLLSTATUS_OFFSET)
* clear, and Status registers.
*/
#define OSCCTRL_INT_XOSCRDY (1 << 0)
#define OSCCTRL_INT_OSC16MRDY (1 << 4)
#define OSCCTRL_INT_DFLLRDY (1 << 8)
#define OSCCTRL_INT_DFLLOOB (1 << 9)
#define OSCCTRL_INT_DFLLLCKF (1 << 10)
#define OSCCTRL_INT_DFLLLCKC (1 << 11)
#define OSCCTRL_INT_DFLLRCS (1 << 12)
#define OSCCTRL_INT_DPLLLCKR (1 << 16)
#define OSCCTRL_INT_DPLLLCKF (1 << 17)
#define OSCCTRL_INT_DPLLLTP (1 << 18)
#define OSCCTRL_INT_DPLLDRTO (1 << 19)
#define OSCCTRL_INT_ALL (0x000f1f11)
#define OSCCTRL_XOSCCTRL_ENABLE (1 << 1)
#define OSCCTRL_XOSCCTRL_XTALEN (1 << 2)
#define OSCCTRL_XOSCCTRL_RUNSTDBY (1 << 6)
#define OSCCTRL_XOSCCTRL_ONDEMAND (1 << 7)
#define OSCCTRL_XOSCCTRL_GAIN_SHIFT (8)
#define OSCCTRL_XOSCCTRL_GAIN_MASK (7 << OSCCTRL_XOSCCTRL_GAIN_SHIFT)
# define OSCCTRL_XOSCCTRL_GAIN(n) ((n) << OSCCTRL_XOSCCTRL_GAIN_SHIFT)
# define OSCCTRL_XOSCCTRL_GAIN_2MHZ (0 << OSCCTRL_XOSCCTRL_GAIN_SHIFT)
# define OSCCTRL_XOSCCTRL_GAIN_4MHZ (1 << OSCCTRL_XOSCCTRL_GAIN_SHIFT)
# define OSCCTRL_XOSCCTRL_GAIN_8MHZ (2 << OSCCTRL_XOSCCTRL_GAIN_SHIFT)
# define OSCCTRL_XOSCCTRL_GAIN_16MHZ (3 << OSCCTRL_XOSCCTRL_GAIN_SHIFT)
# define OSCCTRL_XOSCCTRL_GAIN_30MHZ (4 << OSCCTRL_XOSCCTRL_GAIN_SHIFT)
#define OSCCTRL_XOSCCTRL_AMPGC (1 << 11)
#define OSCCTRL_XOSCCTRL_STARTUP_SHIFT (12)
#define OSCCTRL_XOSCCTRL_STARTUP_MASK (15 << OSCCTRL_XOSCCTRL_STARTUP_SHIFT)
# define OSCCTRL_XOSCCTRL_STARTUP(n) ((n) << OSCCTRL_XOSCCTRL_STARTUP_SHIFT)
# define OSCCTRL_XOSCCTRL_STARTUP_31US (0 << OSCCTRL_XOSCCTRL_STARTUP_SHIFT)
# define OSCCTRL_XOSCCTRL_STARTUP_61US (1 << OSCCTRL_XOSCCTRL_STARTUP_SHIFT)
# define OSCCTRL_XOSCCTRL_STARTUP_122US (2 << OSCCTRL_XOSCCTRL_STARTUP_SHIFT)
# define OSCCTRL_XOSCCTRL_STARTUP_244US (3 << OSCCTRL_XOSCCTRL_STARTUP_SHIFT)
# define OSCCTRL_XOSCCTRL_STARTUP_488US (4 << OSCCTRL_XOSCCTRL_STARTUP_SHIFT)
# define OSCCTRL_XOSCCTRL_STARTUP_977US (5 << OSCCTRL_XOSCCTRL_STARTUP_SHIFT)
# define OSCCTRL_XOSCCTRL_STARTUP_2MS (6 << OSCCTRL_XOSCCTRL_STARTUP_SHIFT)
# define OSCCTRL_XOSCCTRL_STARTUP_4MS (7 << OSCCTRL_XOSCCTRL_STARTUP_SHIFT)
# define OSCCTRL_XOSCCTRL_STARTUP_8MS (8 << OSCCTRL_XOSCCTRL_STARTUP_SHIFT)
# define OSCCTRL_XOSCCTRL_STARTUP_16MS (9 << OSCCTRL_XOSCCTRL_STARTUP_SHIFT)
# define OSCCTRL_XOSCCTRL_STARTUP_31MS (10 << OSCCTRL_XOSCCTRL_STARTUP_SHIFT)
# define OSCCTRL_XOSCCTRL_STARTUP_63MS (11 << OSCCTRL_XOSCCTRL_STARTUP_SHIFT)
# define OSCCTRL_XOSCCTRL_STARTUP_125MS (12 << OSCCTRL_XOSCCTRL_STARTUP_SHIFT)
# define OSCCTRL_XOSCCTRL_STARTUP_250MS (13 << OSCCTRL_XOSCCTRL_STARTUP_SHIFT)
# define OSCCTRL_XOSCCTRL_STARTUP_500MS (14 << OSCCTRL_XOSCCTRL_STARTUP_SHIFT)
# define OSCCTRL_XOSCCTRL_STARTUP_1S (15 << OSCCTRL_XOSCCTRL_STARTUP_SHIFT)
#define OSCCTRL_OSC16MCTRL_ENABLE (1 << 1)
#define OSCCTRL_OSC16MCTRL_FSEL_SHIFT (2)
#define OSCCTRL_OSC16MCTRL_FSEL_MASK (3 << OSCCTRL_OSC16MCTRL_FSEL_SHIFT)
# define OSCCTRL_OSC16MCTRL_FSEL_4MHZ (0 << OSCCTRL_OSC16MCTRL_FSEL_SHIFT)
# define OSCCTRL_OSC16MCTRL_FSEL_8MHZ (1 << OSCCTRL_OSC16MCTRL_FSEL_SHIFT)
# define OSCCTRL_OSC16MCTRL_FSEL_12MHZ (2 << OSCCTRL_OSC16MCTRL_FSEL_SHIFT)
# define OSCCTRL_OSC16MCTRL_FSEL_16MHZ (3 << OSCCTRL_OSC16MCTRL_FSEL_SHIFT)
#define OSCCTRL_OSC16MCTRL_RUNSTDBY (1 << 6)
#define OSCCTRL_OSC16MCTRL_ONDEMAND (1 << 7)
#define OSCCTRL_OSC16MCTRL_GAIN_SHIFT (8)
#define OSCCTRL_OSC16MCTRL_GAIN_MASK (7 << OSCCTRL_OSC16MCTRL_GAIN_SHIFT)
# define OSCCTRL_OSC16MCTRL_GAIN(n) ((n) << OSCCTRL_OSC16MCTRL_GAIN_SHIFT)
# define OSCCTRL_OSC16MCTRL_GAIN_2MHZ (0 << OSCCTRL_OSC16MCTRL_GAIN_SHIFT)
# define OSCCTRL_OSC16MCTRL_GAIN_4MHZ (1 << OSCCTRL_OSC16MCTRL_GAIN_SHIFT)
# define OSCCTRL_OSC16MCTRL_GAIN_8MHZ (2 << OSCCTRL_OSC16MCTRL_GAIN_SHIFT)
# define OSCCTRL_OSC16MCTRL_GAIN_16MHZ (3 << OSCCTRL_OSC16MCTRL_GAIN_SHIFT)
# define OSCCTRL_OSC16MCTRL_GAIN_30MHZ (4 << OSCCTRL_OSC16MCTRL_GAIN_SHIFT)
#define OSCCTRL_OSC16MCTRL_AMPGC (1 << 11)
#define OSCCTRL_OSC16MCTRL_STARTUP_SHIFT (12)
#define OSCCTRL_OSC16MCTRL_STARTUP_MASK (15 << OSCCTRL_OSC16MCTRL_STARTUP_SHIFT)
# define OSCCTRL_OSC16MCTRL_STARTUP(n) ((n) << OSCCTRL_OSC16MCTRL_STARTUP_SHIFT)
# define OSCCTRL_OSC16MCTRL_STARTUP_31US (0 << OSCCTRL_OSC16MCTRL_STARTUP_SHIFT)
# define OSCCTRL_OSC16MCTRL_STARTUP_61US (1 << OSCCTRL_OSC16MCTRL_STARTUP_SHIFT)
# define OSCCTRL_OSC16MCTRL_STARTUP_122US (2 << OSCCTRL_OSC16MCTRL_STARTUP_SHIFT)
# define OSCCTRL_OSC16MCTRL_STARTUP_244US (3 << OSCCTRL_OSC16MCTRL_STARTUP_SHIFT)
# define OSCCTRL_OSC16MCTRL_STARTUP_488US (4 << OSCCTRL_OSC16MCTRL_STARTUP_SHIFT)
# define OSCCTRL_OSC16MCTRL_STARTUP_977US (5 << OSCCTRL_OSC16MCTRL_STARTUP_SHIFT)
# define OSCCTRL_OSC16MCTRL_STARTUP_2MS (6 << OSCCTRL_OSC16MCTRL_STARTUP_SHIFT)
# define OSCCTRL_OSC16MCTRL_STARTUP_4MS (7 << OSCCTRL_OSC16MCTRL_STARTUP_SHIFT)
# define OSCCTRL_OSC16MCTRL_STARTUP_8MS (8 << OSCCTRL_OSC16MCTRL_STARTUP_SHIFT)
# define OSCCTRL_OSC16MCTRL_STARTUP_16MS (9 << OSCCTRL_OSC16MCTRL_STARTUP_SHIFT)
# define OSCCTRL_OSC16MCTRL_STARTUP_31MS (10 << OSCCTRL_OSC16MCTRL_STARTUP_SHIFT)
# define OSCCTRL_OSC16MCTRL_STARTUP_63MS (11 << OSCCTRL_OSC16MCTRL_STARTUP_SHIFT)
# define OSCCTRL_OSC16MCTRL_STARTUP_125MS (12 << OSCCTRL_OSC16MCTRL_STARTUP_SHIFT)
# define OSCCTRL_OSC16MCTRL_STARTUP_250MS (13 << OSCCTRL_OSC16MCTRL_STARTUP_SHIFT)
# define OSCCTRL_OSC16MCTRL_STARTUP_500MS (14 << OSCCTRL_OSC16MCTRL_STARTUP_SHIFT)
# define OSCCTRL_OSC16MCTRL_STARTUP_1S (15 << OSCCTRL_OSC16MCTRL_STARTUP_SHIFT)
#define OSCCTRL_DFLLCTRL_ENABLE (1 << 1)
#define OSCCTRL_DFLLCTRL_MODE (1 << 2)
#define OSCCTRL_DFLLCTRL_STABLE (1 << 3)
#define OSCCTRL_DFLLCTRL_LLAW (1 << 4)
#define OSCCTRL_DFLLCTRL_USBCRM (1 << 5)
#define OSCCTRL_DFLLCTRL_RUNSTDBY (1 << 6)
#define OSCCTRL_DFLLCTRL_ONDEMAND (1 << 7)
#define OSCCTRL_DFLLCTRL_CCDIS (1 << 8)
#define OSCCTRL_DFLLCTRL_QLDIS (1 << 9)
#define OSCCTRL_DFLLCTRL_BPLCKC (1 << 10)
#define OSCCTRL_DFLLCTRL_WAITLOCK (1 << 11)
#define OSCCTRL_DFLLVAL_FINE_SHIFT (0)
#define OSCCTRL_DFLLVAL_FINE_MASK (0x3ff << OSCCTRL_DFLLVAL_FINE_SHIFT)
# define OSCCTRL_DFLLVAL_FINE(n) ((n) << OSCCTRL_DFLLVAL_FINE_SHIFT)
#define OSCCTRL_DFLLVAL_COARSE_SHIFT (10)
#define OSCCTRL_DFLLVAL_COARSE_MASK (0x3f << OSCCTRL_DFLLVAL_COARSE_SHIFT)
# define OSCCTRL_DFLLVAL_COARSE(n) ((n) << OSCCTRL_DFLLVAL_COARSE_SHIFT)
#define OSCCTRL_DFLLVAL_DIFF_SHIFT (16)
#define OSCCTRL_DFLLVAL_DIFF_MASK (0xffff << OSCCTRL_DFLLVAL_DIFF_SHIFT)
# define OSCCTRL_DFLLVAL_DIFF(n) ((n) << OSCCTRL_DFLLVAL_DIFF_SHIFT)
#define OSCCTRL_DFLLMUL_MUL_SHIFT (0)
#define OSCCTRL_DFLLMUL_MUL_MASK (0xffff << OSCCTRL_DFLLMUL_MUL_SHIFT)
# define OSCCTRL_DFLLMUL_MUL(n) ((n) << OSCCTRL_DFLLMUL_MUL_SHIFT)
#define OSCCTRL_DFLLMUL_FSTEP_SHIFT (16)
#define OSCCTRL_DFLLMUL_FSTEP_MASK (0x3ff << OSCCTRL_DFLLMUL_FSTEP_SHIFT)
# define OSCCTRL_DFLLMUL_FSTEP(n) ((n) << OSCCTRL_DFLLMUL_FSTEP_SHIFT)
#define OSCCTRL_DFLLMUL_CSTEP_SHIFT (26)
#define OSCCTRL_DFLLMUL_CSTEP_MASK (0x3f << OSCCTRL_DFLLMUL_CSTEP_SHIFT)
# define OSCCTRL_DFLLMUL_CSTEP(n) ((n) << OSCCTRL_DFLLMUL_CSTEP_SHIFT)
#define OSCCTRL_DFLLSYNC_READREQ (1 << 7)
#define OSCCTRL_DPLLCTRLA_ENABLE (1 << 1)
#define OSCCTRL_DPLLCTRLA_RUNSTDBY (1 << 6)
#define OSCCTRL_DPLLCTRLA_ONDEMAND (1 << 7)
#define OSCCTRL_DPLLRATIO_LDR_SHIFT (0)
#define OSCCTRL_DPLLRATIO_LDR_MASK (0xfff << OSCCTRL_DPLLRATIO_LDR_SHIFT)
# define OSCCTRL_DPLLRATIO_LDR(n) ((uint32_t)(n) << OSCCTRL_DPLLRATIO_LDR_SHIFT)
#define OSCCTRL_DPLLRATIO_LDRFRAC_SHIFT (16)
#define OSCCTRL_DPLLRATIO_LDRFRAC_MASK (15 << OSCCTRL_DPLLRATIO_LDRFRAC_SHIFT)
# define OSCCTRL_DPLLRATIO_LDRFRAC(n) ((uint32_t)(n) << OSCCTRL_DPLLRATIO_LDRFRAC_SHIFT)
#define OSCCTRL_DPLLCTRLB_FILTER_SHIFT (0)
#define OSCCTRL_DPLLCTRLB_FILTER_MASK (3 << OSCCTRL_DPLLCTRLB_FILTER_SHIFT)
# define OSCCTRL_DPLLCTRLB_FILTER_DEFAULT (0 << OSCCTRL_DPLLCTRLB_FILTER_SHIFT)
# define OSCCTRL_DPLLCTRLB_FILTER_LBFILT (1 << OSCCTRL_DPLLCTRLB_FILTER_SHIFT)
# define OSCCTRL_DPLLCTRLB_FILTER_HBFILT (2 << OSCCTRL_DPLLCTRLB_FILTER_SHIFT)
# define OSCCTRL_DPLLCTRLB_FILTER_HDFILT (3 << OSCCTRL_DPLLCTRLB_FILTER_SHIFT)
#define OSCCTRL_DPLLCTRLB_LPEN (1 << 2)
#define OSCCTRL_DPLLCTRLB_WUF (1 << 3)
#define OSCCTRL_DPLLCTRLB_REFLCK_SHIFT (4)
#define OSCCTRL_DPLLCTRLB_REFLCK_MASK (3 << OSCCTRL_DPLLCTRLB_REFLCK_SHIFT)
# define OSCCTRL_DPLLCTRLB_REFLCK_XOSCK32K (0 << OSCCTRL_DPLLCTRLB_REFLCK_SHIFT)
# define OSCCTRL_DPLLCTRLB_REFLCK_XOSC (1 << OSCCTRL_DPLLCTRLB_REFLCK_SHIFT)
# define OSCCTRL_DPLLCTRLB_REFLCK_GLCK (1 << OSCCTRL_DPLLCTRLB_REFLCK_SHIFT)
#define OSCCTRL_DPLLCTRLB_LTIME_SHIFT (8)
#define OSCCTRL_DPLLCTRLB_LTIME_MASK (7 << OSCCTRL_DPLLCTRLB_LTIME_SHIFT)
# define OSCCTRL_DPLLCTRLB_LTIME_NONE (0 << OSCCTRL_DPLLCTRLB_LTIME_SHIFT)
# define OSCCTRL_DPLLCTRLB_LTIME_8MS (4 << OSCCTRL_DPLLCTRLB_LTIME_SHIFT)
# define OSCCTRL_DPLLCTRLB_LTIME_9MS (5 << OSCCTRL_DPLLCTRLB_LTIME_SHIFT)
# define OSCCTRL_DPLLCTRLB_LTIME_10MS (6 << OSCCTRL_DPLLCTRLB_LTIME_SHIFT)
# define OSCCTRL_DPLLCTRLB_LTIME_11MS (7 << OSCCTRL_DPLLCTRLB_LTIME_SHIFT)
#define OSCCTRL_DPLLCTRLB_LBYPASS (1 << 12)
#define OSCCTRL_DPLLCTRLB_DIV_SHIFT (16)
#define OSCCTRL_DPLLCTRLB_DIV_MASK (0x7ff << OSCCTRL_DPLLCTRLB_DIV_SHIFT)
# define OSCCTRL_DPLLCTRLB_DIV(n) ((uint32_t)(n) << OSCCTRL_DPLLCTRLB_DIV_SHIFT)
#define OSCCTRL_DPLLPRESC_SHIFT (0)
#define OSCCTRL_DPLLPRESC_MASK (3 << OSCCTRL_DPLLPRESC_SHIFT)
# define OSCCTRL_DPLLPRESC_DIV1 (0 << OSCCTRL_DPLLPRESC_SHIFT)
# define OSCCTRL_DPLLPRESC_DIV2 (1 << OSCCTRL_DPLLPRESC_SHIFT)
# define OSCCTRL_DPLLPRESC_DIV4 (2 << OSCCTRL_DPLLPRESC_SHIFT)
#define OSCCTRL_DPLLSYNCBUSY_ENABLE (1 << 1)
#define OSCCTRL_DPLLSYNCBUSY_DPLLRATIO (1 << 2)
#define OSCCTRL_DPLLSYNCBUSY_DPLLPRESC (1 << 3)
#define OSCCTRL_DPLLSTATUS_LOCK (1 << 0)
#define OSCCTRL_DPLLSTATUS_CLKRDY (1 << 1)
* Public Types
****************************************************************************/
* Public Data
****************************************************************************/
* Public Functions Prototypes
****************************************************************************/
#endif
#endif