For long delays (> 10 cycles) the code is based on nested loops using 'decfsz' and 'goto' instructions. Small delays are built using 'goto $ + 1' (2 cycles delay) and 'nop' (one cycle delay).
To calculate nested loop counter values the code generator uses an optimum search algorithm. The algorithm finds such values for counters that achieve good approximation to the specified delay.
Even if there is an error in the first block of nested loops, the rest of the code fixes that. As a result, one cycle resolution is achieved.
Idea: James Newton
Implementation: Nikolai Golovchenko
This application is mirrored at:
I'd like to know how exactly I have to calculate the loop. I know my time I want to have and put it in the generator, but when I want to calculate with my variables I don't know how to put those together. I know that for a single loop like this one movlw D'3' movwf d1 decfsz d1,f goto $-1 I have to calculate 3*d1-1. But if I have a nested loop like this one: movlw D'3' movwf d1 movlw D'4' movwf d2 decfsz d1,f goto $-1 decfsz d2,f goto $-3 I don't know how to calculate it! is it (3*d1-1)*(3*d2-1) ? I'd like to get a formula for that!+
Daniel Chia Jin Hao Says:
For PIC18, this delay routine will need a little modification to work properly.. the goto $+1 within the delay loops that sometimes appears needs to be changed to goto $+6, since each program word is 2 bytes, and goto is a 4 byte instruction. Also, at the end sometimes goto $+1 is used as a 2 cycle delay, need to use goto $+4 to skip over the whole goto.+
I hope this is correct, AFAIK it is.
|file: /Techref/piclist/codegen/delay.htm, 7KB, , updated: 2020/7/3 10:19, local time: 2022/1/28 04:23,
|©2022 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://www.piclist.com/techref/piclist/codegen/delay.htm"> Microchip PIC, ASM Delay Code, Code Generator </A>
|Did you find what you needed?|
PICList 2022 contributors:
o List host: MIT, Site host massmind.org, Top posters @20220128
* Page Editors: James Newton, David Cary, and YOU!
* Roman Black of Black Robotics donates from sales of Linistep stepper controller kits.
* Ashley Roll of Digital Nemesis donates from sales of RCL-1 RS232 to TTL converters.
* Monthly Subscribers: Gregg Rew. on-going support is MOST appreciated!
* Contributors: Richard Seriani, Sr.
Welcome to www.piclist.com!