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

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

?? chipcon_cstartup.s51

?? CC2430下基于ZigBee的綜合實力源碼
?? S51
字號:
/******************************************************************************
*                                                                             *
*        **********                                                           *
*       ************                                                          *
*      ***        ***                                                         *
*     ***    ++    ***                                                        *
*     ***   +  +   ***                      CHIPCON                           *
*     ***   +                                                                 *
*     ***   +  +   ***                                                        *
*     ***    ++    ***                                                        *
*      ***        ***                                                         *
*       ************                                                          *
*        **********                                                           *
*                                                                             *
*******************************************************************************

Filename:     chipcon_cstartup.s51
Target:       cc2430
Author:       KJA
Revised:      16/12-2005
Revision:     1.0

Description:
This module contains the code executed before the C/EC++ "main" function is
called. The code is designed to run on Chipcon CC2430/ CC2431.

Add $TOOLKIT_DIR$\SRC\LIB\ to
Options -> Assembler -> Additional include directives.

Copyright 2004-2005 IAR Systems. All rights reserved.
Updated by Chipcon to not clear ?CBANK at init.

******************************************************************************/


#include "iar_common.h"

	PROGRAM	CSTARTUP
	PUBLIC  __program_start

	EXTERN  ?B0
	EXTERNS_FOR_ALL_DPTR_SYMBOLS()
	REQUIRE ?B0
   REQUIRE __call_main

#if (__NUMBER_OF_DPTRS__ > 1)
	REQUIRE ?RESET_DPS
#endif

#if (__CORE__ == __CORE_EXTENDED1__)
   REQUIRE __call_init_extended1
#endif

   ; Uncomment this when rom-monitor requires 3 NOPS between statements.
   ; REQUIRE ?ROM_MONITOR_NOPS

   RSEG	REGISTERS:NOROOT:DATA
   PUBLIC  ?REGISTERS

?REGISTERS:

//------------------------------------------------------------------------
// The C stack segment. Should be mapped into internal data RAM
//
//   ISTACK:    Should be mapped into internal data RAM
//   PSTACK:    Should be mapped into external data RAM page
//   XSTACK:    Should be mapped into external data RAM
//   EXT_STACK: Should be mapped into external data RAM
//
//------------------------------------------------------------------------
// The C stack is used for LCALL's and temporary storage for
// code generator help-routines (math etc). The stack will be
// located after all other internal RAM variables if the stan-
// dard linking procedure is followed. Note that C interrupt
// routines can double stack size demands.
//
//------------------------------------------------------------------------

   RSEG	ISTACK:NOROOT:IDATA
   PUBLIC  ?ISTACK_START
?ISTACK_START:

   RSEG	PSTACK:NOROOT:XDATA
   PUBLIC  ?PSTACK_START
?PSTACK_START:

   RSEG	XSTACK:NOROOT:XDATA
   PUBLIC  ?XSTACK_START
?XSTACK_START:

   RSEG	EXT_STACK:NOROOT:XDATA
   PUBLIC  ?EXT_STACK_START
?EXT_STACK_START:


//------------------------------------------------------------------------
//
// Define reset vector.
//
//------------------------------------------------------------------------

   COMMON   INTVEC:CODE:ROOT(0)

// The reset vector must be located at address zero, the reset
// vector is located first in the INTVEC segment. This segment
// must thus be located at address zero. Be carefull if using
// assembler sequences located with the ASEG directive, which may
// prevent the INTVEC segment from being located at address zero.

   LIMIT SFB(INTVEC),0,0,"The INTVEC segment must begin at address zero"

?reset_vector:
   DB	0x02    ; LJMP
#if defined(START_INIT_IN_FAR)
   DB	BYTE3(__program_start)
#endif
   DB	high(__program_start)
   DB	low(__program_start)


//------------------------------------------------------------------------
//					
// Initialize the chip to suit IAR ICC8051 Compiler
//
//------------------------------------------------------------------------

   RSEG    CSTART:CODE:ROOT
   EXTERN  ?REGISTER_BANK
   REQUIRE ?ISTACK_START
   REQUIRE ?REGISTERS
   REQUIRE ?reset_vector

__program_start:
   MOV     PSW,#(?REGISTER_BANK << 3)

//------------------------------------------------------------------------
//
// Reset of bank registers and stack pointers
// ==========================================
//
// ?RESET_SP:  Resets the IDATA stack pointer
// ?RESET_ESP: Resets the extended stack pointer
// ?RESET_PSP: Resets the PDATA stack pointer
// ?RESET_XSP: Resets the XDATA stack pointer
//
// ?RESET_CODE_BANK:      Resets the current code bank register
// ?RESET_PDATA_BANK:     Resets the high byte of PDATA page register
//
// ?RESET_DPS: Resets the DPTR selector (point at DPTR0)
//
//------------------------------------------------------------------------

//------------------------------------------------------------------------
//
// Reset idata or extended stack pointer
//   extended stack pointer if  the extended stack is used
//   otherwise, the ordinary stack pointer
//
//------------------------------------------------------------------------

#if (defined(__EXTENDED_STACK__) )

//
// Reset extended stack pointer
//

   PUBLIC  ?RESET_ESP
   REQUIRE ?EXT_STACK_START
   EXTERN	?ESP

?RESET_ESP:
   MOV     SP,#low(sfb(EXT_STACK))
   MOV     ?ESP,#high(sfb(EXT_STACK))
#else

//
// Reset idata stack pointer
//

   PUBLIC  ?RESET_SP
   REQUIRE ?ISTACK_START

?RESET_SP:
   MOV     SP,#SFB(ISTACK)
#endif


//------------------------------------------------------------------------
//
// Reset pdata stack pointer
//
//------------------------------------------------------------------------

   RSEG	CSTART:CODE:NOROOT
   PUBLIC  ?RESET_PSP
   EXTERN  ?PSP
   REQUIRE ?PSTACK_START
   REQUIRE ?RESET_PDATA_BANK
   EXTERN  ?PSTACK

?RESET_PSP:
   MOV     ?PSP,#low(sfe(PSTACK))


//------------------------------------------------------------------------
//
// Reset xdata stack pointer
//
//------------------------------------------------------------------------

   RSEG	CSTART:CODE:NOROOT
   PUBLIC  ?RESET_XSP
   EXTERN  ?XSP
   REQUIRE ?XSTACK_START
   EXTERN  ?XSTACK

?RESET_XSP:
   MOV     ?XSP,#low(sfe(XSTACK))
   MOV     ?XSP+1,#high(sfe(XSTACK))


//------------------------------------------------------------------------
//
// Reset code bank
//
//------------------------------------------------------------------------

#if ( (__CODE_MODEL__ == __CM_BANKED__) || ( __CODE_MODEL__ == __CM_NEAR__ ) )
   RSEG	CSTART:CODE:NOROOT
   PUBLIC  ?RESET_CODE_BANK
   EXTERN  ?CBANK

?RESET_CODE_BANK:
   NOP
//	MOV	?CBANK,#0x00
#endif


//------------------------------------------------------------------------
//
// Reset pdata page
//
//------------------------------------------------------------------------

   RSEG	CSTART:CODE:NOROOT
   PUBLIC  ?RESET_PDATA_BANK
   EXTERN  ?PBANK
   EXTERN	?PBANK_NUMBER

?RESET_PDATA_BANK:
   MOV     ?PBANK,#?PBANK_NUMBER
#if (defined ( __EXTENDED_DPTR__))
   EXTERN  ?PBANK_EXT

?RESET_PDATA_BANK_EXT:
   MOV     ?PBANK_EXT,#0x00
#endif


//------------------------------------------------------------------------
//
// Reset data pointer select register
//
//------------------------------------------------------------------------

#if (__NUMBER_OF_DPTRS__ > 1)

   RSEG	CSTART:CODE:NOROOT
   PUBLIC  ?RESET_DPS
   EXTERN  ?DPS

?RESET_DPS:
   MOV	?DPS,#0x00

#endif



//------------------------------------------------------------------------
//
// Initialize the extended1 core
//
//------------------------------------------------------------------------

#if (__CORE__ == __CORE_EXTENDED1__)

   REQUIRE __call_init_extended1

   RSEG	CSTART:CODE:NOROOT
   PUBLIC  __call_init_extended1
   EXTERN	__init_extended1


__call_init_extended1:
   DB	0x12    ; LCALL
#if defined(START_INIT_IN_FAR)
   DB	BYTE3(__init_extended1)
#endif
   DB	high(__init_extended1)
   DB	low(__init_extended1)
#endif



//------------------------------------------------------------------------
//
// Jump to the code that performs the rest of the system initialization
// before calling main().
//
//------------------------------------------------------------------------


   RSEG    CSTART:CODE:NOROOT
   EXTERN  ?cmain

__call_main:
   LJMP	?cmain

   ENDMOD

;----------------------------------------------------------------;
; Virtual registers						 ;
; =================						 ;
; Below is some segment needed for the IAR ICC C/EC++ compiler   ;
;								 ;
; BREG  : A segment for 8 bit registers for use by the compiler. ;
;         ?B0 is the first register.                             ;
; VREG  : Segement that holds up to 32 virtual registers for     ;
;         use by the compiler. ?V0 is the first register.        ;
; PSP   : Segment containing the PDATA stack pointer (?PSP)      ;
; XSP   : Segment containing the XDATA stack pointer (?XSP)      ;
; 								 ;
;----------------------------------------------------------------;
; NOTE: The XLINK varialbe _NR_OF_VIRTUAL_REGISTERS must be 	 ;
;       defined to set the size for the VREG segment.   	 ;
;----------------------------------------------------------------;

   MODULE  VIRTUAL_REGISTERS
   PUBLIC  ?B0
   PUBLIC  ?V0
   PUBLIC  ?PSP
   PUBLIC  ?XSP
   RSEG    BREG:BIT:NOROOT

?B0:
   DS      8

   RSEG    VREG:DATA:NOROOT
   EXTERN	_NR_OF_VIRTUAL_REGISTERS
?V0:
   DS      0

   RSEG    PSP:DATA:NOROOT
   EXTERN  ?RESET_PSP
   REQUIRE	?RESET_PSP
?PSP:
   DS      1

   RSEG    XSP:DATA:NOROOT
   EXTERN  ?RESET_XSP
   REQUIRE	?RESET_XSP
?XSP:
   DS      2

   ENDMOD ; VIRTUAL_REGISTERS


;----------------------------------------------------------------;
; Register banks						 ;
; =================						 ;
; Below is some segment needed for the IAR ICC C/EC++ compiler   ;
;								 ;
; The register banks will only be included if the #pragma        ;
; register_bank is used for the corresponding register bank      ;
; 								 ;
;----------------------------------------------------------------;

   MODULE	REGISTER_BANK0
   PUBLIC	__REG_BANK_0
   ASEGN	__REG_BANK0:DATA,0x00

__REG_BANK_0:
   DS	8
   ENDMOD


   MODULE	REGISTER_BANK1
   PUBLIC	__REG_BANK_1
   ASEGN	__REG_BANK1:DATA,0x08
__REG_BANK_1:
   DS	8
   ENDMOD


   MODULE	REGISTER_BANK2
   PUBLIC	__REG_BANK_2
   ASEGN	__REG_BANK2:DATA,0x10
__REG_BANK_2:
   DS	8
   ENDMOD


   MODULE	REGISTER_BANK3
   PUBLIC	__REG_BANK_3
   ASEGN	__REG_BANK3:DATA,0x18
__REG_BANK_3:
   DS	8
   ENDMOD	; REGISTER_BANK3

   END

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲同性gay激情无套| 精品一区二区三区免费视频| 亚洲另类在线一区| 久久精品国产亚洲a| 91日韩在线专区| 欧美一激情一区二区三区| 亚洲色欲色欲www| 国产精品自拍在线| 欧美日韩在线播放三区四区| 欧美激情一二三区| 久久99精品久久久久| 欧美视频在线观看一区| 国产精品高潮呻吟久久| 国产精品一卡二卡| 欧美一级精品在线| 亚洲一二三四在线| caoporn国产精品| 国产网站一区二区| 国产做a爰片久久毛片 | 五月综合激情网| 99国产精品久| 中文字幕一区二区三| 久久激情五月婷婷| 欧美一级黄色大片| 日本欧美大码aⅴ在线播放| 欧洲亚洲国产日韩| 亚洲制服欧美中文字幕中文字幕| 成人黄色在线网站| 国产精品久久久久一区二区三区| 国产99久久久精品| 国产精品系列在线| 福利一区福利二区| 国产精品沙发午睡系列990531| 国产一区二区视频在线| 国产日韩在线不卡| 国产91色综合久久免费分享| 国产女主播视频一区二区| 成人午夜电影久久影院| 国产精品久久网站| 91免费精品国自产拍在线不卡| 亚洲人成网站色在线观看| 91久久精品一区二区三| 亚洲影院久久精品| 91精品在线观看入口| 久久激五月天综合精品| 国产午夜精品一区二区三区四区 | 粉嫩aⅴ一区二区三区四区五区| 亚洲精品在线观看网站| 国产呦精品一区二区三区网站| 久久久久久久久99精品| 国产成人av电影| 亚洲欧洲日本在线| 欧洲av一区二区嗯嗯嗯啊| 视频一区在线播放| 亚洲精品一区二区三区精华液 | 国产精品久久久久久久久晋中 | 欧美日韩国产综合久久| 日本美女一区二区| 国产婷婷一区二区| 日本韩国一区二区三区| 午夜精品福利一区二区蜜股av| 欧美一区二区三区免费视频| 精品一区二区三区影院在线午夜| 国产欧美精品国产国产专区| 欧美最新大片在线看| 另类成人小视频在线| 国产日韩av一区二区| 色欧美88888久久久久久影院| 亚洲国产一二三| 久久精品一区二区三区不卡 | 日韩精品久久理论片| 欧美不卡一区二区三区四区| 粉嫩久久99精品久久久久久夜| 夜夜嗨av一区二区三区中文字幕 | 成人av影院在线| 五月婷婷综合网| 国产精品视频看| 色久综合一二码| 国产精品一区二区久激情瑜伽| 亚洲男人天堂一区| 日韩亚洲欧美在线观看| 色哟哟国产精品免费观看| 另类小说色综合网站| 亚洲精选一二三| 精品对白一区国产伦| 欧美亚洲动漫制服丝袜| 国产69精品久久777的优势| 午夜精品久久久久影视| 自拍av一区二区三区| 久久久久久久久久久久久夜| 欧美日韩国产经典色站一区二区三区 | 国产成人啪午夜精品网站男同| 亚洲国产一区二区三区| 中文字幕的久久| 久久综合五月天婷婷伊人| 欧美日韩一级黄| 日本精品一级二级| 成人av在线电影| 国产精品77777| 国模少妇一区二区三区| 日韩 欧美一区二区三区| 亚洲美女视频在线观看| 亚洲欧洲成人精品av97| 国产婷婷色一区二区三区四区| 日韩欧美亚洲国产精品字幕久久久 | 亚洲国产成人av好男人在线观看| 2020日本不卡一区二区视频| 在线播放国产精品二区一二区四区| 97国产精品videossex| 成人av在线一区二区| 成人听书哪个软件好| 国产精品正在播放| 国产aⅴ综合色| 国产一区福利在线| 麻豆国产一区二区| 日本亚洲视频在线| 日本成人在线一区| 久久se这里有精品| 紧缚奴在线一区二区三区| 极品少妇xxxx偷拍精品少妇| 热久久免费视频| 久久99精品网久久| 狠狠色丁香久久婷婷综| 国产精品系列在线观看| youjizz久久| 色八戒一区二区三区| 91久久精品一区二区| 欧美吻胸吃奶大尺度电影| 欧美日韩高清不卡| 欧美一区二区福利视频| 欧美一区欧美二区| 久久久午夜精品理论片中文字幕| 日韩欧美一二区| 国产欧美精品在线观看| 1024成人网色www| 亚洲国产另类精品专区| 青草国产精品久久久久久| 美国十次综合导航| 丁香另类激情小说| 色激情天天射综合网| 日韩精品一区二区三区在线 | 91香蕉视频mp4| 欧美精品乱人伦久久久久久| 久久综合成人精品亚洲另类欧美 | 精品成人一区二区三区| 一级女性全黄久久生活片免费| 蜜臀av性久久久久蜜臀av麻豆| 亚洲靠逼com| 久久狠狠亚洲综合| 99精品欧美一区二区三区小说 | 99热精品国产| 欧美一区二区三区男人的天堂| 国产亚洲综合在线| 亚洲成人免费电影| 国产精品1区二区.| 国产91丝袜在线播放| 一区二区三区在线免费| 日韩三级高清在线| 精品国产sm最大网站免费看| 欧美人狂配大交3d怪物一区| 欧美日本韩国一区| 777久久久精品| 亚洲精品视频一区二区| 午夜精品福利一区二区三区蜜桃| 秋霞午夜av一区二区三区| 色婷婷综合久色| 91福利视频网站| 7777精品伊人久久久大香线蕉 | 99国产精品国产精品久久| 99视频国产精品| 欧美在线视频日韩| 国产网站一区二区| 亚洲蜜桃精久久久久久久| 午夜久久久久久电影| 91视频91自| 7777精品伊人久久久大香线蕉经典版下载 | 日韩精品久久理论片| 久久国产精品免费| 成人av资源在线观看| 久久综合资源网| 亚洲天堂免费在线观看视频| 首页欧美精品中文字幕| 蜜臀a∨国产成人精品| 99久久久久久| 日韩欧美国产小视频| 亚洲欧美激情视频在线观看一区二区三区| 欧美久久一区二区| 欧美不卡激情三级在线观看| 国产精品亲子伦对白| 日韩综合在线视频| 狠狠色综合播放一区二区| 色综合久久久网| 亚洲人午夜精品天堂一二香蕉| 日韩精品欧美精品| 亚洲色图色小说| 色婷婷久久久久swag精品| 91精品福利视频| 欧美性欧美巨大黑白大战| 中文字幕永久在线不卡| 亚洲日本一区二区三区|