欢迎访问ic37.com |
会员登录 免费注册
发布采购

PIC16F87-I/P 参数 Datasheet PDF下载

PIC16F87-I/P图片预览
型号: PIC16F87-I/P
PDF下载: 下载PDF文件 查看货源
内容描述: 18 /20/ 28引脚增强型闪存微控制器采用纳瓦技术 [18/20/28-Pin Enhanced FLASH Microcontrollers with nanoWatt Technology]
分类和应用: 闪存微控制器
文件页数/大小: 214 页 / 3543 K
品牌: MICROCHIP [ MICROCHIP ]
 浏览型号PIC16F87-I/P的Datasheet PDF文件第138页浏览型号PIC16F87-I/P的Datasheet PDF文件第139页浏览型号PIC16F87-I/P的Datasheet PDF文件第140页浏览型号PIC16F87-I/P的Datasheet PDF文件第141页浏览型号PIC16F87-I/P的Datasheet PDF文件第143页浏览型号PIC16F87-I/P的Datasheet PDF文件第144页浏览型号PIC16F87-I/P的Datasheet PDF文件第145页浏览型号PIC16F87-I/P的Datasheet PDF文件第146页  
PIC16F87/88  
15.10.1 INT INTERRUPT  
15.10.3 PORTB INTCON CHANGE  
External interrupt on the RB0/INT pin is edge-triggered,  
either rising, if bit INTEDG (OPTION<6>) is set, or fall-  
ing, if the INTEDG bit is clear. When a valid edge  
appears on the RB0/INT pin, flag bit, INTF  
(INTCON<1>), is set. This interrupt can be disabled by  
clearing enable bit INTE (INTCON<4>). Flag bit INTF  
must be cleared in software in the Interrupt Service  
Routine before re-enabling this interrupt. The INT inter-  
rupt can wake-up the processor from SLEEP, if bit INTE  
was set prior to going into SLEEP. The status of global  
interrupt enable bit GIE decides whether or not the  
processor branches to the interrupt vector, following  
wake-up. See Section 15.13 “Power-down Mode  
(SLEEP)” for details on SLEEP mode.  
An input change on PORTB<7:4> sets flag bit RBIF  
(INTCON<0>). The interrupt can be enabled/disabled  
by setting/clearing enable bit RBIE (INTCON<4>), see  
Section 3.2 “EECON1 and EECON2 Registers”.  
15.11 Context Saving During Interrupts  
During an interrupt, only the return PC value is saved  
on the stack. Typically, users may wish to save key reg-  
isters during an interrupt (i.e., W, STATUS registers).  
Since the upper 16 bytes of each bank are common in  
the PIC16F87/88 devices, temporary holding registers  
W_TEMP, STATUS_TEMP, and PCLATH_TEMP  
should be placed in here. These 16 locations don’t  
require banking and therefore, make it easier for con-  
text save and restore. The same code shown in  
Example 15-1 can be used.  
15.10.2 TMR0 INTERRUPT  
An overflow (FFh 00h) in the TMR0 register will set  
flag bit TMR0IF (INTCON<2>). The interrupt can be  
enabled/disabled by setting/clearing enable bit TMR0IE  
(INTCON<5>), see Section 6.0 “Timer0 Module”.  
EXAMPLE 15-1:  
SAVING STATUS, W, AND PCLATH REGISTERS IN RAM  
MOVWF  
SWAPF  
CLRF  
MOVWF  
MOVF  
MOVWF  
CLRF  
:
W_TEMP  
STATUS,W  
STATUS  
STATUS_TEMP  
PCLATH, W  
PCLATH_TEMP  
PCLATH  
;Copy W to TEMP register  
;Swap status to be saved into W  
;bank 0, regardless of current bank, Clears IRP,RP1,RP0  
;Save status to bank zero STATUS_TEMP register  
;Only required if using page 1  
;Save PCLATH into W  
;Page zero, regardless of current page  
:(ISR)  
:
;(Insert user code here)  
MOVF  
MOVWF  
SWAPF  
PCLATH_TEMP, W  
PCLATH  
STATUS_TEMP,W  
;Restore PCLATH  
;Move W into PCLATH  
;Swap STATUS_TEMP register into W  
;(sets bank to original state)  
;Move W into STATUS register  
;Swap W_TEMP  
MOVWF  
SWAPF  
SWAPF  
STATUS  
W_TEMP,F  
W_TEMP,W  
;Swap W_TEMP into W  
DS30487B-page 140  
Preliminary  
2003 Microchip Technology Inc.