?? f06x_oscillator_cmos.c
字號:
//-----------------------------------------------------------------------------
// F06x_Oscillator_CMOS.c
//-----------------------------------------------------------------------------
// Copyright 2006 Silicon Laboratories, Inc.
// http://www.silabs.com
//
// Program Description:
//
// This example demonstrates how to initialize for and switch to an external
// CMOS Oscillator.
// - Pinout:
// P0.0 -> /SYSCLK
//
// P1.6 -> LED
//
// all other port pins unused
//
// XTAL1 -> XTAL1 - External CMOS Oscillator input
//
//
// How To Test:
//
// 1) Define the input CMOS clock frequency using <CMOS_clock>
// 2) Compile and download code to a 'F06x device.
// 3) Connect the CMOS input clock to XTAL1 (J21 on the TB)
// 4) Run the code:
// - the test will blink an LED at a frequency based on the CMOS
// Oscillator
// - the 'F06x will also output the SYSCLK to a port pin (P0.0) for
// observation
//
//
// FID: 06X000010
// Target: C8051F06x
// Tool chain: Keil C51 7.50 / Keil EVAL C51
// Command Line: None
//
// Release 1.0
// -Initial Revision (TP)
// -31 MAY 2006
//
//-----------------------------------------------------------------------------
// Includes
//-----------------------------------------------------------------------------
#include <C8051F060.h> // SFR declarations
//-----------------------------------------------------------------------------
// Global CONSTANTS
//-----------------------------------------------------------------------------
#define CMOS_clock 3062500 // CMOS oscillator frequency
// Timer2 using SYSCLK/12 as its time base
// Timer2 counts 65536 SYSCLKs per Timer2 interrupt
// LED target flash rate = 10 Hz (may be slower, depending on CMOS_clock)
//
// If CMOS_clock is too slow to divide into a number of counts,
// <count> will always remain 0. In this case, the LED Flash rate will be
// slower than 10 Hz.
#define LED_interrupt_count CMOS_clock/12/65536/10
sfr16 RCAP2 = 0xCA; // Timer2 reload value
sfr16 TMR2 = 0xCC; // Timer2 counter
sbit LED = P1^6; // LED='1' means ON
//-----------------------------------------------------------------------------
// Function PROTOTYPES
//-----------------------------------------------------------------------------
void SYSCLK_Init (void);
void ExtCMOSOsc_Init (void);
void Port_Init (void);
void Timer2_Init (void);
void Timer2_ISR (void);
//-----------------------------------------------------------------------------
// MAIN Routine
//-----------------------------------------------------------------------------
//
// Main routine performs all configuration tasks, switches to the external CMOS
// oscillator, and loops forever, blinking the LED.
//
void main (void) {
WDTCN = 0xDE; // disable watchdog timer
WDTCN = 0xAD;
SFRPAGE = CONFIG_PAGE;
SYSCLK_Init (); // Initialize system clock to 24.5MHz
ExtCMOSOsc_Init (); // Initialize for and switch to the
// external CMOS oscillator
Port_Init (); // Initialize crossbar and GPIO
SFRPAGE = TMR2_PAGE;
Timer2_Init (); // Init Timer2 to generate
// interrupts for the LED.
EA = 1; // Enable global interrupts
SFRPAGE = LEGACY_PAGE; // Sit in this SFRPAGE
while (1) { // Spin forever
}
}
//-----------------------------------------------------------------------------
// Initialization Routines
//-----------------------------------------------------------------------------
//-----------------------------------------------------------------------------
// SYSCLK_Init ()
//-----------------------------------------------------------------------------
//
// Return Value : None
// Parameters : None
//
// This routine initializes the system clock to use the internal 24.5 MHz
// oscillator as its clock source. Also enables missing clock detector reset.
//
void SYSCLK_Init (void)
{
OSCICN = 0x83; // Configure internal oscillator for
// its highest frequency (24.5 MHz)
RSTSRC = 0x04; // Enable missing clock detector
}
//-----------------------------------------------------------------------------
// ExtCMOSOsc_Init ()
//-----------------------------------------------------------------------------
//
// Return Value : None
// Parameters : None
//
// This routine initializes for and switches to the External CMOS Oscillator.
//
// Note: In CMOS clock configuration, the clock source should be wired to the
// XTAL1 pin as shown in Option 4 in the Oscillators section of the datasheet.
//
void ExtCMOSOsc_Init (void)
{
OSCXCN = 0x20; // External Oscillator is a CMOS clock
// (no divide by 2 stage)
// XFCN bit settings do not apply to a
// CMOS clock
CLKSEL = 0x01; // Switch to the external CMOS clock
}
//-----------------------------------------------------------------------------
// Port_Init ()
//-----------------------------------------------------------------------------
//
// Return Value : None
// Parameters : None
//
// Configure the Crossbar and GPIO ports.
//
// P0.0 digital push-pull /SYSCLK
// P0.1 unused
// P0.2 unused
// P0.3 unused
// P0.4 unused
// P0.5 unused
// P0.6 unused
// P0.7 unused
//
// P1.0 unused
// P1.1 unused
// P1.2 unused
// P1.3 unused
// P1.4 unused
// P1.5 unused
// P1.6 digital push-pull LED
// P1.7 unused
//
// P2 unused
//
// P3 unused
//
// P4 unused
//
// P5 unused
//
// P6 unused
//
// P7 unused
//
void PORT_Init (void)
{
P0MDOUT |= 0x01; // Enable /SYSCLK as a push-pull output
P1MDOUT |= 0x40; // Enable LED as a push-pull output
XBR1 = 0x80; // Route /SYSCLK to a port pin
XBR2 = 0x40; // Enable crossbar and weak pull-ups
}
//-----------------------------------------------------------------------------
// Timer2_Init ()
//-----------------------------------------------------------------------------
//
// Return Value : None
// Parameters : None
//
// Configure Timer2 to 16-bit auto-reload and generate an interrupt after the
// maximum possible time (TMR2RL = 0x0000).
//
void Timer2_Init (void)
{
TMR2CN = 0x00; // Stop Timer2; Clear TF2;
// auto-reload mode
TMR2CF = 0x00; // use SYSCLK/12 as timebase; count up
RCAP2 = 0x0000; // Init reload value
TMR2 = 0xffff; // Set to reload immediately
ET2 = 1; // Enable Timer2 interrupts
TR2 = 1; // Start Timer2
}
//-----------------------------------------------------------------------------
// Interrupt Service Routines
//-----------------------------------------------------------------------------
//-----------------------------------------------------------------------------
// Timer2_ISR
//-----------------------------------------------------------------------------
//
// This routine changes the state of the LED whenever Timer2 overflows.
//
void Timer2_ISR (void) interrupt 5
{
static unsigned int count = 0;
TF2 = 0; // Clear Timer2 interrupt flag
if (count == LED_interrupt_count)
{
LED = ~LED; // Change state of LED
count = 0;
}
else
{
count++;
}
}
//-----------------------------------------------------------------------------
// End Of File
//-----------------------------------------------------------------------------
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -