📄 f34x_msd_usb_main.src
字号:
; .\F34x_MSD_USB_Main.SRC generated from: F34x_MSD_USB_Main.c
; COMPILER INVOKED BY:
; C:\Keil\C51\BIN\C51.EXE F34x_MSD_USB_Main.c LARGE OPTIMIZE(9,SPEED) BROWSE NOAREGS DEBUG OBJECTEXTEND SRC(.\F34x_MSD_USB_Main.SRC)
$NOMOD51
NAME F34X_MSD_USB_MAIN
CCF2 BIT 0D8H.2
TB80 BIT 098H.3
SPI0CKR DATA 0A2H
CCF3 BIT 0D8H.3
P0 DATA 080H
SPIEN BIT 0F8H.0
CCF4 BIT 0D8H.4
P1 DATA 090H
P2 DATA 0A0H
ADC0CF DATA 0BCH
P3 DATA 0B0H
AC BIT 0D0H.6
P4 DATA 0C7H
EIE1 DATA 0E6H
CF_WE BIT 090H.6
START_STOP_SPI BIT 0B0H.0
EA BIT 0A8H.7
MCE0 BIT 098H.5
EIE2 DATA 0E7H
USB0XCN DATA 0D7H
PSCTL DATA 08FH
CF BIT 0D8H.7
IT01CF DATA 0E4H
ADC0CN DATA 0E8H
P0MDOUT DATA 0A4H
P1MDOUT DATA 0A5H
TMR2RLH DATA 0CBH
IE DATA 0A8H
P2MDOUT DATA 0A6H
T2CE BIT 0C8H.4
P3MDOUT DATA 0A7H
TMR3RLH DATA 093H
EIP1 DATA 0F6H
P4MDOUT DATA 0AEH
TXBMT BIT 0F8H.1
EIP2 DATA 0F7H
PCA0CPH0 DATA 0FCH
TMR2RLL DATA 0CAH
PCA0CPH1 DATA 0EAH
TMR3RLL DATA 092H
PCA0CPH2 DATA 0ECH
CR BIT 0D8H.6
T2SPLIT BIT 0C8H.3
TF2H BIT 0C8H.7
PCA0CPH3 DATA 0EEH
REN0 BIT 098H.4
PCA0CPH4 DATA 0FEH
PCA0CPL0 DATA 0FBH
EMI0CF DATA 085H
PCA0CPL1 DATA 0E9H
PCA0CPM0 DATA 0DAH
PCA0MD DATA 0D9H
PCA0CN DATA 0D8H
PCA0CPL2 DATA 0EBH
PCA0CPM1 DATA 0DBH
TF2L BIT 0C8H.6
PCA0CPL3 DATA 0EDH
PCA0CPM2 DATA 0DCH
IP DATA 0B8H
ARBLOST BIT 0C0H.2
PCA0CPL4 DATA 0FDH
PCA0CPM3 DATA 0DDH
PCA0CPM4 DATA 0DEH
CY BIT 0D0H.7
SI BIT 0C0H.0
C_PWR BIT 090H.7
XBR0 DATA 0E1H
SMB0CF DATA 0C1H
XBR1 DATA 0E2H
PFE0CN DATA 0AFH
EMI0CN DATA 0AAH
XBR2 DATA 0E3H
REF0CN DATA 0D1H
REG0CN DATA 0C9H
CF_CD1 BIT 090H.3
AD0INT BIT 0E8H.5
CF_CE1 BIT 090H.2
SP DATA 081H
EMI0TC DATA 084H
OV BIT 0D0H.2
SMB0CN DATA 0C0H
TMR2 DATA 0CCH
MODF BIT 0F8H.5
SBCON1 DATA 0ACH
START_STOP_WRITE_TO BIT 0B0H.2
S0MODE BIT 098H.7
VDM0CN DATA 0FFH
P0MDIN DATA 0F1H
CPT0MD DATA 09DH
CPT0CN DATA 09BH
P1MDIN DATA 0F2H
CPT1MD DATA 09CH
CPT1CN DATA 09AH
P2MDIN DATA 0F3H
TF2LEN BIT 0C8H.5
P3MDIN DATA 0F4H
SCLK BIT 080H.0
P4MDIN DATA 0F5H
SBRLH1 DATA 0B5H
SPI0CN DATA 0F8H
PCON DATA 087H
SBRLL1 DATA 0B4H
SPIF BIT 0F8H.7
TMOD DATA 089H
TCON DATA 088H
WCOL BIT 0F8H.6
NSSMD0 BIT 0F8H.2
NSSMD1 BIT 0F8H.3
TMR2CN DATA 0C8H
MOSI BIT 080H.2
MISO BIT 080H.1
P0SKIP DATA 0D4H
TMR3CN DATA 091H
START_STOP_READ_TO BIT 0B0H.1
T2XCLK BIT 0C8H.0
P1SKIP DATA 0D5H
P2SKIP DATA 0D6H
P3SKIP DATA 0DFH
IE0 BIT 088H.1
CPT0MX DATA 09FH
IE1 BIT 088H.3
OSCICL DATA 0B3H
CPT1MX DATA 09EH
CLKSEL DATA 0A9H
B DATA 0F0H
ADC0H DATA 0BEH
OSCICN DATA 0B2H
OSCLCN DATA 086H
TMR2RL DATA 0CAH
ADC0L DATA 0BDH
ACC DATA 0E0H
ES0 BIT 0A8H.4
AD0EN BIT 0E8H.7
ET0 BIT 0A8H.1
ET1 BIT 0A8H.3
TF0 BIT 088H.5
CLKMUL DATA 0B9H
ET2 BIT 0A8H.5
RI0 BIT 098H.0
TF1 BIT 088H.7
TH0 DATA 08CH
EX0 BIT 0A8H.0
TI0 BIT 098H.1
IT0 BIT 088H.0
PCA0H DATA 0FAH
TH1 DATA 08DH
MASTER BIT 0C0H.7
EX1 BIT 0A8H.2
IT1 BIT 088H.2
P BIT 0D0H.0
ACK BIT 0C0H.1
OSCXCN DATA 0B1H
TL0 DATA 08AH
PCA0L DATA 0F9H
TL1 DATA 08BH
TXMODE BIT 0C0H.6
PS0 BIT 0B8H.4
PT0 BIT 0B8H.1
RS0 BIT 0D0H.3
PT1 BIT 0B8H.3
RS1 BIT 0D0H.4
PT2 BIT 0B8H.5
TR0 BIT 088H.4
AD0TM BIT 0E8H.6
TR1 BIT 088H.6
TR2 BIT 0C8H.2
PX0 BIT 0B8H.0
CF_RDY BIT 090H.4
PX1 BIT 0B8H.2
DPH DATA 083H
ADC0GTH DATA 0C4H
DPL DATA 082H
ADC0GTL DATA 0C3H
SBUF0 DATA 099H
ESPI0 BIT 0A8H.6
SBUF1 DATA 0D3H
ADC0LTH DATA 0C6H
CF_RST BIT 090H.0
RSTSRC DATA 0EFH
SCON0 DATA 098H
SMOD1 DATA 0E5H
SCON1 DATA 0D2H
AMX0N DATA 0BAH
ADC0LTL DATA 0C5H
AMX0P DATA 0BBH
STA BIT 0C0H.5
SCS BIT 080H.3
PSPI0 BIT 0B8H.6
SMB0DAT DATA 0C2H
TMR2H DATA 0CDH
SPI0CFG DATA 0A1H
TMR3H DATA 095H
CKCON DATA 08EH
T2CSS BIT 0C8H.1
RXOVRN BIT 0F8H.4
TMR2L DATA 0CCH
ACKRQ BIT 0C0H.3
USB0ADR DATA 096H
TMR3L DATA 094H
F0 BIT 0D0H.5
FLSCL DATA 0B6H
USB0DAT DATA 097H
AD0CM0 BIT 0E8H.0
F1 BIT 0D0H.1
STO BIT 0C0H.4
AD0CM1 BIT 0E8H.1
SPI0DAT DATA 0A3H
AD0CM2 BIT 0E8H.2
AD0WINT BIT 0E8H.3
AD0BUSY BIT 0E8H.4
PSW DATA 0D0H
CCF0 BIT 0D8H.0
RB80 BIT 098H.2
FLKEY DATA 0B7H
CF_OE BIT 090H.1
CCF1 BIT 0D8H.1
?PR?main?F34X_MSD_USB_MAIN SEGMENT CODE
?PR?Sys_Clk_Init?F34X_MSD_USB_MAIN SEGMENT CODE
?PR?Port_Init?F34X_MSD_USB_MAIN SEGMENT CODE
?PR?USB0_Init?F34X_MSD_USB_MAIN SEGMENT CODE
?PR?Timer_Init?F34X_MSD_USB_MAIN SEGMENT CODE
?PR?Timer2_ISR?F34X_MSD_USB_MAIN SEGMENT CODE
?PR?Delay?F34X_MSD_USB_MAIN SEGMENT CODE
?C_INITSEG SEGMENT CODE
?XD?F34X_MSD_USB_MAIN SEGMENT XDATA
?DT?Port_Init?F34X_MSD_USB_MAIN SEGMENT DATA OVERLAYABLE
?DT?Delay?F34X_MSD_USB_MAIN SEGMENT DATA OVERLAYABLE
?PR?F34X_MSD_USB_MAIN SEGMENT CODE
EXTRN CODE (Sect_Init)
EXTRN CODE (Cmd_Init)
EXTRN CODE (Cmd_Step)
EXTRN CODE (Log_Step)
EXTRN CODE (Msd_Step)
EXTRN CODE (USB_Bulk_Init)
EXTRN CODE (UART0_Init)
EXTRN CODE (?C_STARTUP)
EXTRN CODE (?C?LSTXDATA)
PUBLIC tickcount
PUBLIC Delay
PUBLIC Timer2_ISR
PUBLIC Timer_Init
PUBLIC USB0_Init
PUBLIC Port_Init
PUBLIC Sys_Clk_Init
PUBLIC main
RSEG ?XD?F34X_MSD_USB_MAIN
tickcount: DS 4
RSEG ?DT?Port_Init?F34X_MSD_USB_MAIN
i?240: DS 2
RSEG ?DT?Delay?F34X_MSD_USB_MAIN
x?641: DS 2
RSEG ?C_INITSEG
DB 044H
DW tickcount
DB 000H,000H,000H,000H ; long
; //-----------------------------------------------------------------------------
; // F34x_MSD_USB_Main.c
; //-----------------------------------------------------------------------------
; // Copyright 2006 Silicon Laboratories, Inc.
; // http://www.silabs.com
; //
; // Program Description:
; //
; // File contains the main loop of application. It also contains small delay
; // function and some simple initializations (CPU, Ports)
; //
; // How To Test: See Readme.txt
; //
; //
; // FID: 34X000062
; // Target: C8051F34x
; // Tool chain: Keil
; // Command Line: See Readme.txt
; // Project Name: F34x_USB_MSD
; //
; // REVISIONS: 11/22/02 - DM: Added support for switches and sample USB
; // interrupt application.
; //
; // Release 1.1
; // -All changes by PKC
; // -09 JUN 2006
; // -Replaced SFR definitions file "c8051f320.h" with "c8051f340.h"
; //
; // Release 1.0
; // -Initial Release
; //
;
; //-----------------------------------------------------------------------------
; // Includes
; //-----------------------------------------------------------------------------
;
; #include "F34x_MSD_Definitions.h"
; #include "F34x_MSD_Physical_Settings.h"
; #include "F34x_MSD_CF_Basic_Functions.h"
; #include "c8051f340.h"
; #include "F34x_MSD_USB_Register.h"
; #include "F34x_MSD_USB_Main.h"
; #include "F34x_MSD_USB_Descriptor.h"
; #include "F34x_MSD_VBUS_Functions.h"
;
; #include "F34x_MSD_Sect_Serv.h"
; #include "F34x_MSD_Msd.h"
; #include "F34x_MSD_UART.h"
; #include "F34x_MSD_File_System.h"
; #include <stdio.h>
;
;
; #include "F34x_MSD_Cmd.h" //wozb - 27-09-2005 - it's not need it was used to communicate via uart
; #include "F34x_MSD_Log.h" //wozb - 27-09-2005 - it's not need it was used to communicate via uart
;
; #include "F34x_MSD_Temp_Sensor.h"
;
; //-----------------------------------------------------------------------------
; // 16-bit SFR Definitions for 'F34x
; //-----------------------------------------------------------------------------
;
; sfr16 TMR2RL = 0xca; // Timer2 reload value
; sfr16 TMR2 = 0xcc; // Timer2 counter
;
; sbit C_PWR = P1^7;
; //-----------------------------------------------------------------------------
; // Main Routine
; //-----------------------------------------------------------------------------
; volatile DWORD xdata tickcount=0;
;
; extern void Wait_ms(unsigned int count);
;
; //----------------------------------------------------------------------------
; // main
; //----------------------------------------------------------------------------
; //
; // Main loop
; //
; // Parameters :
; // Return Value :
; //----------------------------------------------------------------------------
;
RSEG ?PR?F34X_MSD_USB_MAIN
Com0025:
L?0038:
USING 0
CLR C
SUBB A,#088H
MOV A,i?240
XRL A,#080H
SUBB A,#093H
RET
; END OF Com0025
; void main(void) {
RSEG ?PR?main?F34X_MSD_USB_MAIN
main:
USING 0
; SOURCE LINE # 83
; PCA0MD &= ~0x40; // Disable Watchdog timer
; SOURCE LINE # 84
ANL PCA0MD,#0BFH
;
; Sys_Clk_Init(); // Initialize oscillator
; SOURCE LINE # 86
LCALL Sys_Clk_Init
;
; Port_Init(); // Initialize crossbar and GPIO
; SOURCE LINE # 88
LCALL Port_Init
;
;
;
; UART0_Init();
; SOURCE LINE # 92
LCALL UART0_Init
;
; #ifdef __F340_VER__
; Init_Temp_Sensor(); // initialize temerature sensor
; #endif
; Sect_Init();
; SOURCE LINE # 97
LCALL Sect_Init
;
; Timer_Init(); // Initialize timer2
; SOURCE LINE # 99
LCALL Timer_Init
;
; USB0_Init(); // Initialize USB0
; SOURCE LINE # 101
LCALL USB0_Init
;
;
;
; #ifdef __F340_VER__
; FileSys_Init();
; #endif
;
; Cmd_Init();
; SOURCE LINE # 109
LCALL Cmd_Init
;
;
;
; USB_Bulk_Init();
; SOURCE LINE # 113
LCALL USB_Bulk_Init
?C0001:
;
; while (1) {
; SOURCE LINE # 115
; Cmd_Step();
; SOURCE LINE # 116
LCALL Cmd_Step
; Msd_Step();
; SOURCE LINE # 117
LCALL Msd_Step
; Log_Step();
; SOURCE LINE # 118
LCALL Log_Step
; #ifdef __F340_VER__
; Temp_Log_Step();
; Switch_On_Off_UART();
; #endif
; }
; SOURCE LINE # 123
SJMP ?C0001
; END OF main
; }
;
; //-----------------------------------------------------------------------------
; // Initialization Subroutines
; //-----------------------------------------------------------------------------
;
; //----------------------------------------------------------------------------
; // Sys_Clk_Init
; //----------------------------------------------------------------------------
; //
; // This routine initilizes the system clock and USB clock
; //
; // Parameters :
; // Return Value :
; //----------------------------------------------------------------------------
;
; void Sys_Clk_Init(void)
RSEG ?PR?Sys_Clk_Init?F34X_MSD_USB_MAIN
Sys_Clk_Init:
USING 0
; SOURCE LINE # 140
; {
; SOURCE LINE # 141
; #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
; SOURCE LINE # 151
ORL OSCICN,#03H
; // its maximum frequency and enable
; // missing clock detector
;
; CLKMUL = 0x00; // Select internal oscillator as
; SOURCE LINE # 155
CLR A
MOV CLKMUL,A
; // input to clock multiplier
;
; CLKMUL |= 0x80; // Enable clock multiplier
; SOURCE LINE # 158
ORL CLKMUL,#080H
; Delay(); // Delay for clock multiplier to begin
; SOURCE LINE # 159
LCALL Delay
; CLKMUL |= 0xC0; // Initialize the clock multiplier
; SOURCE LINE # 160
ORL CLKMUL,#0C0H
; Delay();
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -