;from Paul W. Webster MOVF file,W ANDLW fmask ; fmask for bit 0 is defined as 0x01 IORWF shadA,W ; add in desired outputs from shadow MOVWF PORTA
Only changes port A on the last cycle. Note that you must call this routine (subroutine/ macro) *whenever* you write to an output bit, which you always do using a BSF or BCF on shadA, never PORTA. You might also consider appending a
MOVWF shadAto keep shadA synchronized with the last byte written to PORTA.
;from Paul W. Webster ; WARNING: may trigger the "read-modify-write glitch" MOVF file,W XORWF PORTA,W ; derive "difference" value. ANDLW fmask ; fmask for bit 0 is defined as 0x01 XORWF PORTA,F ; Flip bit if not same.
We never use the following instructions on an output register like PORTA:
BSF PORTA,bit // don't do this! BCF PORTA,bit // don't do this either! IORWF PORTA,F // or this! XORWF PORTA,F // this either!because we want to avoid the "Read-Modify-Write problem" . Instead, we do the BSF or BCF on a byte of RAM (the "shadow register"), then copy that byte to the output register.
file: /Techref/microchip/math/bit/cbrpwoj.htm, 1KB, , updated: 2005/11/8 23:39, local time: 2024/10/3 12:29,
3.237.15.145:LOG IN ©2024 PLEASE DON'T RIP! THIS SITE CLOSES OCT 28, 2024 SO LONG AND THANKS FOR ALL THE FISH!
|
©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.org/techref/microchip/math/bit/cbrpwoj.htm"> PIC Microcontoller Bit Math Method Transfer one bit from a file register to one pin of PORT w/o jitter</A> |
Did you find what you needed? |
Welcome to massmind.org! |
Welcome to massmind.org! |
.