Electronic Components Datasheet Search
  English  ▼
ALLDATASHEET.COM

X  

PIC16F84A Datasheet(PDF) 25 Page - Microchip Technology

Part # PIC16F84A
Description  18-pin Flash/EEPROM 8-Bit Microcontrollers
Download  124 Pages
Scroll/Zoom Zoom In 100%  Zoom Out
Manufacturer  MICROCHIP [Microchip Technology]
Direct Link  http://www.microchip.com
Logo MICROCHIP - Microchip Technology

PIC16F84A Datasheet(HTML) 25 Page - Microchip Technology

Back Button PIC16F84A Datasheet HTML 21Page - Microchip Technology PIC16F84A Datasheet HTML 22Page - Microchip Technology PIC16F84A Datasheet HTML 23Page - Microchip Technology PIC16F84A Datasheet HTML 24Page - Microchip Technology PIC16F84A Datasheet HTML 25Page - Microchip Technology PIC16F84A Datasheet HTML 26Page - Microchip Technology PIC16F84A Datasheet HTML 27Page - Microchip Technology PIC16F84A Datasheet HTML 28Page - Microchip Technology PIC16F84A Datasheet HTML 29Page - Microchip Technology Next Button
Zoom Inzoom in Zoom Outzoom out
 25 / 124 page
background image
PIC16F8X
© 1998 Microchip Technology Inc.
DS30430C-page 25
5.3
I/O Programming Considerations
5.3.1
BI-DIRECTIONAL I/O PORTS
Any instruction which writes, operates internally as a
read followed by a write operation. The BCF and BSF
instructions, for example, read the register into the
CPU, execute the bit operation and write the result back
to the register. Caution must be used when these
instructions are applied to a port with both inputs and
outputs defined. For example, a BSF operation on bit5
of PORTB will cause all eight bits of PORTB to be read
into the CPU. Then the BSF operation takes place on
bit5 and PORTB is written to the output latches. If
another bit of PORTB is used as a bi-directional I/O pin
(i.e., bit0) and it is defined as an input at this time, the
input signal present on the pin itself would be read into
the CPU and rewritten to the data latch of this particular
pin, overwriting the previous content. As long as the pin
stays in the input mode, no problem occurs. However,
if bit0 is switched into output mode later on, the content
of the data latch is unknown.
Reading the port register, reads the values of the port
pins. Writing to the port register writes the value to the
port latch. When using read-modify-write instructions
(i.e., BCF, BSF, etc.) on a port, the value of the port pins
is read, the desired operation is done to this value, and
this value is then written to the port latch.
A pin actively outputting a Low or High should not be
driven from external devices at the same time in order
to change the level on this pin (“wired-or”, “wired-and”).
The resulting high output current may damage the chip.
5.3.2
SUCCESSIVE OPERATIONS ON I/O
PORTS
The actual write to an I/O port happens at the end of an
instruction cycle, whereas for reading, the data must be
valid at the beginning of the instruction cycle
(Figure 5-5). Therefore, care must be exercised if a
write followed by a read operation is carried out on the
same I/O port. The sequence of instructions should be
such that the pin voltage stabilizes (load dependent)
before the next instruction which causes that file to be
read into the CPU is executed. Otherwise, the previous
state of that pin may be read into the CPU rather than
the new state. When in doubt, it is better to separate
these instructions with a NOP or another instruction not
accessing this I/O port.
Example 5-1 shows the effect of two sequential
read-modify-write instructions (e.g., BCF, BSF, etc.) on
an I/O port.
EXAMPLE 5-1:
READ-MODIFY-WRITE
INSTRUCTIONS ON AN
I/O PORT
;Initial PORT settings: PORTB<7:4> Inputs
;
PORTB<3:0> Outputs
;PORTB<7:6> have external pull-ups and are
;not connected to other circuitry
;
;
PORT latch
PORT pins
;
----------
---------
BCF PORTB, 7
; 01pp ppp
11pp ppp
BCF PORTB, 6
; 10pp ppp
11pp ppp
BSF STATUS, RP0
;
BCF TRISB, 7
; 10pp ppp
11pp ppp
BCF TRISB, 6
; 10pp ppp
10pp ppp
;
;Note that the user may have expected the
;pin values to be 00pp ppp. The 2nd BCF
;caused RB7 to be latched as the pin value
;(high).
FIGURE 5-5:
SUCCESSIVE I/O OPERATION
PC
PC + 1
PC + 2
PC + 3
Q1 Q2 Q3 Q4
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
Q1 Q2 Q3 Q4
Instruction
fetched
RB7:RB0
MOVWF PORTB
write to
PORTB
NOP
Port pin
sampled here
NOP
MOVF PORTB,W
Instruction
executed
MOVWF PORTB
write to
PORTB
NOP
MOVF PORTB,W
PC
TPD
Note:
This example shows a write to PORTB
followed by a read from PORTB.
Note that:
data setup time = (0.25TCY - TPD)
where TCY = instruction cycle
TPD = propagation delay
Therefore, at higher clock frequencies,
a write followed by a read may be
problematic.


Similar Part No. - PIC16F84A

ManufacturerPart #DatasheetDescription
logo
Microchip Technology
PIC16F84A MICROCHIP-PIC16F84A Datasheet
494Kb / 68P
   18-pin Enhanced Flash/EEPROM 8-Bit Microcontroller
1999
PIC16F84A MICROCHIP-PIC16F84A Datasheet
1Mb / 88P
   18-pin Enhanced FLASH/EEPROM 8-bit Microcontroller
2001
PIC16F84A MICROCHIP-PIC16F84A Datasheet
1Mb / 90P
   18-pin Enhanced FLASH/EEPROM 8-Bit Microcontroller
11/29/12 2001-2013
PIC16F84A MICROCHIP-PIC16F84A Datasheet
1Mb / 90P
   18-pin Enhanced FLASH/EEPROM 8-Bit Microcontroller
11/29/12
PIC16F84A MICROCHIP-PIC16F84A Datasheet
1Mb / 337P
   8-Bit CMOS Microcontrollers
01/18/02
More results

Similar Description - PIC16F84A

ManufacturerPart #DatasheetDescription
logo
Microchip Technology
PIC16F8X MICROCHIP-PIC16F8X_99 Datasheet
1Mb / 124P
   18-pin Flash/EEPROM 8-Bit Microcontrollers
1998 - 1999
PIC16F8X MICROCHIP-PIC16F8X_13 Datasheet
1Mb / 128P
   18-pin Flash/EEPROM 8-Bit Microcontrollers
11/29/12 1996-2013
PIC16F84A-04-P MICROCHIP-PIC16F84A-04-P Datasheet
1Mb / 90P
   18-pin Enhanced FLASH/EEPROM 8-Bit Microcontroller
11/29/12
PIC16F84A MICROCHIP-PIC16F84A Datasheet
494Kb / 68P
   18-pin Enhanced Flash/EEPROM 8-Bit Microcontroller
1999
35007B MICROCHIP-35007B Datasheet
1Mb / 88P
   18-pin Enhanced FLASH/EEPROM 8-bit Microcontroller
2001
PIC16F84A MICROCHIP-PIC16F84A_07 Datasheet
1Mb / 88P
   18-pin Enhanced FLASH/EEPROM 8-bit Microcontroller
2001
PIC16F84A MICROCHIP-PIC16F84A_13 Datasheet
1Mb / 90P
   18-pin Enhanced FLASH/EEPROM 8-Bit Microcontroller
11/29/12 2001-2013
PIC12F1501-I MICROCHIP-PIC12F1501-I Datasheet
3Mb / 278P
   8-Pin Flash, 8-Bit Microcontrollers
08/02/11
PIC12LF1552 MICROCHIP-PIC12LF1552 Datasheet
4Mb / 260P
   8-Pin Flash, 8-Bit Microcontrollers
2013
PIC12F519 MICROCHIP-PIC12F519_08 Datasheet
1Mb / 96P
   8-Pin, 8-Bit Flash Microcontrollers
2008
More results


Html Pages

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100  ...More


Datasheet Download

Go To PDF Page


Link URL




Privacy Policy
ALLDATASHEET.COM
Does ALLDATASHEET help your business so far?  [ DONATE ] 

About Alldatasheet   |   Advertisement   |   Datasheet Upload   |   Contact us   |   Privacy Policy   |   Link Exchange   |   Manufacturer List
All Rights Reserved©Alldatasheet.com


Mirror Sites
English : Alldatasheet.com  |   English : Alldatasheet.net  |   Chinese : Alldatasheetcn.com  |   German : Alldatasheetde.com  |   Japanese : Alldatasheet.jp
Russian : Alldatasheetru.com  |   Korean : Alldatasheet.co.kr  |   Spanish : Alldatasheet.es  |   French : Alldatasheet.fr  |   Italian : Alldatasheetit.com
Portuguese : Alldatasheetpt.com  |   Polish : Alldatasheet.pl  |   Vietnamese : Alldatasheet.vn
Indian : Alldatasheet.in  |   Mexican : Alldatasheet.com.mx  |   British : Alldatasheet.co.uk  |   New Zealand : Alldatasheet.co.nz
Family Site : ic2ic.com  |   icmetro.com