; Filename: DTMF_GEN.SRC ; Author: Stephen Holland ; Applications Engineer ; Scenix Semiconductor Inc. ; Revision: 1.0 ; Date: July 05, 1998 ; Part: SX28AC rev. 2.5 ; Freq: 50Mhz ; Compiled using Parallax SX-Key software v0.8 ; ; *This virtual peripheral relies on external RC filters to generate complete ; DTMF tones. ; ; ; The DTMF number string to be dialed is defined by the label _dialnum. ; Each key can be defined as an 8-bit hex value where the upper and ; lower nibbles repesent the keypad bitwise row and column ($RRRRCCCC). ; ; example: _dialnum dw $11,$21,$82,$42,$14,$12,$41,$42,$42,$42,$42,0 ; represents the number 14083278888. ; ; Keypad ; ; 1209 1336 1477 1633 ; ________________________________ ; | | | | | ; 697 | $11 | $12 | $14 | $18 | ; | (1) | (2) | (3) | (A) | ; ________________________________ ; | | | | | ; 770 | $21 | $22 | $24 | $28 | ; | (4) | (5) | (6) | (B) | ; ________________________________ ; | | | | | ; 852 | $41 | $42 | $44 | $48 | ; | (7) | (8) | (9) | (C) | ; ________________________________ ; | | | | | ; 941 | $81 | $82 | $84 | $88 | ; | (*) | (0) | (#) | (D) | ; ________________________________ ; ;************************************************************* ; Device ;************************************************************* device pins28,pages4,banks8,oschs device turbo,stackx,optionx id 'DTMF_GEN' reset reset_entry ;************************************************************* ; Equates ;************************************************************* pwm0_pin = rb.4 pwm1_pin = rb.5 ;************************************************************* ; Variables ;************************************************************* org 8 temp ds 1 string ds 1 ;************************************************************* ; Bank 0 variables ;************************************************************* org 10h timers = $ ;timer timer_accl ds 1 timer_acch ds 1 timer_flag ds 1 ;************************************************************* ; Bank 1 variables ;************************************************************* org 30h pwm = $ pwm_duty_1 ds 1 pwm_duty_1_buf ds 1 pwm_duty_2 ds 1 pwm_duty_2_buf ds 1 pwm_period_1 ds 1 pwm_period_1_buf ds 1 pwm_period_2 ds 1 pwm_period_2_buf ds 1 counter_low ds 1 counter_high ds 1 row ds 1 col ds 1 ;************************************************************* ; Interrupt routine - virtual peripherals ;************************************************************* org 0 interrupt ;3 it takes 3 cycles to get an interrupt bank timers ;1 ;timer stc ;1 set carry add timer_accl,#1 ;2 add timer_accl+carry(=1) sc jmp :timer_out add timer_acch,#0 snc ;1 setb timer_flag.0 ;1 :timer_out ;=7 ;************************************************************* ; D/A Conversions ;************************************************************* da_conv bank pwm ;1 dec pwm_duty_1 ;1 decrement port_duty movb pwm0_pin,/pwm_duty_1.7 ;4 move complement of most significant bit to output dec pwm_duty_2 ;1 decrement port_duty movb pwm1_pin,/pwm_duty_2.7 ;4 move complement of most significant bit to output decsz pwm_period_1 ;1 jmp interrupt_out ;3 mov pwm_duty_1,#5 ;2 mov pwm_duty_2,#5 ;2 mov pwm_period_1,#9 ;2 make_dtmf get_row jb row.0,make697 ;4/6 jb row.1,make770 ;4/6 jb row.2,make852 ;4/6 jb row.3,make941 ;4/6 make697 csae counter_low,#end697 ;1 take new table value jmp :continue ;1 mov counter_low,#sine697 ;1 reload table-counter :continue mov w,counter_low ;1 mov m,#6 ;1 set page iread ;1 get table_data mov m,#$F ;1 mov pwm_duty_1,w ;1 inc counter_low ;1 jmp get_col make770 csae counter_low,#end770 ;1 take new table value jmp :continue ;1 mov counter_low,#sine770 ;1 reload table-counter :continue mov w,counter_low ;1 mov m,#6 ;1 set page iread ;1 get table_data mov m,#$F ;1 mov pwm_duty_1,w ;1 inc counter_low ;1 jmp get_col make852 csae counter_low,#end852 ;1 take new table value jmp :continue ;1 mov counter_low,#sine852 ;1 reload table-counter :continue mov w,counter_low ;1 mov m,#6 ;1 set page iread ;1 get table_data mov m,#$F ;1 mov pwm_duty_1,w ;1 inc counter_low ;1 jmp get_col make941 csae counter_low,#end941 ;1 take new table value jmp :continue ;1 mov counter_low,#sine941 ;1 reload table-counter :continue mov w,counter_low ;1 mov m,#6 ;1 set page iread ;1 get table_data mov m,#$F ;1 mov pwm_duty_1,w ;1 inc counter_low ;1 get_col jb col.0,make1209 ;4/6 jb col.1,make1336 ;4/6 jb col.2,make1477 ;4/6 jb col.3,make1633 ;4/6 make1209 csae counter_high,#end1200 ;1 take new table value jmp :continue ;1 mov counter_high,#sine1200 ;1 reload table-counter :continue mov w,counter_high ;1 mov m,#6 ;1 set page iread ;1 get table_data mov m,#$F ;1 mov pwm_duty_2,w ;1 = 21 inc counter_high ;1 jmp da_out make1336 csae counter_high,#end1336 ;1 take new table value jmp :continue ;1 mov counter_high,#sine1336 ;1 reload table-counter :continue mov w,counter_high ;1 mov m,#6 ;1 set page iread ;1 get table_data mov m,#$F ;1 mov pwm_duty_2,w ;1 = 21 inc counter_high ;1 jmp da_out make1477 csae counter_high,#end1477 ;1 take new table value jmp :continue ;1 mov counter_high,#sine1477 ;1 reload table-counter :continue mov w,counter_high ;1 mov m,#7 ;1 set page iread ;1 get table_data mov m,#$F ;1 mov pwm_duty_2,w ;1 = 21 inc counter_high ;1 jmp da_out make1633 csae counter_high,#end1633 ;1 take new table value jmp :continue ;1 mov counter_high,#sine1633 ;1 reload table-counter :continue mov w,counter_high ;1 mov m,#7 ;1 set page iread ;1 get table_data mov m,#$F ;1 mov pwm_duty_2,w ;1 = 21 inc counter_high ;1 da_out interrupt_out mov w,#-163 ;1 ;interrupt every 159 clocks retiw ;3 ;************************************************************* ; Reset entry ;************************************************************* reset_entry mov !ra,#%0000 ;set ra data direction register mov !rb,#%00110000 ;set rb data direction register mov m,#$F clr fsr ;reset all ram banks :loop setb fsr.4 clr ind ijnz fsr,:loop bank pwm mov pwm_period_1,#9 ;set initial periods mov pwm_period_2,#9 mov pwm_duty_1,#5 ;set initial duty cycles mov pwm_duty_2,#5 mov !option,#%10011111 ;enable rtcc interrupt ;************************************************************* ; Main ;************************************************************* main_loop mov w,#_dialnum ;send phone number string page DTMF_generation call DTMF_generation here jmp here jmp main_loop ;************************************************************* ; Subroutines ;************************************************************* org $200 ;************************************************************* ; Jump table for page 1 ;************************************************************* DTMF_generation jmp DTMF_generation_jump DTMF_generation_jump_out retp ;************************************************************* DTMF_generation_jump mov string,w ;send string at w loop mov w,string ;read chr at w mov m,#1 iread mov m,#$F test w ;if 0, exit snz jmp DTMF_generation_jump_out bank pwm mov temp,w and w,#$0f ;Keep only the lower 4 bits mov col,w ;This is the column swap temp mov w,temp and w,#$0f ;Keep only the lower 4 bits mov row,w ;This is the row setb ra.3 ;Enable output mov m,#$F mov !rb,#%00000000 ;1 Enable PWM outputs bank timers ;Send tone for 300ms mov !option,#%11011111 ;disable rtcc interrupt mov timer_accl,#$ff ;100mS mov timer_acch,#$0f ;--//-- mov !option,#%10011111 ;enable rtcc interrupt clrb timer_flag.0 ;Clear overflow-flag jnb timer_flag.0,$ ;Is overflow-flag set? bank timers mov !option,#%11011111 ;disable rtcc interrupt mov timer_accl,#$ff ;100mS mov timer_acch,#$0f ;--//-- mov !option,#%10011111 ;enable rtcc interrupt clrb timer_flag.0 ;Clear overflow-flag jnb timer_flag.0,$ ;Is overflow-flag set? bank timers mov !option,#%11011111 ;disable rtcc interrupt mov timer_accl,#$ff ;100mS mov timer_acch,#$0f ;--//-- mov !option,#%10011111 ;enable rtcc interrupt clrb timer_flag.0 ;Clear overflow-flag jnb timer_flag.0,$ ;Is overflow-flag set? :interdigit inc string ;next chr clrb ra.3 ;Disable output mov m,#$0f mov !rb,#%00110000 ;1 Disable PWM outputs bank timers ;Send tone for 100ms mov !option,#%11011111 ;disable rtcc interrupt mov timer_accl,#$ff ;50mS mov timer_acch,#$7f ;--//-- mov !option,#%10011111 ;enable rtcc interrupt clrb timer_flag.0 ;Clear overflow-flag jnb timer_flag.0,$ ;Is overflow-flag set? jmp loop ;************************************************************* ; Data ;************************************************************* org $1a0 _dialnum dw $22,0 org $600 sine697 = $ dw 5 ; 1 dw 6 ; 2 dw 7 ; 3 dw 7 ; 4 dw 8 ; 5 dw 8 ; 6 dw 8 ; 7 dw 8 ; 8 dw 9 ; 9 dw 9 ;10 dw 9 ;11 dw 9 ;12 dw 9 ;13 dw 9 ;14 dw 9 ;15 dw 9 ;16 dw 9 ;17 dw 8 ;18 dw 8 ;19 dw 8 ;20 dw 8 ;21 dw 7 ;22 dw 7 ;23 dw 6 ;24 dw 5 ;25 dw 4 ;26 dw 3 ;27 dw 2 ;28 dw 2 ;29 dw 2 ;30 dw 1 ;31 dw 1 ;32 dw 1 ;33 dw 1 ;34 dw 0 ;35 dw 0 ;36 dw 0 ;37 dw 0 ;38 dw 0 ;39 dw 0 ;40 dw 0 ;41 dw 1 ;42 dw 1 ;43 dw 1 ;44 dw 1 ;45 dw 2 ;46 dw 2 ;47 dw 3 ;48 end697 = $ dw 4 ;49 sine770 = $ dw 5 ; 1 dw 6 ; 2 dw 7 ; 3 dw 7 ; 4 dw 7 ; 5 dw 8 ; 6 dw 8 ; 7 dw 8 ; 8 dw 9 ; 9 dw 9 ;10 dw 9 ;11 dw 9 ;12 dw 9 ;13 dw 8 ;14 dw 8 ;15 dw 8 ;16 dw 7 ;17 dw 7 ;18 dw 7 ;19 dw 6 ;20 dw 5 ;21 dw 4 ;22 dw 3 ;23 dw 2 ;24 dw 2 ;25 dw 2 ;26 dw 1 ;27 dw 1 ;28 dw 1 ;29 dw 1 ;30 dw 0 ;31 dw 0 ;32 dw 0 ;33 dw 0 ;34 dw 0 ;35 dw 0 ;36 dw 1 ;37 dw 1 ;38 dw 1 ;39 dw 1 ;40 dw 2 ;41 dw 2 ;42 dw 3 ;43 end770 = $ dw 4 ;44 sine852 = $ dw 5 ; 1 dw 6 ; 2 dw 7 ; 3 dw 7 ; 4 dw 7 ; 5 dw 8 ; 6 dw 8 ; 7 dw 8 ; 8 dw 9 ; 9 dw 9 ;10 dw 9 ;11 dw 9 ;12 dw 9 ;13 dw 8 ;14 dw 8 ;15 dw 8 ;16 dw 7 ;17 dw 7 ;18 dw 7 ;19 dw 6 ;20 dw 5 ;21 dw 4 ;22 dw 3 ;23 dw 2 ;24 dw 2 ;25 dw 2 ;26 dw 1 ;27 dw 1 ;28 dw 1 ;29 dw 0 ;30 dw 0 ;31 dw 0 ;32 dw 0 ;33 dw 0 ;34 dw 1 ;35 dw 1 ;36 dw 1 ;37 dw 2 ;38 dw 2 ;39 dw 3 ;40 end852 = $ dw 4 ;41 sine941 = $ dw 5 ; 1 dw 6 ; 2 dw 7 ; 3 dw 7 ; 4 dw 8 ; 5 dw 8 ; 6 dw 8 ; 7 dw 9 ; 8 dw 9 ; 9 dw 9 ;10 dw 9 ;11 dw 8 ;12 dw 8 ;13 dw 8 ;14 dw 7 ;15 dw 7 ;16 dw 6 ;17 dw 5 ;18 dw 4 ;19 dw 3 ;20 dw 2 ;21 dw 2 ;22 dw 1 ;23 dw 1 ;24 dw 1 ;25 dw 0 ;26 dw 0 ;27 dw 0 ;28 dw 0 ;29 dw 0 ;30 dw 1 ;31 dw 1 ;32 dw 1 ;33 dw 2 ;34 dw 2 ;35 dw 3 ;36 end941 = $ dw 4 ;37 sine1200 = $ dw 5 ; 1 dw 7 ; 2 dw 8 ; 3 dw 8 ; 4 dw 9 ; 5 dw 9 ; 6 dw 10 ; 7 dw 9 ; 8 dw 9 ; 9 dw 8 ;10 dw 8 ;11 dw 7 ;12 dw 6 ;13 dw 5 ;14 dw 4 ;15 dw 3 ;16 dw 2 ;17 dw 1 ;18 dw 1 ;19 dw 0 ;20 dw 0 ;21 dw 0 ;22 dw 0 ;23 dw 0 ;24 dw 1 ;25 dw 1 ;26 dw 2 ;27 dw 3 ;28 end1200 = $ dw 4 ;29 sine1336 = $ dw 5 ; 1 dw 7 ; 2 dw 8 ; 3 dw 8 ; 4 dw 9 ; 5 dw 9 ; 6 dw 9 ; 7 dw 9 ; 8 dw 8 ; 9 dw 8 ;10 dw 7 ;11 dw 6 ;12 dw 5 ;13 dw 3 ;14 dw 2 ;15 dw 1 ;16 dw 1 ;17 dw 0 ;18 dw 0 ;19 dw 0 ;20 dw 0 ;21 dw 1 ;22 dw 1 ;23 dw 2 ;24 dw 3 ;25 end1336 = $ dw 4 ;26 org $700 sine1477 = $ dw 5 ; 1 dw 7 ; 2 dw 8 ; 3 dw 8 ; 4 dw 9 ; 5 dw 9 ; 6 dw 9 ; 7 dw 8 ; 8 dw 8 ; 9 dw 7 ;10 dw 6 ;11 dw 5 ;12 dw 3 ;13 dw 2 ;14 dw 1 ;15 dw 1 ;16 dw 0 ;17 dw 0 ;18 dw 0 ;19 dw 0 ;20 dw 1 ;21 dw 2 ;22 dw 3 ;23 end1477 = $ dw 4 ;24 sine1633 = $ dw 5 ; 1 dw 7 ; 2 dw 8 ; 3 dw 8 ; 4 dw 9 ; 5 dw 9 ; 6 dw 9 ; 7 dw 8 ; 8 dw 7 ; 9 dw 6 ;10 dw 5 ;11 dw 3 ;12 dw 2 ;13 dw 1 ;14 dw 1 ;15 dw 0 ;16 dw 0 ;17 dw 0 ;18 dw 1 ;19 dw 2 ;20 dw 3 ;21 end1633 = $ dw 4 ;22
file: /Techref/scenix/lib/io/osi1/dfs/dtmf.src, 13KB, , updated: 1999/2/20 12:23, local time: 2024/11/14 18:39,
18.219.220.133:LOG IN
|
©2024 These pages are served without commercial sponsorship. (No popup ads, etc...).Bandwidth abuse increases hosting cost forcing sponsorship or shutdown. This server aggressively defends against automated copying for any reason including offline viewing, duplication, etc... Please respect this requirement and DO NOT RIP THIS SITE. Questions? <A HREF="http://massmind.ecomorder.com/techref/scenix/lib/io/osi1/dfs/dtmf.src"> scenix lib io osi1 dfs dtmf</A> |
Did you find what you needed? |
Welcome to ecomorder.com! |
Welcome to massmind.ecomorder.com! |
.