Become a leader in the IoT community!

New DevHeads get a 320-point leaderboard boost when joining the DevHeads IoT Integration Community. In addition to learning and advising, active community leaders are rewarded with community recognition and free tech stuff. Start your Legendary Collaboration now!

Step 1 of 5

CREATE YOUR PROFILE *Required

OR
Step 2 of 5

WHAT BRINGS YOU TO DEVHEADS? *Choose 1 or more

Collaboration & Work šŸ¤
Learn & Grow šŸ“š
Contribute Experience & Expertise šŸ”§
Step 3 of 5

WHAT'S YOUR INTEREST OR EXPERTISE? *Choose 1 or more

Hardware & Design šŸ’”
Embedded Software šŸ’»
Edge Networking āš”
Step 4 of 5

Personalize your profile

Step 5 of 5

Read & agree to our COMMUNITY RULES

  1. We want this server to be a welcoming space! Treat everyone with respect. Absolutely no harassment, witch hunting, sexism, racism, or hate speech will be tolerated.
  2. If you see something against the rules or something that makes you feel unsafe, let staff know by messaging @admin in the "support-tickets" tab in the Live DevChat menu.
  3. No age-restricted, obscene or NSFW content. This includes text, images, or links featuring nudity, sex, hard violence, or other graphically disturbing content.
  4. No spam. This includes DMing fellow members.
  5. You must be over the age of 18 years old to participate in our community.
  6. Our community uses Answer Overflow to index content on the web. By posting in this channel your messages will be indexed on the worldwide web to help others find answers.
  7. You agree to our Terms of Service (https://www.devheads.io/terms-of-service/) and Privacy Policy (https://www.devheads.io/privacy-policy)
By clicking "Finish", you have read and agreed to the our Terms of Service and Privacy Policy.

Issue with ISR Behavior in Zero-Cross Detection on Mega 2560 Board

Hii guys Iā€™m creating lighting variations on PORTA with a MEGA 2560 board.
I am using a zero-cross detection that triggers an interrupt, which calls the “void passage_a_0” function.
A command (continuous action on a button) modifies a lighting level setting from 1 to 25. This setting adjusts the phase delays corresponding to the lighting level.
I have an issue with the ISR interrupt. Below is the simplified code of the two related interrupts:

// Simplified zero-cross and ISR for continuous variation on bit 7 of PORTA
void passage_a_0 () {
  TCNT1 = 0;                           // Initialize TNCT1
  if (variation_demandee == 128) {      // We are on bit 7
    PORTA &= ~variation_demandee;       // Turn off bit 7
    OCR1A = retard_phase[niv_ecl[7]];   // Set the value of OCRIA
    bitSet(TIMSK1, OCIE1A);             // Set OCIE1A to 1 to allow the compare interrupt with OCIE1A
  }
  n0++;                                 // Count the number of passes in this interrupt
}

ISR(TIMER1_COMPA_vect) {
  PORTA |= 128;                         // Immediately act on the port with the concerned bit
  bitClear(TIMSK1, OCIE1A);             // Clear the OCIE1A bit to disable the compare interrupt with OCR1A
  n++;                                  // Count the number of passes in this interrupt
}

Problem:
With the `bitClear(TIMSK1, OCIE1A);` instruction in the ISR, which is necessary, the ISR is executed immediately as if OCR1A were set to 0.
However, if this instruction is removed, the variation works correctly, taking into account the OCR1A values for the phase delay. But depending on the value of OCR1A, the ISR is called several times before the next zero-cross.
Why is the ISR triggered immediately in the presence of ‘bitClear’?
Is it a code error or a defective board?

CONTRIBUTE TO THIS THREAD

Leaderboard

RANKED BY XP

All time
  • 1.
    Avatar
    @Nayel115
    1620 XP
  • 2.
    Avatar
    @UcGee
    650 XP
  • 3.
    Avatar
    @melta101
    600 XP
  • 4.
    Avatar
    @lifegochi
    250 XP
  • 5.
    Avatar
    @Youuce
    180 XP
  • 6.
    Avatar
    @hemalchevli
    170 XP