📄 hal_uart.lst
字号:
##############################################################################
# #
# IAR 8051 C/C++ Compiler V7.20H/W32 18/Sep/2008 17:36:51 #
# 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 = C:\Texas Instruments\ZStack-1.4.2\Components\hal\ #
# target\CC2430DB\hal_uart.c #
# Command line = -f "C:\Texas Instruments\ZStack-1.4.2\Projects\zs #
# tack\Samples\SampleApp\CC2430DB\..\..\..\Tools\CC #
# 2430DB\f8wRouter.cfg" (-DCPU32MHZ #
# -DFORCE_MAC_NEAR -DROOT=__near_func #
# -DMAC_CFG_APP_PENDING_QUEUE=TRUE -DRTR_NWK #
# -DBLINK_LEDS "-DCONST=const __code" #
# -DGENERIC=__generic) -f "C:\Texas #
# Instruments\ZStack-1.4.2\Projects\zstack\Samples\ #
# SampleApp\CC2430DB\..\..\..\Tools\CC2430DB\f8wCon #
# fig.cfg" (-DSECURE=0 -DDEFAULT_CHANLIST=0x0000080 #
# 0 -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 "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\inc\clib\" -I "C:\Texas #
# Instruments\ZStack-1.4.2\Projects\zstack\Samples\ #
# SampleApp\CC2430DB\" -I "C:\Texas #
# Instruments\ZStack-1.4.2\Projects\zstack\Samples\ #
# SampleApp\CC2430DB\..\Source\" -I "C:\Texas #
# Instruments\ZStack-1.4.2\Projects\zstack\Samples\ #
# SampleApp\CC2430DB\..\..\..\ZMain\TI2430DB\" -I #
# "C:\Texas Instruments\ZStack-1.4.2\Projects\zstac #
# k\Samples\SampleApp\CC2430DB\..\..\..\..\..\Compo #
# nents\mt\" -I "C:\Texas #
# Instruments\ZStack-1.4.2\Projects\zstack\Samples\ #
# SampleApp\CC2430DB\..\..\..\..\..\Components\hal\ #
# include\" -I "C:\Texas Instruments\ZStack-1.4.2\P #
# rojects\zstack\Samples\SampleApp\CC2430DB\..\..\. #
# .\..\..\Components\hal\target\CC2430DB\" -I #
# "C:\Texas Instruments\ZStack-1.4.2\Projects\zstac #
# k\Samples\SampleApp\CC2430DB\..\..\..\..\..\Compo #
# nents\osal\mcu\ccsoc\" -I "C:\Texas #
# Instruments\ZStack-1.4.2\Projects\zstack\Samples\ #
# SampleApp\CC2430DB\..\..\..\..\..\Components\osal #
# \include\" -I "C:\Texas #
# Instruments\ZStack-1.4.2\Projects\zstack\Samples\ #
# SampleApp\CC2430DB\..\..\..\..\..\Components\stac #
# k\af\" -I "C:\Texas Instruments\ZStack-1.4.2\Proj #
# ects\zstack\Samples\SampleApp\CC2430DB\..\..\..\. #
# .\..\Components\stack\nwk\" -I "C:\Texas #
# Instruments\ZStack-1.4.2\Projects\zstack\Samples\ #
# SampleApp\CC2430DB\..\..\..\..\..\Components\stac #
# k\sec\" -I "C:\Texas Instruments\ZStack-1.4.2\Pro #
# jects\zstack\Samples\SampleApp\CC2430DB\..\..\..\ #
# ..\..\Components\stack\sys\" -I "C:\Texas #
# Instruments\ZStack-1.4.2\Projects\zstack\Samples\ #
# SampleApp\CC2430DB\..\..\..\..\..\Components\stac #
# k\zdo\" -I "C:\Texas Instruments\ZStack-1.4.2\Pro #
# jects\zstack\Samples\SampleApp\CC2430DB\..\..\..\ #
# ..\..\Components\zmac\f8w\" -I "C:\Texas #
# Instruments\ZStack-1.4.2\Projects\zstack\Samples\ #
# SampleApp\CC2430DB\..\..\..\..\..\Components\zmac #
# \" -I "C:\Texas Instruments\ZStack-1.4.2\Projects #
# \zstack\Samples\SampleApp\CC2430DB\..\..\..\..\.. #
# \Components\services\saddr\" -I "C:\Texas #
# Instruments\ZStack-1.4.2\Projects\zstack\Samples\ #
# SampleApp\CC2430DB\..\..\..\..\..\Components\serv #
# ices\sdata\" -I "C:\Texas #
# Instruments\ZStack-1.4.2\Projects\zstack\Samples\ #
# SampleApp\CC2430DB\..\..\..\..\..\Components\mac\ #
# include\" -I "C:\Texas Instruments\ZStack-1.4.2\P #
# rojects\zstack\Samples\SampleApp\CC2430DB\..\..\. #
# .\..\..\Components\mac\high_level\" -I "C:\Texas #
# Instruments\ZStack-1.4.2\Projects\zstack\Samples\ #
# SampleApp\CC2430DB\..\..\..\..\..\Components\mac\ #
# low_level\srf03\" -I "C:\Texas #
# Instruments\ZStack-1.4.2\Projects\zstack\Samples\ #
# SampleApp\CC2430DB\..\..\..\..\..\Components\mac\ #
# low_level\srf03\single_chip\" -D CC2430DB -D #
# SOFT_START -D ZAPP_P1 -D HOLD_AUTO_START -lC #
# "C:\Texas Instruments\ZStack-1.4.2\Projects\zstac #
# k\Samples\SampleApp\CC2430DB\RouterDB\List\" -lA #
# "C:\Texas Instruments\ZStack-1.4.2\Projects\zstac #
# k\Samples\SampleApp\CC2430DB\RouterDB\List\" #
# --diag_suppress Pe001,Pa010 --diag_remark pe550 #
# -o "C:\Texas Instruments\ZStack-1.4.2\Projects\zs #
# tack\Samples\SampleApp\CC2430DB\RouterDB\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 #
# "C:\Texas Instruments\ZStack-1.4.2\Components\hal #
# \target\CC2430DB\hal_uart.c" #
# List file = C:\Texas Instruments\ZStack-1.4.2\Projects\zstack #
# \Samples\SampleApp\CC2430DB\RouterDB\List\hal_uar #
# t.lst #
# Object file = C:\Texas Instruments\ZStack-1.4.2\Projects\zstack #
# \Samples\SampleApp\CC2430DB\RouterDB\Obj\hal_uart #
# .r51 #
# #
# #
##############################################################################
C:\Texas Instruments\ZStack-1.4.2\Components\hal\target\CC2430DB\hal_uart.c
1 /******************************************************************************
2 Filename: _hal_uart.c
3 Revised: $Date: 2007-03-26 11:53:55 -0700 (Mon, 26 Mar 2007) $
4 Revision: $Revision: 13853 $
5
6 Description: This file contains the interface to the H/W UART driver.
7
8 Copyright (c) 2007 by Texas Instruments, Inc.
9 All Rights Reserved. Permission to use, reproduce, copy, prepare
10 derivative works, modify, distribute, perform, display or sell this
11 software and/or its documentation for any purpose is prohibited
12 without the express written consent of Texas Instruments, Inc.
13 ******************************************************************************/
14
15 /*********************************************************************
16 * INCLUDES
17 */
18
19 #include "hal_types.h"
20 #include "hal_assert.h"
21 #include "hal_board.h"
\ In segment SFR_AN, at 0x95
\ unsigned char volatile __sfr ST0
\ ST0:
\ 000000 DS 1
\ In segment SFR_AN, at 0x9a
\ unsigned char volatile __sfr IEN2
\ IEN2:
\ 000000 DS 1
\ In segment SFR_AN, at 0xc1
\ unsigned char volatile __sfr U0DBUF
\ U0DBUF:
\ 000000 DS 1
\ In segment SFR_AN, at 0xf1
\ unsigned char volatile __sfr PERCFG
\ PERCFG:
\ 000000 DS 1
\ In segment SFR_AN, at 0xf2
\ unsigned char volatile __sfr ADCCFG
\ ADCCFG:
\ 000000 DS 1
\ In segment SFR_AN, at 0xf4
\ unsigned char volatile __sfr P1SEL
\ P1SEL:
\ 000000 DS 1
\ In segment SFR_AN, at 0xf9
\ unsigned char volatile __sfr U1DBUF
\ U1DBUF:
\ 000000 DS 1
\ In segment SFR_AN, at 0xfa
\ unsigned char volatile __sfr U1BAUD
\ U1BAUD:
\ 000000 DS 1
\ In segment SFR_AN, at 0xfb
\ unsigned char volatile __sfr U1UCR
\ U1UCR:
\ 000000 DS 1
\ In segment SFR_AN, at 0xfc
\ unsigned char volatile __sfr U1GCR
\ U1GCR:
\ 000000 DS 1
\ In segment SFR_AN, at 0xfe
\ unsigned char volatile __sfr P1DIR
\ P1DIR:
\ 000000 DS 1
\ In segment SFR_AN, at 0xff
\ unsigned char volatile __sfr P2DIR
\ P2DIR:
\ 000000 DS 1
22 #include "hal_defs.h"
23 #if defined( HAL_UART_DMA ) && HAL_UART_DMA
24 #include "hal_dma.h"
25 #endif
26 #include "hal_mcu.h"
27 #include "hal_uart.h"
28 #include "osal.h"
29
30 /*********************************************************************
31 * MACROS
32 */
33
34 #if !defined ( HAL_UART_DEBUG )
35 #define HAL_UART_DEBUG FALSE
36 #endif
37
38 #if !defined ( HAL_UART_CLOSE )
39 #define HAL_UART_CLOSE FALSE
40 #endif
41
42 #if !defined ( HAL_UART_BIG_TX_BUF )
43 #define HAL_UART_BIG_TX_BUF FALSE
44 #endif
45
46 /*
47 * The MAC_ASSERT macro is for use during debugging.
48 * The given expression must evaluate as "true" or else fatal error occurs.
49 * At that point, the call stack feature of the debugger can pinpoint where
50 * the problem occurred.
51 *
52 * To disable this feature and save code size, the project should define
53 * HAL_UART_DEBUG to FALSE.
54 */
55 #if ( HAL_UART_DEBUG )
56 #define HAL_UART_ASSERT( expr) HAL_ASSERT( expr )
57 #else
58 #define HAL_UART_ASSERT( expr )
59 #endif
60
61 #define P2DIR_PRIPO 0xC0
62 #if HAL_UART_0_ENABLE
63 #define HAL_UART_PRIPO 0x00
64 #else
65 #define HAL_UART_PRIPO 0x40
66 #endif
67
68 #define HAL_UART_0_PERCFG_BIT 0x01 // USART0 on P0, so clear this bit.
69 #define HAL_UART_0_P0_RX_TX 0x0c // Peripheral I/O Select for Rx/Tx.
70 #define HAL_UART_0_P0_RTS 0x10 // Peripheral I/O Select for RTS.
71 #define HAL_UART_0_P0_CTS 0x20 // Peripheral I/O Select for CTS.
72
73 #define HAL_UART_1_PERCFG_BIT 0x02 // USART1 on P1, so set this bit.
74 #define HAL_UART_1_P1_RTS 0x10 // Peripheral I/O Select for RTS.
75 #define HAL_UART_1_P1_CTS 0x20 // Peripheral I/O Select for CTS.
76 #define HAL_UART_1_P1_RX_TX 0xC0 // Peripheral I/O Select for Rx/Tx.
77
78 #define TX_AVAIL( cfg ) \
79 ((cfg->txTail == cfg->txHead) ? (cfg->txMax-1) : \
80 ((cfg->txTail > cfg->txHead) ? (cfg->txTail - cfg->txHead - 1) : \
81 (cfg->txMax - cfg->txHead + cfg->txTail)))
82
83 #define RX0_FLOW_ON ( P0 &= ~HAL_UART_0_P0_CTS )
84 #define RX0_FLOW_OFF ( P0 |= HAL_UART_0_P0_CTS )
85 #define RX1_FLOW_ON ( P1 &= ~HAL_UART_1_P1_CTS)
86 #define RX1_FLOW_OFF ( P1 |= HAL_UART_1_P1_CTS )
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -