Home     Contact     Projects     Experiments     Circuits     Theory     BLOG     PIC Tutorials     Time for Science     RSS     Terms of services     Privacy policy  
   
 Home      Projects     Experiments     Circuits     Theory     BLOG     PIC Tutorials     Time for Science   



All about PIC microcontrollers

Within these pages, you can find many useful pieces of code mostly in assembly for the Microchip PIC micro controller family. A lot of people have spend many hours trying to put the bits and bytes together. If the code is NOT written by a member of the PCB Heaven community, then a link will be added above the code with the original website that this code was found.
Because the code is copied to our servers, you should know that:

  • The responsible web master of the website that the code is taken, has been informed and he has agreed to copy the code
  • All emails from the above contact have been kept as records but due to personal privacy cannot be shown in public.
  • The author of the code is always clearly indicated above the code. In some cases the author is unknown. If you happen to be the author of the code or you know the person who wrote it, please inform us by email and it will be added ASAP.

We would personally like to send the credits to all the people that managed to write some very interesting code and publish it, and special thanx to the people that originally hosted those code snippets and gave us the permission to copy them.


View code
16 bits by 8
Author: Lou Zher
This code was originally located @ http://www.piclist.com


Follow this link to go back

#define bf_carry 3, 0
#define bf_zero 3, 2

#define same 1
#define wreg 0

#define stc bsf bf_carry
#define clc bcf bf_carry

;-[ Div ]--------------------------------------------------------------
; Call w/: Number in f_divhi:f_divlo, divisor in W.
; Returns: Quotient in f_divlo, remainder in f_divhi. W preserved.
; Carry set if error. Z if divide by zero, NZ if divide overflow.
; Notes: Works by left shifted subtraction.
; Size = 29, Speed(w/ call&ret) = 7 cycles if div by zero
; Speed = 94 minimum, 129 maximum cycles

Div;
addlw 0 ; w+=0 (to test for div by zero)
stc ; set carry in case of error
btfsc bf_zero ; if zero
return ; return (error C,Z)

call DivSkipHiShift
iDivRepeat = 8
while iDivRepeat

call DivCode

iDivRepeat--
endw

rlf f_divlo, same ; C << lo << C

; If the first subtract didn't underflow, and the carry was shifted
; into the quotient, then it will be shifted back off the end by this
; last RLF. This will automatically raise carry to indicate an error.
; The divide will be accurate to quotients of 9-bits, but past that
; the quotient and remainder will be bogus and carry will be set.

bcf bf_zero ; NZ (in case of overflow error)
return ; we are done!

DivCode
rlf f_divlo, same ; C << lo << C
rlf f_divhi, same ; C << hi << C
btfss bf_carry ; if Carry
goto DivSkipHiShift ;
subwf f_divhi, same ; hi-=w
stc ; ignore carry
return ; done
; endif
DivSkipHiShift
subwf f_divhi, same ; hi-=w
btfsc bf_carry ; if carry set
return ; done
addwf f_divhi, same ; hi+=w
clc ; clear carry
return ; done

Follow this link to go back






delicious
digg
reddit this Reddit this
Faves



 HOT in heaven!