9-21
TIMER/COUNTER UNIT
Example 9-2. Configuring a Square-Wave Generator
$mod186
name
example_timer1_square_wave_code
;FUNCTION:
This function generates a square wave of given
;
frequency and duty cycle on Timer 1 output pin.
;
; SYNTAX:
extern void far clock(int mark, int space)
;
; INPUTS:
mark - This is the mark (1) time.
;
space - This is the space (0) time.
;
;
The register compare value for a given time can be
;
easily calculated from the formula below.
;
;
CompareValue = (req_pulse_width*f)/4
;
; OUTPUTS:
None
;
; NOTE:
Parameters are passed on the stack as required by
;
high-level Languages
T1CMPA
equ xxxxH
;substitute register offsets
T1CMPB
equ xxxxH
T1CNT
equ xxxxH
T1CON
equ xxxxH
lib_80186
segment public ’code’
assume
cs:lib_80186
public
_clock
_clock
proc far
push
bp
;save caller’s bp
mov
bp, sp
;get current top of stack
_space
equ word ptr[bp+6]
;get parameters off the stack
_mark
equ word ptr[bp+8]
push
ax
;save registers that will be
push
bx
;modified
push
dx
mov
dx, T1CMPA
;set mark time
mov
ax, _mark
out
dx, al
mov
dx, T1CMPB
;set space time
mov
ax, _space
out
dx, al
mov
dx, T1CNT
;Clear Timer 1 Counter
xor
ax, ax
out
dx, al
mov
dx, T1CON
;start Timer 1
mov ax,
C003H
out dx,
al
Summary of Contents for 80C186XL
Page 1: ...80C186XL 80C188XL Microprocessor User s Manual...
Page 2: ...80C186XL 80C188XL Microprocessor User s Manual 1995...
Page 18: ...1 Introduction...
Page 19: ......
Page 27: ......
Page 28: ...2 Overview of the 80C186 Family Architecture...
Page 29: ......
Page 79: ......
Page 80: ...3 Bus Interface Unit...
Page 81: ......
Page 127: ......
Page 128: ...4 Peripheral Control Block...
Page 129: ......
Page 137: ......
Page 138: ...5 ClockGenerationand Power Management...
Page 139: ......
Page 154: ...6 Chip Select Unit...
Page 155: ......
Page 178: ...7 Refresh Control Unit...
Page 179: ......
Page 193: ......
Page 194: ...8 Interrupt Control Unit...
Page 195: ......
Page 227: ......
Page 228: ...9 Timer Counter Unit...
Page 229: ......
Page 253: ......
Page 254: ...10 Direct Memory Access Unit...
Page 255: ......
Page 283: ......
Page 284: ...11 Math Coprocessing...
Page 285: ......
Page 302: ...12 ONCE Mode...
Page 303: ......
Page 306: ...A 80C186 Instruction Set Additions and Extensions...
Page 307: ......
Page 318: ...B Input Synchronization...
Page 319: ......
Page 322: ...C Instruction Set Descriptions...
Page 323: ......
Page 371: ......
Page 372: ...D Instruction Set Opcodes and Clock Cycles...
Page 373: ......
Page 396: ...Index...
Page 397: ......