This post is older than 2 years and might not be relevant anymore
More Info: Consider searching for newer posts

Using two GPIOTE config to a single pin

In another thread entitled:

Change in GPIO to start/stop timer and fire interrupt

The following code is used:

  NRF_GPIOTE->CONFIG[0] = (GPIOTE_CONFIG_POLARITY_HiToLo << GPIOTE_CONFIG_POLARITY_Pos)
        | (myPin << GPIOTE_CONFIG_PSEL_Pos) // using GPIO 5 as input
        | (GPIOTE_CONFIG_MODE_Event << GPIOTE_CONFIG_MODE_Pos);

    //// Configure GPIOTE channel 1 as event that occurs when pin 5 changes from digital
    //// low to hi.
    NRF_GPIOTE->CONFIG[1] = (GPIOTE_CONFIG_POLARITY_LoToHi << GPIOTE_CONFIG_POLARITY_Pos)
        | (myPin<< GPIOTE_CONFIG_PSEL_Pos) // using GPIO 5 as input
        | (GPIOTE_CONFIG_MODE_Event << GPIOTE_CONFIG_MODE_Pos);

In the nRF51 RM, there is a statement: Each GPIOTE channel is associated with one physical GPIO pin through the CONFIG.PSEL field...

Is the above code breaking this rule? Are two configurations being mapped to a single pin?

Would the correct code be to look for a change, then check the PIN state in the ISR to determine whether it was HiToLo or LoToHi?

If so, what would be the recommended debounce approach?

Parents
  • I was going to try to flip in the interrupt. If I have a clean signal no problem. But I have the same concern as you, what happens with noise or a true interrupt that is missed? And thanks for clearing my issues with pin vs signal.

    I have another question on interrupts. I am used to interrupts that when you end up in the ISR, you need to clear the interrupt flag - or else a subsequent interrupt is not going to happen. Often this is done by just reading the interrupt status register. But with the M0 you actually have to write to the clear interrupt register. Am I reading the RM correctly?

Reply
  • I was going to try to flip in the interrupt. If I have a clean signal no problem. But I have the same concern as you, what happens with noise or a true interrupt that is missed? And thanks for clearing my issues with pin vs signal.

    I have another question on interrupts. I am used to interrupts that when you end up in the ISR, you need to clear the interrupt flag - or else a subsequent interrupt is not going to happen. Often this is done by just reading the interrupt status register. But with the M0 you actually have to write to the clear interrupt register. Am I reading the RM correctly?

Children
No Data
Related