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 80C186EA
Page 1: ...80C186EA 80C188EA Microprocessor User s Manual...
Page 2: ...80C186EA 80C188EA Microprocessor User s Manual 1995...
Page 19: ......
Page 20: ...1 Introduction...
Page 21: ......
Page 28: ...2 Overview of the 80C186 Family Architecture...
Page 29: ......
Page 79: ......
Page 80: ...3 Bus Interface Unit...
Page 81: ......
Page 129: ......
Page 130: ...4 Peripheral Control Block...
Page 131: ......
Page 139: ......
Page 140: ...5 ClockGenerationand Power Management...
Page 141: ......
Page 165: ......
Page 166: ...6 Chip Select Unit...
Page 167: ......
Page 190: ...7 Refresh Control Unit...
Page 191: ......
Page 205: ......
Page 206: ...8 Interrupt Control Unit...
Page 207: ......
Page 239: ...INTERRUPT CONTROL UNIT 8 32...
Page 240: ...9 Timer Counter Unit...
Page 241: ......
Page 265: ......
Page 266: ...10 Direct Memory Access Unit...
Page 267: ......
Page 295: ...DIRECT MEMORY ACCESS UNIT 10 28...
Page 296: ...11 Math Coprocessing...
Page 297: ......
Page 314: ...12 ONCE Mode...
Page 315: ......
Page 318: ...A 80C186 Instruction Set Additions and Extensions...
Page 319: ......
Page 330: ...B Input Synchronization...
Page 331: ......
Page 334: ...C Instruction Set Descriptions...
Page 335: ......
Page 383: ...INSTRUCTION SET DESCRIPTIONS C 48...
Page 384: ...D Instruction Set Opcodes and Clock Cycles...
Page 385: ......
Page 408: ...Index...
Page 409: ......