Timer and GPIOTE interrupts priorities

Hello!

I use NRF Connect SDK 1.8.0, but peripherials are configured using nrfx library.

My task is to implement serial interface where I have PIN_TX and PIN_RX. I transmit data over PIN_TX, when I'm transmitting data on PIN_TX I've got feedback on PIN_RX. On oscilloscop I can see that delay beetwen set PIN_TX and got feedback on PIN_RX is about 1us delay(electronic circuit delay).

PIN_TX is driven in Timer Output Compare mode but PIN_RX work in Timer Input Copture mode. Timer Output Compare interrupt is enabled and GPIOTE interrupt is enabled as well. They are configured with the same interrupt priority, let's say IRQ_PRIO_LOWEST-2.

Haw does situation looks 99.99% cases

1. Output Compare Event occur and PIN_TX has been toggle

2. Timer Output Compare interrupt occured

3. GPIOTE interrupt occured and I can read timer compare value that has been captured


But, sometimes situation looks a little bit different...

1. Output Compare Event occured and PIN_TX has been toggle

2. GPIOTE interrupt occured and I can read timer compare value that has been captured
3. Timer Output Compare interrupt occured

This situation never occur when I configure Timer whit higher priority than GPIOTE but then I have other problems...

The questions are:

* Interrupt can interrupt other interrupt with the same priority? (to this day I have been convinced that it is not)

* Is that mybe known problem and there is some solution to fix it? I have not so big experience with nrf52. I have never had similar situation when I was working with stm32...

Parents
  • * Interrupt can interrupt other interrupt with the same priority? (to this day I have been convinced that it is not)

    On ARM Cortex M4 same priority interrupts cannot pre-empt an existing interrupt with same priority. Are you toggling some gpios that are connected to compare event to measure the distance or do you rely on interrupt service routines for few measurements?

    This is purely ARM related implementation and I have not heard that there is a bug in priority handling in such contexts. 

    * Is that mybe known problem and there is some solution to fix it? I have not so big experience with nrf52. I have never had similar situation when I was working with stm32...

    I am quite confident that there is no known problem in context prioritizing within ARM controller. 
    I need to understand more on how you concluded that it could be priority issue. If you have ISR involved in any of these measurements, then I can say that the timings of ISR running are not the same as the timings of interrupt happening. 

Reply
  • * Interrupt can interrupt other interrupt with the same priority? (to this day I have been convinced that it is not)

    On ARM Cortex M4 same priority interrupts cannot pre-empt an existing interrupt with same priority. Are you toggling some gpios that are connected to compare event to measure the distance or do you rely on interrupt service routines for few measurements?

    This is purely ARM related implementation and I have not heard that there is a bug in priority handling in such contexts. 

    * Is that mybe known problem and there is some solution to fix it? I have not so big experience with nrf52. I have never had similar situation when I was working with stm32...

    I am quite confident that there is no known problem in context prioritizing within ARM controller. 
    I need to understand more on how you concluded that it could be priority issue. If you have ISR involved in any of these measurements, then I can say that the timings of ISR running are not the same as the timings of interrupt happening. 

Children
  • On ARM Cortex M4 same priority interrupts cannot pre-empt an existing interrupt with same priority. Are you toggling some gpios that are connected to compare event to measure the distance or do you rely on interrupt service routines for few measurements?

    I'm doing this to measure the distance between edges and in interrupt service runtime I'm verifying if this distance is proper...

    I am quite confident that there is no known problem in context prioritizing within ARM controller. 
    I need to understand more on how you concluded that it could be priority issue. If you have ISR involved in any of these measurements, then I can say that the timings of ISR running are not the same as the timings of interrupt happening.

    I think that this issue is not connected with strictly ARM related implementation couse to triger on compare pin toggle we need to engage gpiote task and ppi peripherials... And this latency can be generated here in my opinion...

    I can resolve this issue by using some software trick and by setting timer iqr priority to higher than gpio.

    There is one another thing that can has same influence here... I noticed that when I excluded ble stack from project some another latency is provided to measuring distance between edges... Solution that I found is to set NRF_POWER->TASKS_CONSTLAT = 1. Then measuring is much more accurate. What is the way to configure this in right way, is there some zephyr api to this or some nrfx library api to configure this... What are all consequences of setting this to 1...?

     

    Next issue is connected with erasing/writing flash memory. I'm developing projects based on nrf52832 and nrf52833, erasing page on first of them takes 2ms but on second of them above 80ms! I found information that this operation can take from 2 - 90 ms on nrf52 mcu's. It means that it depends on cpu production series, every cpu can have this time in range(2, 90), or maybe there is some way configure this time?

  • trafficode said:
    There is one another thing that can has same influence here... I noticed that when I excluded ble stack from project some another latency is provided to measuring distance between edges... Solution that I found is to set NRF_POWER->TASKS_CONSTLAT = 1. Then measuring is much more accurate. What is the way to configure this in right way, is there some zephyr api to this or some nrfx library api to configure this... What are all consequences of setting this to 1...?

    There is the nRFX library where you can use nrf_power_task_trigger(NRF_POWER, NRF_POWER_TASK_CONSTLAT). There is no other API tapping into this functionality of constlat register.

    trafficode said:
    Next issue is connected with erasing/writing flash memory. I'm developing projects based on nrf52832 and nrf52833, erasing page on first of them takes 2ms but on second of them above 80ms! I found information that this operation can take from 2 - 90 ms on nrf52 mcu's. It means that it depends on cpu production series, every cpu can have this time in range(2, 90), or maybe there is some way configure this time?

    Is there any RADIO activity while requesting the flash erase? it should not be that much difference in time Which HFLCK are you using? is it XTAL or internal RC HFCLK?

  • There is a simple test you can do to isolate the external effects of the TX_PIN and RX_PIN  connection (which includes pin capacitance) by using internal loopback. Change the RX_PIN to instead use TX_PIN (this works, I use it on serial loopback testing) and enable the input thus:

        nrf_gpio_cfg(TX_PIN, NRF_GPIO_PIN_DIR_OUTPUT, NRF_GPIO_PIN_INPUT_CONNECT, NRF_GPIO_PIN_NOPULL, NRF_GPIO_PIN_H0H1, NRF_GPIO_PIN_NOSENSE);
    

  • I should have asked you this in the very beginning, but before I test this I need to know if this is on custom hardware or on our nRF52833 DK? If you are using custom hardware and If you have not already tested this on the DK, I would recommend you to test it first on DK to see if it is the same behavior.

  • I can't do it in that way. Those "external effects" - You mean feedback delay... are desirable. It depends on kind of used hardware layer to implement this type of serial interface. In this way there is 1us delay but there is also another usage/hardware where is 80us and this problem not occur.

    Like I said. I have implemented "temporary" solution and problem isn't occure right now. I didn't tests this with nrf_power_task_trigger(NRF_POWER, NRF_POWER_TASK_CONSTLAT) yet, maybe problem won't occure.

Related