⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 spda_dtmf软拨号.txt

📁 8888是一款高性能的电话通信芯片
💻 TXT
字号:
;=====================================================
;	Lixin: 2002/7/30
;	dtmf dial
;	fx=8M
;=====================================================
.include "sys.h"
.include "def_macro.h"
.include "sys_var.h"
.include	"InterruptServer.h"

.global	DialOutController_DialOut
.global	DialOutController_Initial
.global	DialOutController_SetIndex
.global	DialOutController_Int_TimerA
.global	DialOutController_Int_DA

_sr_DA_OUT		equ		_doc_data
_sr_DTMF_FLAG	equ		_doc_flag

bDIAL_INP		equ		0
bFINISH			equ		1

cDIAL_TIME	equ 50	;25			;0x600*(286/8000000)=54.912ms
cDTSLI_TIME	equ 100	;50		;(0xc00-0x600)*286/8000000=54.912ms

;DACNT_TBL is the da numbers in one sin wave of a frequency
DACNT_TBL:	DW	86,78,71,64,50,45,41,37 

;DTRANS_TBL is used to calculate the two freq for one number
DTRANS_TBL:	DW	0DH, 00H, 01H, 02H, 04H, 05H, 06H, 08H, 09H, 0AH, 0CH, 0EH, 0BH, 0FH, 03H, 07H; '*'->0AH, '#'->0BH
; the DA out table
;×××××××频率低采样个数多,频率高采样点少××××××××××
F_697:
	DW	0X1C0,0X1E0,0X201,0X221,0X241,0X260,0X27E,0X29B,0X2B7,0X2D1,0X2EA,0X302,0X318,0X32C,0X33E,0X34E,0X35C,0X368,0X371,0X378
	DW	0X37D,0X37F,0X37F,0X37D,0X378,0X371,0X368,0X35C,0X34E,0X33E,0X32C,0X318,0X302,0X2EA,0X2D1,0X2B7,0X29B,0X27E,0X260,0X241
	DW	0X221,0X201,0X1E0,0X1C0,0X19F,0X17E,0X15E,0X13E,0X11F,0X101,0XE4,0XC8,0XAE,0X95,0X7D,0X67,0X53,0X41,0X31,0X23
	DW	0X17,0XE,0X7,0X2,0X0,0X0,0X2,0X7,0XE,0X17,0X23,0X31,0X41,0X53,0X67,0X7D,0X95,0XAE,0XC8,0XE4
	DW	0X101,0X11F,0X13E,0X15E,0X17E,0X19F

F_770:
	DW	0X1C0,0X1E4,0X207,0X22B,0X24D,0X26F,0X290,0X2AF,0X2CD,0X2E9,0X303,0X31B,0X330,0X343,0X354,0X362,0X36E,0X376,0X37C,0X37F
	DW	0X37F,0X37C,0X376,0X36E,0X362,0X354,0X343,0X330,0X31B,0X303,0X2E9,0X2CD,0X2AF,0X290,0X26F,0X24D,0X22B,0X207,0X1E4,0X1C0
	DW	0X19B,0X178,0X154,0X132,0X110,0XEF,0XD0,0XB2,0X96,0X7C,0X64,0X4F,0X3C,0X2B,0X1D,0X11,0X9,0X3,0X0,0X0
	DW	0X3,0X9,0X11,0X1D,0X2B,0X3C,0X4F,0X64,0X7C,0X96,0XB2,0XD0,0XEF,0X110,0X132,0X154,0X178,0X19B

F_852:
	DW	0X1C0,0X1E7,0X20E,0X235,0X25B,0X27F,0X2A2,0X2C4,0X2E3,0X300,0X31A,0X332,0X347,0X358,0X367,0X372,0X37A,0X37F,0X37F,0X37D
	DW	0X377,0X36D,0X360,0X350,0X33D,0X326,0X30D,0X2F2,0X2D3,0X2B3,0X291,0X26D,0X248,0X222,0X1FB,0X1D3,0X1AC,0X184,0X15D,0X137
	DW	0X112,0XEE,0XCC,0XAC,0X8D,0X72,0X59,0X42,0X2F,0X1F,0X12,0X8,0X2,0X0,0X0,0X5,0XD,0X18,0X27,0X38
	DW	0X4D,0X65,0X7F,0X9C,0XBB,0XDD,0X100,0X124,0X14A,0X171,0X198

F_941:
	DW	0X1C0,0X1EB,0X217,0X242,0X26B,0X293,0X2B8,0X2DC,0X2FC,0X31A,0X334,0X34B,0X35D,0X36C,0X377,0X37D,0X380,0X37D,0X377,0X36C
	DW	0X35D,0X34B,0X334,0X31A,0X2FC,0X2DC,0X2B8,0X293,0X26B,0X242,0X217,0X1EB,0X1C0,0X194,0X168,0X13D,0X114,0XEC,0XC7,0XA3
	DW	0X83,0X65,0X4B,0X34,0X22,0X13,0X8,0X2,0X0,0X2,0X8,0X13,0X22,0X34,0X4B,0X65,0X83,0XA3,0XC7,0XEC
	DW	0X114,0X13D,0X168,0X194

F_1209:
	DW	0X240,0X288,0X2CF,0X314,0X355,0X392,0X3CA,0X3FB,0X426,0X449,0X463,0X475,0X47E,0X47E,0X475,0X463,0X449,0X426,0X3FB,0X3CA
	DW	0X392,0X355,0X314,0X2CF,0X288,0X240,0X1F7,0X1B0,0X16B,0X12A,0XED,0XB5,0X84,0X59,0X36,0X1C,0XA,0X1,0X1,0XA
	DW	0X1C,0X36,0X59,0X84,0XB5,0XED,0X12A,0X16B,0X1B0,0X1F7

F_1336:
	DW	0X240,0X290,0X2DE,0X32A,0X371,0X3B2,0X3EC,0X41D,0X445,0X463,0X477,0X47F,0X47C,0X46E,0X456,0X432,0X405,0X3D0,0X392,0X34E
	DW	0X305,0X2B7,0X268,0X217,0X1C8,0X17A,0X131,0XED,0XAF,0X7A,0X4D,0X29,0X11,0X3,0X0,0X8,0X1C,0X3A,0X62,0X93
	DW	0XCD,0X10E,0X155,0X1A1,0X1EF

F_1477:
	DW	0X240,0X297,0X2ED,0X33F,0X38B,0X3CF,0X40A,0X43A,0X45E,0X475,0X47F,0X47C,0X46B,0X44D,0X423,0X3EE,0X3AE,0X366,0X317,0X2C3
	DW	0X26C,0X213,0X1BC,0X168,0X119,0XD1,0X91,0X5C,0X32,0X14,0X3,0X0,0XA,0X21,0X45,0X75,0XB0,0XF4,0X140,0X192
	DW	0X1E8

F_1633:
	DW	0X240,0X2A1,0X2FF,0X358,0X3A9,0X3F0,0X42A,0X456,0X473,0X47F,0X47B,0X466,0X442,0X40F,0X3CE,0X382,0X32D,0X2D1,0X270,0X20F
	DW	0X1AE,0X152,0XFD,0XB1,0X70,0X3D,0X19,0X4,0X0,0XC,0X29,0X55,0X8F,0XD6,0X127,0X180,0X1DE
;FREQ_INDEX is the adresss for the sin data
FREQ_COM_TBL	DW	F_697,F_770,F_852,F_941,F_1209,F_1336,F_1477,F_1633

TMR16_CON	DB	1


; 子程序=>>

DialOutController_Initial:
		ret

DialOutController_SetIndex:
	cp	r3,#0bh
	jp	UGT,_set_index_fail
	ld	_doc_index,r3
	jp	_set_index_exit
_set_index_fail:
	ld	r3,#0fh
	ld	_doc_index,r3	
_set_index_exit:
	ret
		
DialOutController_Int_TimerA:
	LD		R0,_sr_DA_OUT
	BITS	ADCON.5			
	LD		DADATA,R0
	LD		DADATA,R0
	LD		DADATA,R0
	LD		DADATA,R0
	BITS	_sr_DTMF_FLAG.bFINISH	
	ret
	
DialOutController_Int_DA:
	
	ret
				
