亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? f34x_usb_main.c

?? C8051F340的USB開發
?? C
字號:
//-----------------------------------------------------------------------------
// F34x_USB_Main.c
//-----------------------------------------------------------------------------
// Copyright 2005 Silicon Laboratories, Inc.
// http://www.silabs.com
//
// Program Description:
//
// This application note covers the implementation of a simple USB application 
// using the interrupt transfer type. This includes support for device
// enumeration, control and interrupt transactions, and definitions of 
// descriptor data. The purpose of this software is to give a simple working 
// example of an interrupt transfer application; it does not include
// support for multiple configurations or other transfer types.
//
// How To Test:    See Readme.txt
//
//
// FID:            34X000019
// Target:         C8051F34x
// Tool chain:     Keil C51 7.50 / Keil EVAL C51
//                 Silicon Laboratories IDE version 2.6
// Command Line:   See Readme.txt
// Project Name:   F34x_USB_Interrupt
//
//
// Release 1.0
//    -Initial Revision (GP)
//    -22 NOV 2005
//    -Ported from 'F320_USB_Bulk
//

//-----------------------------------------------------------------------------
// Includes
//-----------------------------------------------------------------------------

#include <c8051f340.h>
#include "F34x_USB_Register.h"
#include "F34x_USB_Main.h"
#include "F34x_USB_Descriptor.h"

//-----------------------------------------------------------------------------
// 16-bit SFR Definitions for 'F32x
//-----------------------------------------------------------------------------

sfr16 TMR2RL   = 0xca;                 // Timer2 reload value
sfr16 TMR2     = 0xcc;                 // Timer2 counter

//-----------------------------------------------------------------------------
// Globals
//-----------------------------------------------------------------------------

sbit Led1 = P2^2;                      // LED='1' means ON
sbit Led2 = P2^3;

#define Sw1 0x01                       // These are the port2 bits for Sw1
#define Sw2 0x02                       // and Sw2 on the development board
BYTE Switch1State = 0;                 // Indicate status of switch
BYTE Switch2State = 0;                 // starting at 0 == off

BYTE Toggle1 = 0;                      // Variable to make sure each button
BYTE Toggle2 = 0;                      // press and release toggles switch

BYTE Potentiometer = 0x00;             // Last read potentiometer value
BYTE Temperature = 0x00;               // Last read temperature sensor value

idata BYTE Out_Packet[64];             // Last packet received from host
idata BYTE In_Packet[64];              // Next packet to sent to host

code const BYTE TEMP_ADD = 112;        // This constant is added to Temperature


//-----------------------------------------------------------------------------
// Main Routine
//-----------------------------------------------------------------------------
void main(void)
{
   PCA0MD &= ~0x40;                    // Disable Watchdog timer

   OSCILLATOR_Init();                  // Initialize oscillator
   PORT_Init();                        // Initialize crossbar and GPIO
   USB0_Init();                        // Initialize USB0
   Timer2_Init();                      // Initialize Timer2
   ADC0_Init();                        // Initialize ADC0

   while (1)
   {
    // It is possible that the contents of the following packets can change
    // while being updated.  This doesn't cause a problem in the sample
    // application because the bytes are all independent.  If data is NOT
    // independent, packet update routines should be moved to an interrupt
    // service routine, or interrupts should be disabled during data updates.

      if (Out_Packet[0] == 1) Led1 = 1;   // Update status of LED #1
      else Led1 = 0;
      if (Out_Packet[1] == 1) Led2 = 1;   // Update status of LED #2
      else Led2 = 0;
      P1 = (Out_Packet[2] & 0x0F);        // Set Port 1 pins


      In_Packet[0] = Switch1State;        // Send status of switch 1
      In_Packet[1] = Switch2State;        // and switch 2 to host
      In_Packet[2] = (P0 & 0x0F);         // Port 0 [0-3]
      In_Packet[3] = Potentiometer;       // Potentiometer value
      In_Packet[4] = Temperature;         // Temperature sensor value
   }
}

//-----------------------------------------------------------------------------
// Initialization Subroutines
//-----------------------------------------------------------------------------

//-----------------------------------------------------------------------------
// OSCILLATOR_Init
//-----------------------------------------------------------------------------
//
// Return Value : None
// Parameters   : None
//
// Initialize the system clock and USB clock
//
//-----------------------------------------------------------------------------
void OSCILLATOR_Init(void)
{
#ifdef _USB_LOW_SPEED_

   OSCICN |= 0x03;                     // Configure internal oscillator for
                                       // its maximum frequency and enable
                                       // missing clock detector

   CLKSEL  = SYS_INT_OSC;              // Select System clock
   CLKSEL |= USB_INT_OSC_DIV_2;        // Select USB clock
#else
   OSCICN |= 0x03;                     // Configure internal oscillator for
                                       // its maximum frequency and enable
                                       // missing clock detector

   CLKMUL  = 0x00;                     // Select internal oscillator as
                                       // input to clock multiplier

   CLKMUL |= 0x80;                     // Enable clock multiplier
   Delay();                            // Delay for clock multiplier to begin
   CLKMUL |= 0xC0;                     // Initialize the clock multiplier
   Delay();                            // Delay for clock multiplier to begin

   while(!(CLKMUL & 0x20));            // Wait for multiplier to lock
   CLKSEL  = SYS_INT_OSC;              // Select system clock
   CLKSEL |= USB_4X_CLOCK;             // Select USB clock
#endif  /* _USB_LOW_SPEED_ */
}

//-----------------------------------------------------------------------------
// PORT_Init
//-----------------------------------------------------------------------------
//
// Return Value : None
// Parameters   : None
//
// This function configures the crossbar and GPIO ports.
//
// P2.2   digital   push-pull     LED
// P2.3   digital   push-pull     LED
// P2.5   analog                  Potentiometer
//-----------------------------------------------------------------------------
void PORT_Init(void)
{
   P2MDIN   = 0xDF;                    // P2.5 set as analog input

   P0MDOUT |= 0x0F;                    // P0 pins 0-3 set high impedance
   P1MDOUT |= 0x0F;                    // P1 pins 0-3 set high impedance
   P2MDOUT |= 0x0C;                    // P2 pins 0,1 set high impedance

   P2SKIP   = 0x20;                    // P2.5 skipped by crossbar

   XBR0     = 0x00;
   XBR1     = 0x40;                    // Enable Crossbar
}

//-----------------------------------------------------------------------------
// USB0_Init
//-----------------------------------------------------------------------------
//
// Return Value : None
// Parameters   : None
// 
// - Initialize USB0
// - Enable USB0 interrupts
// - Enable USB0 transceiver
// - Enable USB0 with suspend detection
//-----------------------------------------------------------------------------
void USB0_Init(void)
{
   BYTE Count;

   // Set initial values of In_Packet and Out_Packet to zero
   // Initialize here as opposed to above main() to prevent WDT reset
   for (Count = 0; Count < 64; Count++)
   {
      Out_Packet[Count] = 0;
      In_Packet[Count] = 0;
   }

   POLL_WRITE_BYTE(POWER,  0x08);      // Force Asynchronous USB Reset
   POLL_WRITE_BYTE(IN1IE,  0x07);      // Enable Endpoint 0-2 in interrupts
   POLL_WRITE_BYTE(OUT1IE, 0x07);      // Enable Endpoint 0-2 out interrupts
   POLL_WRITE_BYTE(CMIE,   0x07);      // Enable Reset,Resume,Suspend interrupts
#ifdef _USB_LOW_SPEED_
   USB0XCN = 0xC0;                     // Enable transceiver; select low speed
   POLL_WRITE_BYTE(CLKREC, 0xA0);      // Enable clock recovery; single-step mode
                                       // disabled; low speed mode enabled
#else
   USB0XCN = 0xE0;                     // Enable transceiver; select full speed
   POLL_WRITE_BYTE(CLKREC, 0x80);      // Enable clock recovery, single-step mode
                                       // disabled
#endif // _USB_LOW_SPEED_

   EIE1 |= 0x02;                       // Enable USB0 Interrupts
   EA = 1;                             // Global Interrupt enable
                                       // Enable USB0 by clearing the USB 
                                       // Inhibit bit
   POLL_WRITE_BYTE(POWER,  0x01);      // and enable suspend detection
}

//-----------------------------------------------------------------------------
// Timer2_Init
//-----------------------------------------------------------------------------
//
// Return Value : None
// Parameters   : None
// 
// Timer 2 reload, used to check if switch pressed on overflow and
// used for ADC continuous conversion
//-----------------------------------------------------------------------------

void Timer2_Init(void)
{
   TMR2CN  = 0x00;                     // Stop Timer2; Clear TF2;

   CKCON  &= ~0xF0;                    // Timer2 clocked based on T2XCLK;
   TMR2RL  = 0;                        // Initialize reload value
   TMR2    = 0xffff;                   // Set to reload immediately

   ET2     = 1;                        // Enable Timer2 interrupts
   TR2     = 1;                        // Start Timer2
}

//-----------------------------------------------------------------------------
// ADC0_Init
//-----------------------------------------------------------------------------
//
// Return Value : None
// Parameters   : None
// 
// Configures ADC for single ended continuous conversion or Timer2
//-----------------------------------------------------------------------------

void ADC0_Init(void)
{
   REF0CN  = 0x0E;                     // Enable voltage reference VREF
   AMX0P = 0x1E;                       // Positive input starts as temp sensor
   AMX0N = 0x1F;                       // Single ended mode(neginput = gnd)

   ADC0CF  = 0xF8;                     // SAR Period 0x1F, Right adjusted

   ADC0CN  = 0xC2;                     // Continuous converion on timer 2 
                                       // overflow; low power tracking mode on

   EIE1   |= 0x08;                     // Enable conversion complete interrupt
}

//-----------------------------------------------------------------------------
// Timer2_ISR
//-----------------------------------------------------------------------------
//
// Called when timer 2 overflows, check to see if switch is pressed,
// then watch for release.
//
//-----------------------------------------------------------------------------

void Timer2_ISR(void) interrupt 5
{
   if (!(P2 & Sw1))                    // Check for switch #1 pressed
   {
      if (Toggle1 == 0)                // Toggle is used to debounce switch
      {                                // so that one press and release will
         Switch1State = ~Switch1State; // toggle the state of the switch sent
         Toggle1 = 1;                  // to the host
      }
   }
   else Toggle1 = 0;                   // Reset toggle variable

   if (!(P2 & Sw2))                    // Same as above, but Switch2
   {
      if (Toggle2 == 0)
      {
         Switch2State = ~Switch2State;
         Toggle2 = 1;
      }
   }
   else Toggle2 = 0;

   TF2H = 0;                           // Clear Timer2 interrupt flag
}

//-----------------------------------------------------------------------------
// ADC0_ConvComplete_ISR
//-----------------------------------------------------------------------------
//
// Called after a conversion of the ADC has finished
// Updates the appropriate variable for potentiometer or temperature sensor
// Switches the ADC multiplexor value to switch between the potentiometer 
// and temp sensor
//
//-----------------------------------------------------------------------------

void ADC0_ConvComplete_ISR(void) interrupt 10
{
   if (AMX0P == 0x1E)                  // This switches the AMUX between
   {                                   // the temperature sensor and the
      Temperature   = ADC0L;           // potentiometer pin after conversion
      Temperature  += TEMP_ADD;        // Add offset to Temperature
      AMX0P       = 0x04;              // switch to potentiometer
      ADC0CF      = 0xFC;              // Place ADC0 in left-adjusted mode
   }
   else
   {
      Potentiometer = ADC0H;
      AMX0P       = 0x1E;              // switch to temperature sensor
      ADC0CF      = 0xF8;              // place ADC0 in right-adjusted mode
   }

   AD0INT = 0;
}

//-----------------------------------------------------------------------------
// Delay
//-----------------------------------------------------------------------------
//
// Used for a small pause, approximately 80 us in Full Speed,
// and 1 ms when clock is configured for Low Speed
//
//-----------------------------------------------------------------------------

void Delay(void)
{
   int x;
   for(x = 0;x < 500;x)
      x++;
}

//-----------------------------------------------------------------------------
// End Of File
//-----------------------------------------------------------------------------

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品中文字幕欧美| 欧美日韩精品专区| 国产欧美一区视频| 国产成人自拍网| 国产在线观看免费一区| 激情久久五月天| av资源网一区| jlzzjlzz亚洲女人18| 不卡的电影网站| 欧美久久久久免费| 91精品国产高清一区二区三区蜜臀 | 国产精品另类一区| 国产欧美一区二区精品性 | 欧美日韩二区三区| 午夜免费久久看| 欧美精品一区二区高清在线观看| 国产成人亚洲综合a∨猫咪| 国产精品久久久久精k8| 欧美日韩aaaaa| 国产综合久久久久久鬼色| 国产精品美女www爽爽爽| 欧美天天综合网| 国产曰批免费观看久久久| 中文字幕在线观看不卡视频| 欧美午夜影院一区| 国产成人亚洲精品狼色在线| 亚洲狠狠爱一区二区三区| 日韩欧美一级二级三级久久久| 福利一区在线观看| 日韩国产欧美在线观看| 国产日韩v精品一区二区| 欧美日韩日日摸| 国产夫妻精品视频| 天涯成人国产亚洲精品一区av| 国产亚洲女人久久久久毛片| 欧美无人高清视频在线观看| 成人一区二区三区视频| 毛片av一区二区| 亚洲精品久久嫩草网站秘色| 久久九九久久九九| 欧美日本在线看| 97精品超碰一区二区三区| 精品制服美女丁香| 一区二区三区四区乱视频| 欧美激情一区二区三区全黄| 91精品国产色综合久久不卡电影 | 精品影院一区二区久久久| 欧美一区在线视频| 亚洲午夜精品久久久久久久久| 欧美www视频| 激情小说亚洲一区| 精品卡一卡二卡三卡四在线| 九一久久久久久| 精品国产免费一区二区三区四区| 日韩 欧美一区二区三区| 欧美日韩午夜影院| 午夜欧美电影在线观看| 国产99精品国产| 午夜精品久久久久久久久久| 日本道色综合久久| 国产精品不卡视频| 一本色道久久综合亚洲91| 亚洲成人免费在线观看| 久久精品视频在线免费观看| 亚洲成人免费av| 91美女福利视频| 国产女同性恋一区二区| 欧美电视剧免费观看| 国产成人在线视频网站| 国产精品天美传媒| 97久久超碰精品国产| 欧美日韩一区在线观看| 日韩视频在线一区二区| 久久久久久久久伊人| 久久国产日韩欧美精品| 欧美精品第一页| 成人国产一区二区三区精品| 国产精品美女www爽爽爽| 成人h版在线观看| 精品一区二区三区久久| 欧美军同video69gay| 欧美日本不卡视频| 久久电影国产免费久久电影| 国产+成+人+亚洲欧洲自线| 美腿丝袜亚洲色图| 亚洲一区二区四区蜜桃| 亚洲综合视频网| 亚洲国产wwwccc36天堂| 亚洲国产精品久久人人爱蜜臀| 亚洲欧美激情小说另类| 日韩一区二区三区视频| 91丝袜呻吟高潮美腿白嫩在线观看| 国产中文一区二区三区| 国产精品蜜臀在线观看| 精品国内片67194| 久久精品无码一区二区三区| 国产女人18水真多18精品一级做| 51午夜精品国产| 欧美绝品在线观看成人午夜影视| 在线精品视频免费观看| 色素色在线综合| av福利精品导航| youjizz国产精品| 国产精一品亚洲二区在线视频| 激情综合网av| 久草热8精品视频在线观看| 蜜臀精品一区二区三区在线观看| 中文字幕不卡的av| 亚洲欧美怡红院| 久久99精品久久久久久久久久久久| 国产亚洲一区二区三区| 国产视频一区在线观看| 国产午夜亚洲精品理论片色戒| 国产三级欧美三级| 国产亚洲人成网站| 免费亚洲电影在线| 91理论电影在线观看| 欧美区在线观看| 另类的小说在线视频另类成人小视频在线| 热久久久久久久| 成人免费不卡视频| 5858s免费视频成人| 中文字幕在线观看一区| 日韩av在线播放中文字幕| 粉嫩aⅴ一区二区三区四区五区| 欧美性生活久久| 国产视频一区不卡| 天堂一区二区在线| av在线这里只有精品| 欧美成人r级一区二区三区| 亚洲欧美偷拍另类a∨色屁股| 久久精品久久精品| 欧亚一区二区三区| 中文字幕不卡一区| 精品一区二区三区蜜桃| 欧美日韩二区三区| 亚洲乱码中文字幕| 成人免费毛片app| 精品免费一区二区三区| 天堂va蜜桃一区二区三区漫画版| 成人短视频下载| 久久综合国产精品| 日韩经典一区二区| 欧美性一级生活| 亚洲欧美日韩国产综合在线 | 美女视频第一区二区三区免费观看网站| 国产激情一区二区三区四区| 欧美一区二视频| 午夜欧美电影在线观看| 在线免费精品视频| 亚洲手机成人高清视频| 国产成人自拍高清视频在线免费播放| 欧美成人午夜电影| 蜜桃av噜噜一区| 欧美一卡二卡三卡| 奇米影视在线99精品| 8v天堂国产在线一区二区| 亚洲一区欧美一区| 色av一区二区| 亚洲啪啪综合av一区二区三区| 波多野结衣中文字幕一区二区三区| 久久美女艺术照精彩视频福利播放| 日日骚欧美日韩| 91麻豆精品国产无毒不卡在线观看 | 国产精品一区二区三区网站| 精品伦理精品一区| 久久99精品国产麻豆不卡| 欧美mv日韩mv国产| 国产一区二区三区精品视频| 久久这里只有精品6| 国产高清亚洲一区| 国产欧美1区2区3区| 不卡av在线免费观看| 亚洲欧美偷拍另类a∨色屁股| 91福利精品视频| 亚洲一区二区五区| 91精品国产综合久久精品麻豆| 日韩高清不卡一区二区三区| 日韩精品一区二区三区视频在线观看| 美女一区二区三区在线观看| 日韩欧美资源站| 福利一区二区在线| 亚洲丝袜另类动漫二区| 欧美日韩色一区| 激情图片小说一区| 国产精品国产三级国产普通话99 | av激情成人网| 亚洲综合网站在线观看| 91麻豆精品国产91久久久久| 久久er99精品| 中文字幕一区免费在线观看| 欧美色图免费看| 精品在线观看视频| 亚洲丝袜另类动漫二区| 欧美日韩精品一二三区| 久久99精品国产.久久久久久| 国产精品视频一二三| 欧美日韩精品综合在线| 国产成人免费在线| 亚洲国产精品一区二区久久|