📄 mac_cc2430.s51
字号:
//////////////////////////////////////////////////////////////////////////////
// /
// IAR 8051 C/C++ Compiler V7.20H/W32 16/Jan/2007 15:30:35 /
// Copyright 2004-2006 IAR Systems. All rights reserved. /
// /
// Core = plain /
// Code model = banked /
// Data model = large /
// Calling convention = xdata reentrant /
// Constant location = data /
// Dptr setup = 1,16 /
// Source file = E:\公司产品资料\Zigbee\cc2431\cc2431定位\LOC_Eng /
// ine\lib\mac\CC2430\mac_cc2430.c /
// Command line = -I "C:\Program Files\IAR Systems\Embedded /
// Workbench 4.05 Evaluation version\8051\INC\" -I /
// "C:\Program Files\IAR Systems\Embedded /
// Workbench 4.05 Evaluation /
// version\8051\SRC\LIB\" -I "C:\Program Files\IAR /
// Systems\Embedded Workbench 4.05 Evaluation /
// version\8051\INC\CLIB\" -I /
// E:\公司产品资料\Zigbee\cc2431\cc2431定位\LOC_Eng /
// ine\Test\mac\mac_loc\..\..\..\include\ -I /
// E:\公司产品资料\Zigbee\cc2431\cc2431定位\LOC_Eng /
// ine\Test\mac\mac_loc\..\..\..\include\mac\cc2430 /
// \ -I E:\公司产品资料\Zigbee\cc2431\cc2431定位\LO /
// C_Engine\Test\mac\mac_loc\..\..\..\include\hal\c /
// c2430\ -I E:\公司产品资料\Zigbee\cc2431\cc2431定 /
// 位\LOC_Engine\Test\mac\mac_loc\..\..\..\apps\ /
// -D CC2430EB -D USE_LED -lCN /
// E:\公司产品资料\Zigbee\cc2431\cc2431定位\LOC_Eng /
// ine\Test\mac\mac_loc\CC2430EB\List\ -lA /
// E:\公司产品资料\Zigbee\cc2431\cc2431定位\LOC_Eng /
// ine\Test\mac\mac_loc\CC2430EB\List\ -o /
// E:\公司产品资料\Zigbee\cc2431\cc2431定位\LOC_Eng /
// ine\Test\mac\mac_loc\CC2430EB\Obj\ -e -s9 /
// --debug --core=plain --dptr=16,1 /
// --data_model=large --code_model=banked /
// --calling_convention=xdata_reentrant /
// --place_constants=data --nr_virtual_regs 8 /
// E:\公司产品资料\Zigbee\cc2431\cc2431定位\LOC_Eng /
// ine\lib\mac\CC2430\mac_cc2430.c /
// List file = E:\公司产品资料\Zigbee\cc2431\cc2431定位\LOC_Eng /
// ine\Test\mac\mac_loc\CC2430EB\List\mac_cc2430.s5 /
// 1 /
// /
// /
//////////////////////////////////////////////////////////////////////////////
NAME mac_cc2430
RTMODEL "__calling_convention", "xdata_reentrant"
RTMODEL "__code_model", "banked"
RTMODEL "__core", "plain"
RTMODEL "__data_model", "large"
RTMODEL "__dptr_size", "16"
RTMODEL "__extended_stack", "disabled"
RTMODEL "__location_for_constants", "data"
RTMODEL "__number_of_dptrs", "1"
RTMODEL "__rt_version", "1"
RSEG DOVERLAY:DATA:NOROOT(0)
RSEG IOVERLAY:IDATA:NOROOT(0)
RSEG ISTACK:IDATA:NOROOT(0)
RSEG PSTACK:XDATA:NOROOT(0)
RSEG XSTACK:XDATA:NOROOT(0)
EXTERN ?FUNC_ENTER_XDATA
EXTERN ?FUNC_LEAVE_XDATA
EXTERN ?S_SHL
EXTERN ?UC_SWITCH_DENSE
EXTERN ?V0
EXTERN __INIT_XDATA_Z
PUBWEAK DMA1CFGH
PUBWEAK DMA1CFGL
PUBWEAK DMAARM
PUBWEAK DMAIRQ
PUBWEAK DMAREQ
PUBLIC DisableRfInterrupts
FUNCTION DisableRfInterrupts,021203H
PUBLIC EnableRfInterrupts
FUNCTION EnableRfInterrupts,021203H
PUBLIC FetchDmaChannelConfiguration
FUNCTION FetchDmaChannelConfiguration,0203H
LOCFRAME XSTACK, 9, STACK
PUBWEAK IEN2
PUBLIC InitializeDma
FUNCTION InitializeDma,0203H
LOCFRAME ISTACK, 2, STACK
PUBLIC InitializeRfInterrupts
FUNCTION InitializeRfInterrupts,021203H
PUBWEAK S1CON
PUBLIC StartDma
FUNCTION StartDma,080203H
LOCFRAME ISTACK, 2, STACK
PUBWEAK _A_IEN0
PUBWEAK _A_IEN1
PUBWEAK _A_IRCON
PUBWEAK _A_TCON
PUBLIC pDma1234Configs
CFI Names cfiNames0
CFI StackFrame CFA_SP SP DATA
CFI StackFrame CFA_PSP16 PSP16 XDATA
CFI StackFrame CFA_XSP16 XSP16 XDATA
CFI StaticOverlayFrame CFA_IOVERLAY IOVERLAY
CFI StaticOverlayFrame CFA_DOVERLAY DOVERLAY
CFI Resource `PSW.CY`:1, `B.BR0`:1, `B.BR1`:1, `B.BR2`:1, `B.BR3`:1
CFI Resource `B.BR4`:1, `B.BR5`:1, `B.BR6`:1, `B.BR7`:1, `VB.BR8`:1
CFI Resource `VB.BR9`:1, `VB.BR10`:1, `VB.BR11`:1, `VB.BR12`:1
CFI Resource `VB.BR13`:1, `VB.BR14`:1, `VB.BR15`:1, VB:8, B:8, A:8
CFI Resource PSW:8, DPL0:8, DPH0:8, R0:8, R1:8, R2:8, R3:8, R4:8, R5:8
CFI Resource R6:8, R7:8, V0:8, V1:8, V2:8, V3:8, V4:8, V5:8, V6:8, V7:8
CFI Resource SP:8, PSPH:8, PSPL:8, PSP16:16, XSPH:8, XSPL:8, XSP16:16
CFI VirtualResource ?RET:24
CFI Resource ?BRET_EXT:8
CFI VirtualResource ?RET_HIGH:8, ?RET_LOW:8
CFI ResourceParts PSP16 PSPH, PSPL
CFI ResourceParts XSP16 XSPH, XSPL
CFI ResourceParts ?RET ?BRET_EXT, ?RET_HIGH, ?RET_LOW
CFI EndNames cfiNames0
CFI Common cfiCommon0 Using cfiNames0
CFI CodeAlign 1
CFI DataAlign -1
CFI ReturnAddress ?RET CODE
CFI CFA_DOVERLAY Used
CFI CFA_IOVERLAY Used
CFI CFA_SP SP+-2
CFI CFA_PSP16 PSP16+0
CFI CFA_XSP16 XSP16+0
CFI `PSW.CY` SameValue
CFI `B.BR0` SameValue
CFI `B.BR1` SameValue
CFI `B.BR2` SameValue
CFI `B.BR3` SameValue
CFI `B.BR4` SameValue
CFI `B.BR5` SameValue
CFI `B.BR6` SameValue
CFI `B.BR7` SameValue
CFI `VB.BR8` SameValue
CFI `VB.BR9` SameValue
CFI `VB.BR10` SameValue
CFI `VB.BR11` SameValue
CFI `VB.BR12` SameValue
CFI `VB.BR13` SameValue
CFI `VB.BR14` SameValue
CFI `VB.BR15` SameValue
CFI VB SameValue
CFI B Undefined
CFI A Undefined
CFI PSW SameValue
CFI DPL0 SameValue
CFI DPH0 SameValue
CFI R0 Undefined
CFI R1 Undefined
CFI R2 Undefined
CFI R3 Undefined
CFI R4 Undefined
CFI R5 Undefined
CFI R6 SameValue
CFI R7 SameValue
CFI V0 SameValue
CFI V1 SameValue
CFI V2 SameValue
CFI V3 SameValue
CFI V4 SameValue
CFI V5 SameValue
CFI V6 SameValue
CFI V7 SameValue
CFI PSPH Undefined
CFI PSPL Undefined
CFI XSPH Undefined
CFI XSPL Undefined
CFI ?RET Concat
CFI ?BRET_EXT SameValue
CFI ?RET_HIGH Frame(CFA_SP, 2)
CFI ?RET_LOW Frame(CFA_SP, 1)
CFI EndCommon cfiCommon0
EXTERN SET_RFIM
FUNCTION SET_RFIM,0202H
EXTERN SET_RFIF
FUNCTION SET_RFIF,0202H
// E:\公司产品资料\Zigbee\cc2431\cc2431定位\LOC_Engine\lib\mac\CC2430\mac_cc2430.c
// 1 /*******************************************************************************************************
// 2 * *
// 3 * ********** *
// 4 * ************ *
// 5 * *** *** *
// 6 * *** +++ *** *
// 7 * *** + + *** *
// 8 * *** + CHIPCON CC2430 INTEGRATED 802.15.4 MAC AND PHY *
// 9 * *** + + *** MAC-CC2430.C *
// 10 * *** +++ *** *
// 11 * *** *** *
// 12 * ************ *
// 13 * ********** *
// 14 * *
// 15 *******************************************************************************************************
// 16 * CONFIDENTIAL *
// 17 * The use of this file is restricted by the signed MAC software license agreement. *
// 18 * *
// 19 * Copyright Chipcon AS, 2005 *
// 20 *******************************************************************************************************/
// 21 #include "mac_headers.h"
ASEGN SFR_AN:DATA:NOROOT,09aH
// unsigned char volatile __sfr IEN2
IEN2:
DS 1
ASEGN SFR_AN:DATA:NOROOT,09bH
// unsigned char volatile __sfr S1CON
S1CON:
DS 1
ASEGN SFR_AN:DATA:NOROOT,0d1H
// unsigned char volatile __sfr DMAIRQ
DMAIRQ:
DS 1
ASEGN SFR_AN:DATA:NOROOT,0d2H
// unsigned char volatile __sfr DMA1CFGL
DMA1CFGL:
DS 1
ASEGN SFR_AN:DATA:NOROOT,0d3H
// unsigned char volatile __sfr DMA1CFGH
DMA1CFGH:
DS 1
ASEGN SFR_AN:DATA:NOROOT,0d6H
// unsigned char volatile __sfr DMAARM
DMAARM:
DS 1
ASEGN SFR_AN:DATA:NOROOT,0d7H
// unsigned char volatile __sfr DMAREQ
DMAREQ:
DS 1
// 22
RSEG XDATA_Z:XDATA:NOROOT(0)
REQUIRE __INIT_XDATA_Z
// 23 DMA_CHANNEL_CONFIGURATION pDma1234Configs[4];
pDma1234Configs:
DS 32
// 24
// 25 static ROOT void DisableMcuRfErrInterrupt (void);
// 26 static ROOT void DisableMcuRfifInterrupt (void);
// 27 static ROOT void EnableMcuDmaInterrupt (void);
// 28 static ROOT void EnableMcuRfifInterrupt (void);
// 29 static ROOT void EnableMcuRfErrInterrupt (void);
// 30 static ROOT void InitializeDmaAes (void);
// 31 static ROOT void InitializeDmaRf (void);
// 32
// 33 //-------------------------------------------------------------------------------------------------------
// 34 //
// 35 // DMA routines
// 36 //
// 37 //-------------------------------------------------------------------------------------------------------
// 38 //-------------------------------------------------------------------------------------------------------
// 39 //
// 40 //-------------------------------------------------------------------------------------------------------
RSEG NEAR_CODE:CODE:NOROOT(0)
// 41 ROOT void InitializeDma (void)
InitializeDma:
CFI Block cfiBlock0 Using cfiCommon0
CFI Function InitializeDma
// 42 {
PUSH DPL
CFI DPL0 Frame(CFA_SP, 3)
CFI CFA_SP SP+-3
PUSH DPH
CFI DPH0 Frame(CFA_SP, 4)
CFI CFA_SP SP+-4
; Saved register size: 2
; Auto size: 0
// 43 DMA_CHANNEL_CONFIGURATION *dmaChannelConfiguration;
// 44 WORD address;
// 45
// 46 FetchDmaChannelConfiguration(DMA_TO_AES_CHANNEL_NO, &dmaChannelConfiguration);
// 47
// 48 address = (WORD)dmaChannelConfiguration;
// 49 DMA1CFGH = (BYTE)(address >> 8);
MOV A,#((pDma1234Configs >> 8) & 0xff)
MOV 0xd3,A
// 50 DMA1CFGL = (BYTE)(address);
MOV 0xd2,#(pDma1234Configs & 0xff)
// 51 DMAIRQ = 0;
MOV 0xd1,#0x0
// 52 InitializeDmaRf ();
MOV A,#-0x21
MOV DPTR,#(pDma1234Configs + 24)
MOVX @DPTR,A
MOV A,#-0x27
MOV DPTR,#(pDma1234Configs + 25)
MOVX @DPTR,A
CLR A
MOV DPTR,#(pDma1234Configs + 28)
MOVX @DPTR,A
MOV A,#0x13
MOV DPTR,#(pDma1234Configs + 30)
MOVX @DPTR,A
MOV A,#0x1c
MOV DPTR,#(pDma1234Configs + 31)
MOVX @DPTR,A
// 53 InitializeDmaAes ();
MOV A,#-0x21
MOV DPTR,#(pDma1234Configs + 2)
MOVX @DPTR,A
MOV A,#-0x4f
MOV DPTR,#(pDma1234Configs + 3)
MOVX @DPTR,A
CLR A
MOV DPTR,#(pDma1234Configs + 4)
MOVX @DPTR,A
MOV A,#0x1d
MOV DPTR,#(pDma1234Configs + 6)
MOVX @DPTR,A
MOV A,#0x42
MOV DPTR,#(pDma1234Configs + 7)
MOVX @DPTR,A
MOV A,#-0x21
MOV DPTR,#(pDma1234Configs + 8)
MOVX @DPTR,A
MOV A,#-0x4e
MOV DPTR,#(pDma1234Configs + 9)
MOVX @DPTR,A
CLR A
MOV DPTR,#(pDma1234Configs + 12)
MOVX @DPTR,A
MOV A,#0x1e
MOV DPTR,#(pDma1234Configs + 14)
MOVX @DPTR,A
MOV A,#0x12
MOV DPTR,#(pDma1234Configs + 15)
MOVX @DPTR,A
// 54 EnableMcuDmaInterrupt ();
CLR 0xc0.0
SETB 0xb8.0
CFI EndBlock cfiBlock0
// 55
// 56 }
REQUIRE ?Subroutine0
; // Fall through to label ?Subroutine0
RSEG NEAR_CODE:CODE:NOROOT(0)
?Subroutine0:
CFI Block cfiBlock1 Using cfiCommon0
CFI NoFunction
CFI CFA_SP SP+-4
CFI DPL0 Frame(CFA_SP, 3)
CFI DPH0 Frame(CFA_SP, 4)
POP DPH
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -