dt int timer1 ignores offset value


Closed Thread
Results 1 to 15 of 15

Hybrid View

  1. #1
    Join Date
    Dec 2009
    Location
    Kalamazoo
    Posts
    42

    Default dt int timer1 ignores offset value

    hi everyone. im trying to produce a sine wave with this section of code, on a 18f2431
    Code:
    INTCON = %11000000
    T1CON = %10000001
     TIMER = 64233
         TIMER.BYTE0 = TMR1L ;= $E9
         TIMER.BYTE1 = TMR1H ;= $FA
      INCLUDE "DT_INTS-18.bas"
    ;----[High Priority Interrupts]-----------------------------------------------
    ASM
    INT_LIST  macro    ; IntSource,   Label,  Type,  ResetFlag? 
            INT_Handler   TMR1_INT,   _SINE,   asm,  yes
            
        endm
        INT_CREATE
         
        INT_ENABLE TMR1_INT
                                            
    ENDASM
    
    
    SINE:
    PORTA.1 = 1
    X = X + 1
    IF X > 63 THEN X = 0
    LOOKUP X,[127, 139, 152, 164, 176, 187, 198, 208, 217, 225, 233, 239, 244, 249, 252,_
              253, 254, 253, 252, 249, 244, 239, 233, 225, 217, 208, 198, 187, 176, 164,_
              152, 139, 127, 115, 102, 90, 78, 67, 56, 46, 37, 29, 21, 15, 10, 5, 2, 1,_
              0, 1, 2, 5, 10, 15, 21, 29, 37, 46, 56, 67, 78, 90, 102, 115],SINEWAVE
    
         
    PORTA.1 = 0
         
    @  INT_RETURN
    timer1 works to the preload value, but completely ignores my offset values.
    yes, i checked all over the forum, and the solutions suggested was to use timer0. i really need to use this timer, because of its high resolution, and the other timers will be tied up in later programming stages. ive tried all this:
    Code:
    TIMER = 64233
         TIMER.BYTE0 = TMR1L
         TIMER.BYTE1 = TMR1H
    and
    Code:
    TMR1L = $E9
    TMR1H = $FA
    what i'm doing wrong?
    NAG CON WIFE!
    WIFE VAR MOOD

  2. #2
    Join Date
    Jul 2003
    Location
    Colorado Springs
    Posts
    4,959


    Did you find this post helpful? Yes | No

    Default

    Timer1 should be re-loaded each time in the handler.
    It should be the first thing done in the handler, and it should be added to the timer value instead of just loaded.
    Adding the value helps to compensate for interrupt latencies, keeping the frequency nice and stable.

    To make it easier to add, RD16 (T1CON.7) should be turned off.

    Code:
    Timer1  VAR WORD EXT
    @Timer1 = TMR1L
    
    T1CON = %00000001
    TIMER = 64233
    
    ;... Main program here
    
    SINE:                      ; interrupt handler
        T1CON.0 = 0            ; stop Timer
        Timer1 = Timer1 + TIMER
        T1CON.0 = 1            ; restart Timer
    
    ;... rest of handler
    @ INT_RETURN
    DT

  3. #3
    Join Date
    Oct 2005
    Location
    Sweden
    Posts
    3,621


    Did you find this post helpful? Yes | No

    Default

    Hi,
    Not 100% sure what you mean but I think you're forgetting to reload the timer inside the ISR.

    If you preset the timer to 12345 at the beginning of the program you'll interrupt after 65536-12345 cycles - the first time only. Then the timer will be free running and you'll get an interrupt every 65536th cycle (1:1 prescaler).

    Or is that not at all what you're asking about?

    /Henrik.

    EDIT: Oh, well the man himself beat me to it - again.... ;-)

  4. #4
    Join Date
    Dec 2009
    Location
    Kalamazoo
    Posts
    42


    Did you find this post helpful? Yes | No

    Default thanks for the reply.

    thanks for coming to my aid, guys. reload the value within the isr. now i know. the timer is working, with the offset with a new problem; im aiming for 3840 hz, and thats = 64233 offset value.
    instead, im getting 3030 hz. i used a different pic timer calculator because picmulticalc will not run in windows 7.
    this is not really a big problem, as i can adjust the offset value to get the exact frequency that im aiming for.

    Timer1 VAR WORD EXT ; what does the EXT stand for?

    thanks
    NAG CON WIFE!
    WIFE VAR MOOD

  5. #5
    Join Date
    Jul 2003
    Location
    Colorado Springs
    Posts
    4,959


    Did you find this post helpful? Yes | No

    Default

    Quote Originally Posted by DDDvvv View Post
    im aiming for 3840 hz, and thats = 64233 offset value.
    instead, im getting 3030 hz.
    What OSC are you running at?

    64233 would be close for 20Mhz.
    With 16Mhz OSC it would give 3.06 Khz.

    picmulticalc will not run in windows 7
    Turn on XP compatability mode for PicMultiCalc.

    Timer1 VAR WORD EXT ; what does the EXT stand for?
    The EXT (external) modifier.
    http://www.picbasic.co.uk/forum/showthread.php?t=3891

    Scroll down to ... Using EXT with Variables.
    DT

  6. #6
    Join Date
    Dec 2009
    Location
    Kalamazoo
    Posts
    42


    Did you find this post helpful? Yes | No

    Smile

    thanks again for the reply. yes, i have the osc set for 16 mhz. there's my problem!

    about picmulticalc, it starts ok in windows 7 but when you click on any of the buttons (timer calc, timer helper, usart calc) i get a runtime error 713; missing msstdfmt.dll that needs to be installed. rather than troll the web searching for a "trojaned" file, i chose a different calc.

    thanks
    NAG CON WIFE!
    WIFE VAR MOOD

  7. #7
    Join Date
    Oct 2005
    Location
    Sweden
    Posts
    3,621


    Did you find this post helpful? Yes | No

    Default

    Hi,
    FYI, I run PICMultiCalc on Win7-64bit without any problems, no compatibility mode set or anything.

    /Henrik.

Members who have read this thread : 0

You do not have permission to view the list of names.

Posting Permissions

  • You may not post new threads
  • You may not post replies
  • You may not post attachments
  • You may not edit your posts