forked from Imagelibrary/rtems
Directly use the CPU port API in boot_card() to allow tracing of the higher level interrupt disable/enable routines, e.g. _ISR_Local_disable() and _ISR_Local_enable(). Currently, there is no configuration option to enable this. Below is a patch. It may be used to investigate some nasty low level bugs in the system. Update #3665. diff --git a/cpukit/include/rtems/score/isrlevel.h b/cpukit/include/rtems/score/isrlevel.h index c42451d010..46d361ddc2 100644 --- a/cpukit/include/rtems/score/isrlevel.h +++ b/cpukit/include/rtems/score/isrlevel.h @@ -40,6 +40,10 @@ extern "C" { */ typedef uint32_t ISR_Level; +uint32_t rtems_record_interrupt_disable( void ); + +void rtems_record_interrupt_enable( uint32_t level ); + /** * @brief Disables interrupts on this processor. * @@ -56,8 +60,7 @@ typedef uint32_t ISR_Level; */ #define _ISR_Local_disable( _level ) \ do { \ - _CPU_ISR_Disable( _level ); \ - RTEMS_COMPILER_MEMORY_BARRIER(); \ + _level = rtems_record_interrupt_disable(); \ } while (0) /** @@ -72,10 +75,7 @@ typedef uint32_t ISR_Level; * _ISR_Local_disable(). */ #define _ISR_Local_enable( _level ) \ - do { \ - RTEMS_COMPILER_MEMORY_BARRIER(); \ - _CPU_ISR_Enable( _level ); \ - } while (0) + rtems_record_interrupt_enable( _level ) /** * @brief Temporarily enables interrupts on this processor. @@ -98,9 +98,8 @@ typedef uint32_t ISR_Level; */ #define _ISR_Local_flash( _level ) \ do { \ - RTEMS_COMPILER_MEMORY_BARRIER(); \ - _CPU_ISR_Flash( _level ); \ - RTEMS_COMPILER_MEMORY_BARRIER(); \ + rtems_record_interrupt_enable( _level ); \ + _level = rtems_record_interrupt_disable(); \ } while (0) /
69 lines
1.7 KiB
C
69 lines
1.7 KiB
C
/**
|
|
* @file
|
|
*
|
|
* @ingroup RTEMSBSPsSharedStartup
|
|
*/
|
|
|
|
/*
|
|
* COPYRIGHT (c) 1989-2014.
|
|
* On-Line Applications Research Corporation (OAR).
|
|
*
|
|
* The license and distribution terms for this file may be
|
|
* found in the file LICENSE in this distribution or at
|
|
* http://www.rtems.org/license/LICENSE.
|
|
*/
|
|
|
|
#include <bsp/bootcard.h>
|
|
|
|
#include <rtems.h>
|
|
#include <rtems/sysinit.h>
|
|
|
|
/*
|
|
* At most a single pointer to the cmdline for those target
|
|
* short on memory and not supporting a command line.
|
|
*/
|
|
const char *bsp_boot_cmdline;
|
|
|
|
RTEMS_SYSINIT_ITEM(
|
|
bsp_work_area_initialize,
|
|
RTEMS_SYSINIT_BSP_WORK_AREAS,
|
|
RTEMS_SYSINIT_ORDER_MIDDLE
|
|
);
|
|
|
|
RTEMS_SYSINIT_ITEM(
|
|
bsp_start,
|
|
RTEMS_SYSINIT_BSP_START,
|
|
RTEMS_SYSINIT_ORDER_MIDDLE
|
|
);
|
|
|
|
/*
|
|
* This is the initialization framework routine that weaves together
|
|
* calls to RTEMS and the BSP in the proper sequence to initialize
|
|
* the system while maximizing shared code and keeping BSP code in C
|
|
* as much as possible.
|
|
*/
|
|
void boot_card(
|
|
const char *cmdline
|
|
)
|
|
{
|
|
ISR_Level bsp_isr_level;
|
|
|
|
/*
|
|
* Make sure interrupts are disabled. Directly use the CPU port API to allow
|
|
* tracing of the higher level interrupt disable/enable routines, e.g.
|
|
* _ISR_Local_disable() and _ISR_Local_enable().
|
|
*/
|
|
_CPU_ISR_Disable( bsp_isr_level );
|
|
(void) bsp_isr_level;
|
|
|
|
bsp_boot_cmdline = cmdline;
|
|
|
|
rtems_initialize_executive();
|
|
|
|
/***************************************************************
|
|
***************************************************************
|
|
* APPLICATION RUNS NOW!!! We will not return to here!!! *
|
|
***************************************************************
|
|
***************************************************************/
|
|
}
|