Quality RTOS & Embedded Software

 Real time embedded FreeRTOS RSS feed 
Quick Start Supported MCUs PDF Books Trace Tools Ecosystem


Loading

xQueueTakeMutexRecursive not supported from an ISR

Posted by jon-gordon on October 13, 2016

Using Tracealyzer for FreeRTOS, I'm trying to call a vTracePrintF from inside an ISR. The code works fine for non-ISR and I see my event printed but inside the ISR, I end up with an assert failure because in xQueueTakeMutexRecursive, there is a call to xQueueGenericReceive without checking whether the "fromISR" alternative should be called instead. Is this an oversight or am I missing something?

Cheers, Jon


xQueueTakeMutexRecursive not supported from an ISR

Posted by edwards3 on October 13, 2016

The trace recorder is source code so you can edit the code to check if you are in an interrupt, but also check if vTracePrintF is ok to call from an interrupt. You would not normally want to call the library printf() from there because its slow, stack heavy and not reentrant.


xQueueTakeMutexRecursive not supported from an ISR

Posted by richard_damon on October 13, 2016

Generally it doesn't make sense to use a mutex in an ISR, as the ISR has no way to 'wait' for the shared resource to become available.

As MEdwards said, 'printing' something in a ISR is almost certainly a bad idea,


xQueueTakeMutexRecursive not supported from an ISR

Posted by jon-gordon on October 17, 2016

I had figured it was using its own derived version of a printf routine but alas, no, it uses my compiler's version which attempts to be thread safe by using a mutex - hence the problem.

I'll stick to SEGGER's RTT for printing in an ISR then. Would just have been nice to have the interrupt behaviour observed in Tracealyzer but I must be missing something else there.


[ Back to the top ]    [ About FreeRTOS ]    [ Privacy ]    [ Sitemap ]    [ ]


Copyright (C) Amazon Web Services, Inc. or its affiliates. All rights reserved.

Latest News

NXP tweet showing LPC5500 (ARMv8-M Cortex-M33) running FreeRTOS.

Meet Richard Barry and learn about running FreeRTOS on RISC-V at FOSDEM 2019

Version 10.1.1 of the FreeRTOS kernel is available for immediate download. MIT licensed.

View a recording of the "OTA Update Security and Reliability" webinar, presented by TI and AWS.


Careers

FreeRTOS and other embedded software careers at AWS.



FreeRTOS Partners

ARM Connected RTOS partner for all ARM microcontroller cores

Espressif ESP32

IAR Partner

Microchip Premier RTOS Partner

RTOS partner of NXP for all NXP ARM microcontrollers

Renesas

STMicro RTOS partner supporting ARM7, ARM Cortex-M3, ARM Cortex-M4 and ARM Cortex-M0

Texas Instruments MCU Developer Network RTOS partner for ARM and MSP430 microcontrollers

OpenRTOS and SafeRTOS

Xilinx Microblaze and Zynq partner