;------------拨号程序>>----------------	
;    PUBLIC _fun_DTMF_DIAL
;**********************************************
;*_FUN_DIAL
;*FUNCTION:	DIAL (NUMBER)
;*OUTPUT:	DTMF wave
;*HW STACK:	USED 1+1=2 LEVEL
;*SW STACK:	USED 0 BYTES
;*USED:		NUM_COUNTER,L_FQ_DA_NUM,H_FQ_DA_NUM,LOW_FREQ_I,HIGH_FREQ_I,LOW_F_CNTR,HIGH_F_CNTR,TIMECNTR
;*			IDH,IDL0,ILH,ILL,TBL,TBH,R0,R1,R2,R3_tr_MAC_TMP0[0-1]
;*          FLAG C(Z,NZ)
;**********************************************
;tempdata
STACK_SIZE	.SETVAR	0
_tm_LOWFDA_CNT		EQU	STACK_SIZE	;DA num in one cycle of  low frequency wave
STACK_SIZE	.SETVAR	STACK_SIZE+1
_tm_HIGFDA_CNT		EQU	STACK_SIZE	;DA num in one cycle of  high frequency wave
STACK_SIZE	.SETVAR	STACK_SIZE+1
_tm_LOWF_INDEX		EQU	STACK_SIZE	;STORE LOW FREQUENCY SIN DATA ADDRESS
STACK_SIZE	.SETVAR	STACK_SIZE+2
_tm_HIGF_INDEX		EQU	STACK_SIZE	;STORE HIGH FREQUENCY SIN DATA ADDRESS
STACK_SIZE	.SETVAR	STACK_SIZE+2
_tm_LOWF_CNTR		EQU	STACK_SIZE	;low freq counter
STACK_SIZE	.SETVAR	STACK_SIZE+1
_tm_HIGF_CNTR		EQU	STACK_SIZE	;high freq counter
STACK_SIZE	.SETVAR	STACK_SIZE+1
_tm_TIME_CNTR		EQU	STACK_SIZE	;counter to control the output time
STACK_SIZE	.SETVAR	STACK_SIZE+2

bDTMF_FINISH		EQU		bFINISH
;*--------------------------------------------------------------
; Func: _fun_DTMF_DIAL,
; Input: _doc_index, the number to dial out
;*--------------------------------------------------------------

DialOutController_DialOut:
		bitr	p4.0
		_macro_ALLOC STACK_SIZE
		
		ld	r3,#IS_TIMER_A_DIALOUT
		lcall	InterruptServer_Regist
		ld	r3,#IS_DA_DIALOUT
		lcall	InterruptServer_Regist
		
		ld	r3,_doc_index
		cp	r3,#0fh
		jp	z,_dial_out_exit
		
		BMS
		LD	R0, #<DTRANS_TBL	; Transfe from number to position
		LD	ILH, R0
		LD	R0, #>DTRANS_TBL
		ADD	R0, R3
		LD	ILL, R0
		LDC	@IL
		LD	R2, TBL
		LD	R3, R2			; Get the DA count for the frequent combination
		SR	R3
		SR	R3
		AND	R2, #3			; R2 for high freq, R3 for low freq
		ADD	R2, #4
		LD	R0, #<DACNT_TBL
		LD	ILH, R0
		LD	R0, #>DACNT_TBL
		ADD	R0, R3
		LD	ILL, R0
		LDC	@IL
		LD	R0, TBL
		_macro_WRITE	_tm_LOWFDA_CNT, R0
		LD	R0, #>DACNT_TBL
		ADD	R0, R2
		LD	ILL, R0
		LDC	@IL
		LD	R0, TBL
		_macro_WRITE	_tm_HIGFDA_CNT, R0
		LD	R0, #<FREQ_COM_TBL	; Get the freq combination index
		LD	ILH, R0
		LD	R0, #>FREQ_COM_TBL
		ADD	R0, R3
		LD	ILL, R0
		LDC	@IL
		LD	R0, TBH
		_macro_WRITE	_tm_LOWF_INDEX, R0
		LD	R0, TBL
		_macro_WRITE	_tm_LOWF_INDEX+1, R0
		LD	R0, #>FREQ_COM_TBL
		ADD	R0, R2
		LD	ILL, R0
		LDC	@IL
		LD	R0, TBH
		_macro_WRITE	_tm_HIGF_INDEX, R0
		LD	R0, TBL
		_macro_WRITE	_tm_HIGF_INDEX+1, R0
		LD	R0, #0
		_macro_WRITE	_tm_LOWF_CNTR, R0
		_macro_WRITE	_tm_HIGF_CNTR, R0
		_macro_WRITE	_tm_TIME_CNTR, R0
		_macro_WRITE	_tm_TIME_CNTR+1, R0
		BITS	_sr_DTMF_FLAG.bDIAL_INP
		
; Set the timer A for DTMF usage 
		LD	R0, TACON
		PUSH	R0
		LD	R0, #43H		; timer A run, Fxx/1
		LD	TACON, R0
		LD	R0, TADATA
		PUSH	R0
		LD	R0, #134; the FREQ dividor
		LD	TADATA, R0
		BITS	ADCON.6			; Enable the DA int	
