📄 mac_csp_tx.lst
字号:
##############################################################################
# #
# IAR 8051 C/C++ Compiler V7.20H/W32 06/Nov/2008 11:13:24 #
# 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:\解决\路由\Components\mac\low_level\srf03\singl #
# e_chip\mac_csp_tx.c #
# Command line = -f E:\解决\路由\Projects\zstack\Samples\SampleApp #
# \CC2430DB\..\..\..\Tools\CC2430DB\f8wCoord.cfg #
# (-DCPU32MHZ -DFORCE_MAC_NEAR -DROOT=__near_func #
# -DMAC_CFG_APP_PENDING_QUEUE=TRUE #
# -DZDO_COORDINATOR -DRTR_NWK -DBLINK_LEDS #
# "-DCONST=const __code" -DGENERIC=__generic) -f #
# E:\解决\路由\Projects\zstack\Samples\SampleApp\CC #
# 2430DB\..\..\..\Tools\CC2430DB\f8wConfig.cfg #
# (-DSECURE=0 -DDEFAULT_CHANLIST=0x00000800 #
# -DZDAPP_CONFIG_PAN_ID=0xFFFF #
# -DNWK_START_DELAY=100 -DEXTENDED_JOINING_RANDOM_M #
# ASK=0x007F -DBEACON_REQUEST_DELAY=100 #
# -DBEACON_REQ_DELAY_MASK=0x00FF #
# -DROUTE_EXPIRY_TIME=30 -DAPSC_ACK_WAIT_DURATION_P #
# OLLED=3000 -DNWK_INDIRECT_MSG_TIMEOUT=7 #
# -DMAX_RREQ_ENTRIES=10 -DAPSC_MAX_FRAME_RETRIES=3 #
# -DNWK_MAX_DATA_RETRIES=2 #
# -DMAX_POLL_FAILURE_RETRIES=2 -DMAX_BCAST=9 #
# -DAPS_MAX_GROUPS=16 -DMAX_RTG_ENTRIES=20 #
# -DNWK_MAX_BINDING_ENTRIES=10 #
# -DMAX_BINDING_CLUSTER_IDS=5 #
# "-DDEFAULT_KEY={0x01, 0x03, 0x05, 0x07, 0x09, #
# 0x0B, 0x0D, 0x0F, 0x00, 0x02, 0x04, 0x06, 0x08, #
# 0x0A, 0x0C, 0x0D}" -DRFD_RCVC_ALWAYS_ON=FALSE #
# -DPOLL_RATE=1000 -DQUEUED_POLL_RATE=100 #
# -DRESPONSE_POLL_RATE=100 -DREJOIN_POLL_RATE=440 #
# -DTOP_BOOT_PAGES=0) -I "D:\Program Files\IAR #
# Systems\Embedded Workbench 4.05 Evaluation #
# version\8051\inc\" -I "D:\Program Files\IAR #
# Systems\Embedded Workbench 4.05 Evaluation #
# version\8051\inc\clib\" -I #
# E:\解决\路由\Projects\zstack\Samples\SampleApp\CC #
# 2430DB\ -I E:\解决\路由\Projects\zstack\Samples\S #
# ampleApp\CC2430DB\..\Source\ -I #
# E:\解决\路由\Projects\zstack\Samples\SampleApp\CC #
# 2430DB\..\..\..\ZMain\TI2430DB\ -I #
# E:\解决\路由\Projects\zstack\Samples\SampleApp\CC #
# 2430DB\..\..\..\..\..\Components\mt\ -I #
# E:\解决\路由\Projects\zstack\Samples\SampleApp\CC #
# 2430DB\..\..\..\..\..\Components\hal\include\ -I #
# E:\解决\路由\Projects\zstack\Samples\SampleApp\CC #
# 2430DB\..\..\..\..\..\Components\hal\target\CC243 #
# 0DB\ -I E:\解决\路由\Projects\zstack\Samples\Samp #
# leApp\CC2430DB\..\..\..\..\..\Components\osal\mcu #
# \ccsoc\ -I E:\解决\路由\Projects\zstack\Samples\S #
# ampleApp\CC2430DB\..\..\..\..\..\Components\osal\ #
# include\ -I E:\解决\路由\Projects\zstack\Samples\ #
# SampleApp\CC2430DB\..\..\..\..\..\Components\stac #
# k\af\ -I E:\解决\路由\Projects\zstack\Samples\Sam #
# pleApp\CC2430DB\..\..\..\..\..\Components\stack\n #
# wk\ -I E:\解决\路由\Projects\zstack\Samples\Sampl #
# eApp\CC2430DB\..\..\..\..\..\Components\stack\sec #
# \ -I E:\解决\路由\Projects\zstack\Samples\SampleA #
# pp\CC2430DB\..\..\..\..\..\Components\stack\sys\ #
# -I E:\解决\路由\Projects\zstack\Samples\SampleApp #
# \CC2430DB\..\..\..\..\..\Components\stack\zdo\ #
# -I E:\解决\路由\Projects\zstack\Samples\SampleApp #
# \CC2430DB\..\..\..\..\..\Components\zmac\f8w\ -I #
# E:\解决\路由\Projects\zstack\Samples\SampleApp\CC #
# 2430DB\..\..\..\..\..\Components\zmac\ -I #
# E:\解决\路由\Projects\zstack\Samples\SampleApp\CC #
# 2430DB\..\..\..\..\..\Components\services\saddr\ #
# -I E:\解决\路由\Projects\zstack\Samples\SampleApp #
# \CC2430DB\..\..\..\..\..\Components\services\sdat #
# a\ -I E:\解决\路由\Projects\zstack\Samples\Sample #
# App\CC2430DB\..\..\..\..\..\Components\mac\includ #
# e\ -I E:\解决\路由\Projects\zstack\Samples\Sample #
# App\CC2430DB\..\..\..\..\..\Components\mac\high_l #
# evel\ -I E:\解决\路由\Projects\zstack\Samples\Sam #
# pleApp\CC2430DB\..\..\..\..\..\Components\mac\low #
# _level\srf03\ -I E:\解决\路由\Projects\zstack\Sam #
# ples\SampleApp\CC2430DB\..\..\..\..\..\Components #
# \mac\low_level\srf03\single_chip\ -D CC2430DB #
# -lC E:\解决\路由\Projects\zstack\Samples\SampleAp #
# p\CC2430DB\CoordinatorDB\List\ -lA #
# E:\解决\路由\Projects\zstack\Samples\SampleApp\CC #
# 2430DB\CoordinatorDB\List\ --diag_suppress #
# Pe001,Pa010 --diag_remark pe550 -o #
# E:\解决\路由\Projects\zstack\Samples\SampleApp\CC #
# 2430DB\CoordinatorDB\Obj\ -e #
# --require_prototypes -z9 --no_code_motion #
# --debug --core=plain --dptr=16,1 #
# --data_model=large --code_model=banked #
# --calling_convention=xdata_reentrant #
# --place_constants=data --nr_virtual_regs 8 #
# E:\解决\路由\Components\mac\low_level\srf03\singl #
# e_chip\mac_csp_tx.c #
# List file = E:\解决\路由\Projects\zstack\Samples\SampleApp\CC #
# 2430DB\CoordinatorDB\List\mac_csp_tx.lst #
# Object file = E:\解决\路由\Projects\zstack\Samples\SampleApp\CC #
# 2430DB\CoordinatorDB\Obj\mac_csp_tx.r51 #
# #
# #
##############################################################################
E:\解决\路由\Components\mac\low_level\srf03\single_chip\mac_csp_tx.c
1 /**************************************************************************************************
2 Filename:
3 Revised: $Date: 2007-03-28 18:21:19 -0700 (Wed, 28 Mar 2007) $
4 Revision: $Revision: 13888 $
5
6 Description:
7
8 Describe the purpose and contents of the file.
9
10 Copyright (c) 2006 by Texas Instruments, Inc.
11 All Rights Reserved. Permission to use, reproduce, copy, prepare
12 derivative works, modify, distribute, perform, display or sell this
13 software and/or its documentation for any purpose is prohibited
14 without the express written consent of Texas Instruments, Inc.
15 **************************************************************************************************/
16
17
18
19 /* ------------------------------------------------------------------------------------------------
20 * Includes
21 * ------------------------------------------------------------------------------------------------
22 */
23
24 /* hal */
25 #include "hal_types.h"
26 #include "hal_mcu.h"
\ In segment SFR_AN, at 0x91
\ unsigned char volatile __sfr RFIM
\ RFIM:
\ 000000 DS 1
\ In segment SFR_AN, at 0x94
\ unsigned char volatile __sfr T2CMP
\ T2CMP:
\ 000000 DS 1
\ In segment SFR_AN, at 0xa1
\ unsigned char volatile __sfr T2OF0
\ T2OF0:
\ 000000 DS 1
\ In segment SFR_AN, at 0xa6
\ unsigned char volatile __sfr T2TLD
\ T2TLD:
\ 000000 DS 1
\ In segment SFR_AN, at 0xa7
\ unsigned char volatile __sfr T2THD
\ T2THD:
\ 000000 DS 1
\ In segment SFR_AN, at 0xe1
\ unsigned char volatile __sfr RFST
\ RFST:
\ 000000 DS 1
27
28 /* high-level */
29 #include "mac_spec.h"
30 #include "mac_pib.h"
31
32 /* exported low-level */
33 #include "mac_low_level.h"
34
35 /* low-level specific */
36 #include "mac_csp_tx.h"
37 #include "mac_tx.h"
38 #include "mac_rx.h"
39 #include "mac_rx_onoff.h"
40
41 /* target specific */
42 #include "mac_radio_defs.h"
43
44 /* debug */
45 #include "mac_assert.h"
46
47
48 /* ------------------------------------------------------------------------------------------------
49 * CSP Defines / Macros
50 * ------------------------------------------------------------------------------------------------
51 */
52 /* immediate strobe commands */
53 #define ISSTART 0xFE
54 #define ISSTOP 0xFF
55
56 /* strobe processor instructions */
57 #define SKIP(s,c) (0x00 | (((s) & 0x07) << 4) | ((c) & 0x0F)) /* skip 's' instructions if 'c' is true */
58 #define WHILE(c) SKIP(0,c) /* pend while 'c' is true (derived instruction) */
59 #define WAITW(w) (0x80 | ((w) & 0x1F)) /* wait for 'w' number of MAC timer overflows */
60 #define WEVENT (0xB8) /* wait for MAC timer compare */
61 #define WAITX (0xBB) /* wait for CPSX number of MAC timer overflows */
62 #define LABEL (0xBA) /* set next instruction as start of loop */
63 #define RPT(c) (0xA0 | ((c) & 0x0F)) /* if condition is true jump to last label */
64 #define INT (0xB9) /* assert IRQ_CSP_INT interrupt */
65 #define INCY (0xBD) /* increment CSPY */
66 #define INCMAXY(m) (0xB0 | ((m) & 0x07)) /* increment CSPY but not above maximum value of 'm' */
67 #define DECY (0xBE) /* decrement CSPY */
68 #define DECZ (0xBF) /* decrement CSPZ */
69 #define RANDXY (0xBC) /* load the lower CSPY bits of CSPX with random value */
70
71 /* strobe processor command instructions */
72 #define SSTOP (0xDF) /* stop program execution */
73 #define SNOP (0xC0) /* no operation */
74 #define STXCALN (0xC1) /* enable and calibrate frequency synthesizer for TX */
75 #define SRXON (0xC2) /* turn on receiver */
76 #define STXON (0xC3) /* transmit after calibration */
77 #define STXONCCA (0xC4) /* transmit after calibration if CCA indicates clear channel */
78 #define SRFOFF (0xC5) /* turn off RX/TX */
79 #define SFLUSHRX (0xC6) /* flush receive FIFO */
80 #define SFLUSHTX (0xC7) /* flush transmit FIFO */
81 #define SACK (0xC8) /* send ACK frame */
82 #define SACKPEND (0xC9) /* send ACK frame with pending bit set */
83
84 /* conditions for use with instructions SKIP and RPT */
85 #define C_CCA_IS_VALID 0x00
86 #define C_SFD_IS_ACTIVE 0x01
87 #define C_CPU_CTRL_IS_ON 0x02
88 #define C_END_INSTR_MEM 0x03
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -