If there is a certain length of code coming before the DT (define table) directive, then characters/entries in the DT past a certain point will fail to return a value. Instead, upon reaching that character, the program will restart from the beginning.

 

Remember, or realize, that DT is actually a short form for a long list of retlw instructions. That means that having a DT holding a long string counts as many instructions.

 

This does NOT appear to be an issue of crossing the 2000 line limit, because I counted my lines and each character in the DTs, and I am still a good ways away from the next program memory page.

 

I spent hours working this out. Our book was not helpful at all. I had many theories and many false leads. Unless we hear official word from someone more experienced, my reccomendation would be to keep your DTs at or near the top of your code.

 

Update:

I forgot, or rather vaguely remembered but was not until recently able to find mention in the book, that tables have limited space per page of program memory. My knowledge worked against me, because knowing that DT is just a series of RETLW instructions made me believe that they were simply instructions. It turns out RETLW is also placed in this table memory.

 

This partially explains things. The strange thing is, the location of DT should not matter if it is only a case of using up memory. There seems to be something else at play here. I remember reading another blog post or question mentioning something similar to this, but I am a little unclear on the details.

Views: 90

Comment

You need to be a member of Personal Mechatronics Lab to add comments!

Join Personal Mechatronics Lab

Comment by Yifan Wang on January 27, 2011 at 9:22am
This is very helpful
Comment by Jack Sparrow on January 26, 2011 at 8:59pm
Table lookups on the PIC16 work by replacing PCL with a base+offset address. Since PCL is only 8 bits, PCLATH provides the remainder of the new PC register, so the easiest solution is to ensure the entirety of any given table falls within the same 256-byte region.
Comment by Emma Redwood on January 26, 2011 at 9:50am
Putting the tables at the beginning solved my problem. :) Thanks!
Comment by Emma Redwood on January 26, 2011 at 9:41am
Interesting. My code improved slightly when I put my tables at the end of the code. But not perfectly. It only increased the number of dt instructions I could have. I'll try putting them at the beginning.

© 2024   Created by PML.   Powered by

Badges  |  Report an Issue  |  Terms of Service