; Backup the interrupt setting
		DI
		LD	R0, IMR00
		PUSH	R0
		LD	R0, #00
		LD	IMR00, R0
		LD	R0, IMR01
		PUSH	R0
		LD	R0, #00
		LD	IMR01, R0
		LD	R0, IMR1
		PUSH	R0	
		LD	R0, #00	
		LD	IMR1, R0
; Initial the interrupt setting		
		BITS	ADCON.5				; Enable the AD/DA clk
		BITS	IMR00.0				; Enable the DA INT
		BITS	IMR00.1				; Enable timer A
		BITS	DACON.0				; Enable DA
		EI
; Dial out the DTMF wave
	DA_LOOP:
		_macro_READ	R2, _tm_LOWF_INDEX	; Get the low freq DA out
		_macro_READ	R0, _tm_LOWF_INDEX+1
		_macro_READ	R1, _tm_LOWF_CNTR
		ADD	R0, R1
		INCC	R2
		LD	ILH, R2
		LD	ILL, R0
		LDC	@IL
		LD	R0, TBL
		PUSH	R0
		LD	R1, TBH
		_macro_READ	R0, _tm_HIGF_INDEX	; Get the high freq DA out
		_macro_READ	R2, _tm_HIGF_INDEX+1
		_macro_READ	R3, _tm_HIGF_CNTR
		ADD	R2, R3
		INCC	R0
		LD	ILH, R0
		LD	ILL, R2
		LDC	@IL
		LD	R2, TBL
		LD	R3, TBH
		POP	R0
		ADD	R0, R2
		ADC	R1, R3
		SR	R1
		RRC	R0
		SR	R1
		RRC	R0
		SR	R1		
		RRC	R0
		_macro_READ	R1, _tm_LOWF_CNTR	; loop the DTMF wave
		INC	R1
		_macro_READ	R2, _tm_LOWFDA_CNT
		CP	R1, R2
		Jp	ULE, %F1
		LD	R1, #0
	%1:	
		_macro_WRITE	_tm_LOWF_CNTR, R1
		_macro_READ	R1, _tm_HIGF_CNTR
		INC	R1
		_macro_READ	R2, _tm_HIGFDA_CNT
		CP	R1, R2
		Jp	ULE, %F2
		LD	R1, #0
	%2:	
		_macro_WRITE	_tm_HIGF_CNTR, R1
		LD	_sr_DA_OUT, R0
	WAIT_DA:
		NOP	
		BITT	_sr_DTMF_FLAG.bFINISH
		Jp	Z, WAIT_DA
		BMS
		BITR	_sr_DTMF_FLAG.bFINISH
		_macro_READ	R0, _tm_TIME_CNTR	; output enough long time
		_macro_READ	R1, _tm_TIME_CNTR+1
		INC	R1
		INCC	R0
		_macro_WRITE	_tm_TIME_CNTR, R0
		_macro_WRITE	_tm_TIME_CNTR+1, R1
		CP	R1, #0
		Jp	NZ, DA_LOOP
		CP	R0, #cDIAL_TIME
		Jp	ULE, DA_LOOP
		
		LD	R0, #7FH			; output enough long empty time
		LD	_sr_DA_OUT, R0
	DTMF_WTIME:
		NOP	
		BITT	_sr_DTMF_FLAG.bDTMF_FINISH	
		Jp	Z, DTMF_WTIME
		BITR	_sr_DTMF_FLAG.bDTMF_FINISH
		_macro_READ	R0, _tm_TIME_CNTR
		_macro_READ	R1, _tm_TIME_CNTR+1
		INC	R1
		INCC	R0
		_macro_WRITE	_tm_TIME_CNTR, R0
		_macro_WRITE	_tm_TIME_CNTR+1, R1
		CP	R1, #0
		Jp	NZ, DTMF_WTIME
		CP	R0, #cDTSLI_TIME
		Jp	ULE, DTMF_WTIME
		
		BITR	_sr_DTMF_FLAG.bDIAL_INP
; Disable the DA clk and interrupt

		DI
		BITR	ADCON.5		; Disable the AD/DA clk
		BITR	DACON.0		; Disable the DA 
; Restore the IMR		
		POP	R0
		LD	IMR1, R0
		POP	R0
		LD	IMR01, R0
		POP	R0
		LD	IMR00, R0
		POP	R0
		LD	TADATA, R0
		POP	R0
		LD	TACON, R0
		EI
		
_dial_out_exit:
		ld	r3,#IS_TIMER_A_DIALOUT
		lcall	InterruptServer_Unregist
		ld	r3,#IS_DA_DIALOUT
		lcall	InterruptServer_Unregist

		_macro_FREE STACK_SIZE
		bits	p4.0
		
		RET
.end

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -