xsched/note:add switch and dump instrumentation
Signed-off-by: zhanghu6 <zhanghu6@xiaomi.com>
This commit is contained in:
parent
13889ba868
commit
ebf751b16e
@ -63,14 +63,20 @@
|
|||||||
/* Note filter mode flag definitions */
|
/* Note filter mode flag definitions */
|
||||||
|
|
||||||
#define NOTE_FILTER_MODE_FLAG_ENABLE (1 << 0) /* Enable instrumentation */
|
#define NOTE_FILTER_MODE_FLAG_ENABLE (1 << 0) /* Enable instrumentation */
|
||||||
|
#ifdef CONFIG_SCHED_INSTRUMENTATION_SWITCH
|
||||||
|
#define NOTE_FILTER_MODE_FLAG_SWITCH (1 << 1) /* Enable syscall instrumentation */
|
||||||
|
#endif
|
||||||
#ifdef CONFIG_SCHED_INSTRUMENTATION_SYSCALL
|
#ifdef CONFIG_SCHED_INSTRUMENTATION_SYSCALL
|
||||||
#define NOTE_FILTER_MODE_FLAG_SYSCALL (1 << 1) /* Enable syscall instrumentation */
|
#define NOTE_FILTER_MODE_FLAG_SYSCALL (1 << 2) /* Enable syscall instrumentation */
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_SCHED_INSTRUMENTATION_IRQHANDLER
|
#ifdef CONFIG_SCHED_INSTRUMENTATION_IRQHANDLER
|
||||||
#define NOTE_FILTER_MODE_FLAG_IRQ (1 << 2) /* Enable IRQ instrumentaiton */
|
#define NOTE_FILTER_MODE_FLAG_IRQ (1 << 3) /* Enable IRQ instrumentaiton */
|
||||||
|
#endif
|
||||||
|
#ifdef CONFIG_SCHED_INSTRUMENTATION_DUMP
|
||||||
|
#define NOTE_FILTER_MODE_FLAG_DUMP (1 << 4) /* Enable dump instrumentaiton */
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_SCHED_INSTRUMENTATION_SYSCALL
|
#ifdef CONFIG_SCHED_INSTRUMENTATION_SYSCALL
|
||||||
#define NOTE_FILTER_MODE_FLAG_SYSCALL_ARGS (1 << 3) /* Enable collecting syscall arguments */
|
#define NOTE_FILTER_MODE_FLAG_SYSCALL_ARGS (1 << 5) /* Enable collecting syscall arguments */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Helper macros for syscall instrumentation filter */
|
/* Helper macros for syscall instrumentation filter */
|
||||||
|
@ -1064,13 +1064,15 @@ config SCHED_INSTRUMENTATION_FILTER
|
|||||||
config SCHED_INSTRUMENTATION_FILTER_DEFAULT_MODE
|
config SCHED_INSTRUMENTATION_FILTER_DEFAULT_MODE
|
||||||
hex "Default instrumentation filter mode"
|
hex "Default instrumentation filter mode"
|
||||||
depends on SCHED_INSTRUMENTATION_FILTER
|
depends on SCHED_INSTRUMENTATION_FILTER
|
||||||
default 0xf
|
default 0x3f
|
||||||
---help---
|
---help---
|
||||||
Default mode of the instrumentation filter logic.
|
Default mode of the instrumentation filter logic.
|
||||||
Bit 0 = Enable instrumentation
|
Bit 0 = Enable instrumentation
|
||||||
Bit 1 = Enable syscall instrumentation
|
Bit 1 = Enable switch instrumentation
|
||||||
Bit 2 = Enable IRQ instrumentation
|
Bit 2 = Enable syscall instrumentation
|
||||||
Bit 3 = Enable collecting syscall arguments
|
Bit 3 = Enable IRQ instrumentation
|
||||||
|
Bit 4 = Enable dump instrumentation
|
||||||
|
Bit 5 = Enable collecting syscall arguments
|
||||||
|
|
||||||
endif # SCHED_INSTRUMENTATION
|
endif # SCHED_INSTRUMENTATION
|
||||||
endmenu # Performance Monitoring
|
endmenu # Performance Monitoring
|
||||||
|
@ -204,6 +204,41 @@ static inline int note_isenabled(void)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: note_isenabled_switch
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Check whether the switch instrumentation is enabled.
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* None
|
||||||
|
*
|
||||||
|
* Returned Value:
|
||||||
|
* True is returned if the instrumentation is enabled.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#ifdef CONFIG_SCHED_INSTRUMENTATION_SWITCH
|
||||||
|
static inline int note_isenabled_switch(void)
|
||||||
|
{
|
||||||
|
#ifdef CONFIG_SCHED_INSTRUMENTATION_FILTER
|
||||||
|
if (!note_isenabled())
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* If the switch trace is disabled, do nothing. */
|
||||||
|
|
||||||
|
if ((g_note_filter.mode.flag & NOTE_FILTER_MODE_FLAG_SWITCH) == 0)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: note_isenabled_syscall
|
* Name: note_isenabled_syscall
|
||||||
*
|
*
|
||||||
@ -319,6 +354,41 @@ static inline int note_isenabled_irq(int irq, bool enter)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: note_isenabled_dump
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Check whether the dump instrumentation is enabled.
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* None
|
||||||
|
*
|
||||||
|
* Returned Value:
|
||||||
|
* True is returned if the instrumentation is enabled.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#ifdef CONFIG_SCHED_INSTRUMENTATION_DUMP
|
||||||
|
static inline int note_isenabled_dump(void)
|
||||||
|
{
|
||||||
|
#ifdef CONFIG_SCHED_INSTRUMENTATION_FILTER
|
||||||
|
if (!note_isenabled())
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* If the dump trace is disabled, do nothing. */
|
||||||
|
|
||||||
|
if ((g_note_filter.mode.flag & NOTE_FILTER_MODE_FLAG_DUMP) == 0)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: note_spincommon
|
* Name: note_spincommon
|
||||||
*
|
*
|
||||||
@ -452,7 +522,7 @@ void sched_note_suspend(FAR struct tcb_s *tcb)
|
|||||||
{
|
{
|
||||||
struct note_suspend_s note;
|
struct note_suspend_s note;
|
||||||
|
|
||||||
if (!note_isenabled())
|
if (!note_isenabled_switch())
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -472,7 +542,7 @@ void sched_note_resume(FAR struct tcb_s *tcb)
|
|||||||
{
|
{
|
||||||
struct note_resume_s note;
|
struct note_resume_s note;
|
||||||
|
|
||||||
if (!note_isenabled())
|
if (!note_isenabled_switch())
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -532,7 +602,7 @@ void sched_note_cpu_pause(FAR struct tcb_s *tcb, int cpu)
|
|||||||
{
|
{
|
||||||
struct note_cpu_pause_s note;
|
struct note_cpu_pause_s note;
|
||||||
|
|
||||||
if (!note_isenabled())
|
if (!note_isenabled_switch())
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -552,7 +622,7 @@ void sched_note_cpu_paused(FAR struct tcb_s *tcb)
|
|||||||
{
|
{
|
||||||
struct note_cpu_paused_s note;
|
struct note_cpu_paused_s note;
|
||||||
|
|
||||||
if (!note_isenabled())
|
if (!note_isenabled_switch())
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -571,7 +641,7 @@ void sched_note_cpu_resume(FAR struct tcb_s *tcb, int cpu)
|
|||||||
{
|
{
|
||||||
struct note_cpu_resume_s note;
|
struct note_cpu_resume_s note;
|
||||||
|
|
||||||
if (!note_isenabled())
|
if (!note_isenabled_switch())
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -591,7 +661,7 @@ void sched_note_cpu_resumed(FAR struct tcb_s *tcb)
|
|||||||
{
|
{
|
||||||
struct note_cpu_resumed_s note;
|
struct note_cpu_resumed_s note;
|
||||||
|
|
||||||
if (!note_isenabled())
|
if (!note_isenabled_switch())
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -810,7 +880,7 @@ void sched_note_string(FAR const char *buf)
|
|||||||
unsigned int length;
|
unsigned int length;
|
||||||
FAR struct tcb_s *tcb = this_task();
|
FAR struct tcb_s *tcb = this_task();
|
||||||
|
|
||||||
if (!note_isenabled())
|
if (!note_isenabled_dump())
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -843,7 +913,7 @@ void sched_note_dump(uint32_t module, uint8_t event,
|
|||||||
unsigned int length;
|
unsigned int length;
|
||||||
FAR struct tcb_s *tcb = this_task();
|
FAR struct tcb_s *tcb = this_task();
|
||||||
|
|
||||||
if (!note_isenabled())
|
if (!note_isenabled_dump())
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -879,7 +949,7 @@ void sched_note_vprintf(FAR const char *fmt, va_list va)
|
|||||||
unsigned int length;
|
unsigned int length;
|
||||||
FAR struct tcb_s *tcb = this_task();
|
FAR struct tcb_s *tcb = this_task();
|
||||||
|
|
||||||
if (!note_isenabled())
|
if (!note_isenabled_dump())
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -941,7 +1011,7 @@ void sched_note_vbprintf(uint32_t module, uint8_t event,
|
|||||||
int next = 0;
|
int next = 0;
|
||||||
FAR struct tcb_s *tcb = this_task();
|
FAR struct tcb_s *tcb = this_task();
|
||||||
|
|
||||||
if (!note_isenabled())
|
if (!note_isenabled_dump())
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user