529 lines
13 KiB
Plaintext
Executable File
529 lines
13 KiB
Plaintext
Executable File
; --------------------------------------------------------------------------------
|
|
; @Title: FreeRTOS specific menu
|
|
; @Description: -
|
|
; @Keywords: freertos menu awareness
|
|
; @Author: DIE
|
|
; @Copyright: (c) 1989-2020 Lauterbach GmbH, licensed for use with TRACE32(R) only
|
|
; --------------------------------------------------------------------------------
|
|
; $Id: freertos.men 5228 2020-04-24 09:06:18Z amerkle $
|
|
|
|
add
|
|
menu
|
|
(
|
|
|
|
popup "&FreeRTOS"
|
|
|
|
(
|
|
default
|
|
menuitem "Display &Tasks" "TASK.TaskList"
|
|
menuitem "Display &Queues"
|
|
(
|
|
if task.avail(qreg)!=0
|
|
TASK.Queue
|
|
else
|
|
(
|
|
dialog
|
|
(
|
|
header "Display Queue"
|
|
pos 0x1 0x1 30.
|
|
addr: defedit "" ""
|
|
pos 32. 1. 7.
|
|
button "Browse..."
|
|
(
|
|
local &wildcard
|
|
&wildcard=dialog.string(addr)
|
|
if "&wildcard"==""
|
|
&wildcard="*Queue"
|
|
if !string.find("&wildcard","*?")
|
|
&wildcard="*&wildcard*"
|
|
symbol.browse.v &wildcard * /c "dialog.set addr ""*""" /d
|
|
)
|
|
pos 40. 1. 7.
|
|
defbutton "Ok"
|
|
(
|
|
local &addr
|
|
&addr=dialog.string(addr)
|
|
if cpufamily()=="M68HC12"
|
|
TASK.Queue data.word(&addr)
|
|
else
|
|
TASK.Queue data.long(&addr)
|
|
dialog.end
|
|
)
|
|
pos 0. 0. 49. 3.
|
|
box "Queue"
|
|
)
|
|
)
|
|
)
|
|
menuitem "Display &Semaphores"
|
|
(
|
|
if task.avail(qreg)!=0
|
|
TASK.Semaphore
|
|
else
|
|
(
|
|
dialog
|
|
(
|
|
header "Display Semaphore"
|
|
pos 0x1 0x1 30.
|
|
addr: defedit "" ""
|
|
pos 32. 1. 7.
|
|
button "Browse..."
|
|
(
|
|
local &wildcard
|
|
&wildcard=dialog.string(addr)
|
|
if "&wildcard"==""
|
|
&wildcard="*Semaphore"
|
|
if !string.find("&wildcard","*?")
|
|
&wildcard="*&wildcard*"
|
|
symbol.browse.v &wildcard * /c "dialog.set addr ""*""" /d
|
|
)
|
|
pos 40. 1. 7.
|
|
defbutton "Ok"
|
|
(
|
|
local &addr
|
|
&addr=dialog.string(addr)
|
|
if cpufamily()=="M68HC12"
|
|
TASK.Semaphore data.word(&addr)
|
|
else
|
|
TASK.Semaphore data.long(&addr)
|
|
dialog.end
|
|
)
|
|
pos 0. 0. 49. 3.
|
|
box "Semaphore"
|
|
)
|
|
)
|
|
)
|
|
menuitem "Display &Timers" "TASK.TImer"
|
|
menuitem "Display &Event Group..."
|
|
(
|
|
dialog
|
|
(
|
|
header "Display Event Group"
|
|
pos 0x1 0x1 30.
|
|
var: defedit "" ""
|
|
pos 32. 1. 7.
|
|
button "Browse..."
|
|
(
|
|
local &wildcard
|
|
&wildcard=dialog.string(var)
|
|
if "&wildcard"==""
|
|
&wildcard="*EventGroup"
|
|
if !string.find("&wildcard","*?")
|
|
&wildcard="*&wildcard*"
|
|
symbol.browse.v &wildcard * /c "dialog.set var ""*""" /d
|
|
)
|
|
pos 40. 1. 7.
|
|
defbutton "Ok"
|
|
(
|
|
local &var
|
|
&var=dialog.string(var)
|
|
ON ERROR CONTinue
|
|
ERROR.RESet
|
|
SIlENT.TASK.EvtGrp Var.VALUE(&var)
|
|
IF ERROR.OCCURRED()
|
|
SILENT.TASK.EvtGrp Var.ADDRESS(&var)
|
|
ON ERROR inherit
|
|
PRINT ""
|
|
DIALOG.END
|
|
)
|
|
pos 0. 0. 49. 3.
|
|
box "Event Group"
|
|
)
|
|
)
|
|
menuitem "Display &Stream Buffer..."
|
|
(
|
|
dialog
|
|
(
|
|
header "Display Stream Buffer"
|
|
pos 0x1 0x1 30.
|
|
var: defedit "" ""
|
|
pos 32. 1. 7.
|
|
button "Browse..."
|
|
(
|
|
local &wildcard
|
|
&wildcard=dialog.string(var)
|
|
if "&wildcard"==""
|
|
&wildcard="*StreamBuffer"
|
|
if !string.find("&wildcard","*?")
|
|
&wildcard="*&wildcard*"
|
|
symbol.browse.v &wildcard * /c "dialog.set var ""*""" /d
|
|
)
|
|
pos 40. 1. 7.
|
|
defbutton "Ok"
|
|
(
|
|
local &var
|
|
&var=dialog.string(var)
|
|
TASK.StrBuf var.value(&var)
|
|
dialog.end
|
|
)
|
|
pos 0. 0. 49. 3.
|
|
box "Stream Buffer"
|
|
)
|
|
)
|
|
menuitem "Display &Message Buffer..."
|
|
(
|
|
dialog
|
|
(
|
|
header "Display Message Buffer"
|
|
pos 0x1 0x1 30.
|
|
var: defedit "" ""
|
|
pos 32. 1. 7.
|
|
button "Browse..."
|
|
(
|
|
local &wildcard
|
|
&wildcard=dialog.string(var)
|
|
if "&wildcard"==""
|
|
&wildcard="*MessageBuffer"
|
|
if !string.find("&wildcard","*?")
|
|
&wildcard="*&wildcard*"
|
|
symbol.browse.v &wildcard * /c "dialog.set var ""*""" /d
|
|
)
|
|
pos 40. 1. 7.
|
|
defbutton "Ok"
|
|
(
|
|
local &var
|
|
&var=dialog.string(var)
|
|
TASK.MsgBuf var.value(&var)
|
|
dialog.end
|
|
)
|
|
pos 0. 0. 49. 3.
|
|
box "Message Buffer"
|
|
)
|
|
)
|
|
separator
|
|
popup "&Stack Coverage"
|
|
(
|
|
menuitem "&List Stacks"
|
|
(
|
|
|
|
if !ice()&&!fire()
|
|
TASK.STacK.PATtern 0x5a
|
|
|
|
TASK.STacK.view
|
|
)
|
|
menuitem "Add Task" "TASK.STacK.ADD"
|
|
menuitem "Remove Task" "TASK.STacK.RM"
|
|
enable ice()||fire()
|
|
menuitem "&Reset Coverage" "TASK.STacK.RESet"
|
|
)
|
|
)
|
|
popup "Trace"
|
|
(
|
|
popup "List"
|
|
(
|
|
separator
|
|
menuitem "&Task Switches" "Trace.List List.TASK"
|
|
menuitem "&Default and Tasks" "Trace.List List.TASK DEFault"
|
|
)
|
|
)
|
|
popup "Perf"
|
|
(
|
|
separator
|
|
popup "&Task Runtime"
|
|
(
|
|
menuitem "&Prepare"
|
|
(
|
|
if t.method.analyzer()
|
|
(
|
|
Analyzer.AutoInit on
|
|
)
|
|
if (ice()||fire())&&!a.mode.flow()
|
|
(
|
|
Analyzer.ReProgram
|
|
(
|
|
Sample.Enable if AlphaBreak&&Write
|
|
)
|
|
Break.Delete /Alpha
|
|
Break.Set task.config(magic)++(task.config(magicsize)-1) /Alpha
|
|
)
|
|
if a.mode.flow()
|
|
(
|
|
Break.Delete /TraceEnable
|
|
Break.Set task.config(magic) /TraceEnable
|
|
)
|
|
)
|
|
menuitem "[:perf]Show &Numerical" "Trace.STATistic.TASK"
|
|
menuitem "[:achart]Show as &Timing" "Trace.CHART.TASK"
|
|
menuitem "[:achart]Tracking with Trace &List"
|
|
(
|
|
Trace.List List.TASK DEFault /Track
|
|
Trace.CHART.TASK /Track
|
|
)
|
|
)
|
|
popup "Task &Function Runtime"
|
|
(
|
|
menuitem "&Prepare"
|
|
(
|
|
if t.method.analyzer()
|
|
(
|
|
Analyzer.AutoInit on
|
|
Analyzer.STATistic.PreFetch on
|
|
)
|
|
|
|
if (ice()||fire())&&!a.mode.flow()
|
|
(
|
|
if a.config.hac()
|
|
(
|
|
Analyzer.ReProgram
|
|
(
|
|
Sample.Enable if AlphaBreak
|
|
Sample.Enable if BetaBreak
|
|
Mark.A if AlphaBreak
|
|
Mark.B if BetaBreak
|
|
)
|
|
)
|
|
else
|
|
(
|
|
Analyzer.ReProgram
|
|
(
|
|
Sample.Enable if AlphaBreak||BetaBreak
|
|
Mark.A if AlphaBreak
|
|
Mark.B if BetaBreak
|
|
)
|
|
)
|
|
Break.Delete /Alpha /Beta /Charly
|
|
Break.SetFunc
|
|
Break.Set task.config(magic)++(task.config(magicsize)-1) /Alpha
|
|
)
|
|
if a.mode.flow()
|
|
(
|
|
Break.Delete /TraceData
|
|
Break.Set task.config(magic) /TraceData
|
|
)
|
|
)
|
|
menuitem "[:perf]Show &Numerical" "Trace.STATistic.TASKFUNC"
|
|
menuitem "[:perf]Show as &Tree" "Trace.STATistic.TASKTREE"
|
|
menuitem "[:perf]Show &Detailed Tree" "Trace.STATistic.TASKTREE ALL"
|
|
menuitem "[:achart]Show as &Timing" "Trace.CHART.TASKFUNC"
|
|
menuitem "[:alist]Show N&esting" "Trace.List List.TASK FUNC TI.FUNC"
|
|
)
|
|
;popup "Task &Status"
|
|
;(
|
|
; menuitem "&Prepare"
|
|
; (
|
|
; if t.method.analyzer()
|
|
; (
|
|
; Analyzer.AutoInit on
|
|
; )
|
|
; if (ice()||fire())&&!a.mode.flow()
|
|
; (
|
|
; Analyzer.ReProgram
|
|
; (
|
|
; Sample.Enable if AlphaBreak&&Write
|
|
; )
|
|
; Break.Delete /Alpha
|
|
; Break.Set task.config(magic)++(task.config(magicsize)-1) /Alpha
|
|
; TASK.TASKState
|
|
; )
|
|
; )
|
|
; menuitem "[:perf]Show &Numerical" "Trace.STATistic.TASKSTATE"
|
|
; menuitem "[:achart]Show as &Timing" "Trace.CHART.TASKSTATE"
|
|
; menuitem "[:achart]Tracking with Trace &List"
|
|
; (
|
|
; Trace.List List.TASK DEFault /Track
|
|
; Trace.CHART.TASKSTATE /Track
|
|
; )
|
|
;)
|
|
)
|
|
popup "&Help"
|
|
(
|
|
MENUITEM "[:manual]OS Awareness Manual Linux" "HELP __RTOS_FREERTOS_"
|
|
)
|
|
)
|
|
|
|
|
|
menu "task.tl"
|
|
(
|
|
default
|
|
menuitem "Display detailed"
|
|
(
|
|
LOCAL &magic
|
|
&magic=address.offset(track.address())
|
|
TASK.TaskList &magic
|
|
)
|
|
menuitem "Display task struct"
|
|
(
|
|
LOCAL &address &struct
|
|
&address=track.address()
|
|
&struct=task.struct(tcb)
|
|
Var.View %Open %String (&struct*)(&address)
|
|
)
|
|
separator
|
|
menuitem "Display Stack Frame"
|
|
(
|
|
LOCAL &magic
|
|
&magic=address.offset(track.address())
|
|
Var.Frame /Locals /Caller /Task &magic
|
|
)
|
|
menuitem "Display Registers"
|
|
(
|
|
LOCAL &magic
|
|
&magic=address.offset(track.address())
|
|
Register /Task &magic
|
|
)
|
|
menuitem "Switch Context" "Register.TASK address.offset(track.address())"
|
|
separator
|
|
menuitem "Add to Stack Cov" "TASK.STK.ADD address.offset(track.address())"
|
|
menuitem "Rm from Stack Cov" "TASK.STK.RM address.offset(track.address())"
|
|
separator
|
|
menuitem "Dump task entry"
|
|
(
|
|
LOCAL &address
|
|
&address=track.address()
|
|
Data.dump &address /Long /DIALOG
|
|
)
|
|
)
|
|
|
|
|
|
menu "task.q"
|
|
(
|
|
default
|
|
menuitem "Display detailed"
|
|
(
|
|
LOCAL &magic
|
|
&magic=address.offset(track.address())
|
|
TASK.Queue &magic
|
|
)
|
|
menuitem "Display queue struct"
|
|
(
|
|
LOCAL &address &struct
|
|
&address=track.address()
|
|
&struct=task.struct(queue)
|
|
Var.View %Open %String (&struct*)(&address)
|
|
)
|
|
separator
|
|
menuitem "Dump queue entry"
|
|
(
|
|
LOCAL &address
|
|
&address=track.address()
|
|
Data.dump &address /Long /DIALOG
|
|
)
|
|
)
|
|
|
|
|
|
menu "task.s"
|
|
(
|
|
default
|
|
menuitem "Display detailed"
|
|
(
|
|
LOCAL &magic
|
|
&magic=address.offset(track.address())
|
|
TASK.Semaphore &magic
|
|
)
|
|
menuitem "Display semaphore struct"
|
|
(
|
|
LOCAL &address &struct
|
|
&address=track.address()
|
|
&struct=task.struct(queue)
|
|
Var.View %Open %String (&struct*)(&address)
|
|
)
|
|
separator
|
|
menuitem "Dump semaphore entry"
|
|
(
|
|
LOCAL &address
|
|
&address=track.address()
|
|
Data.dump &address /Long /DIALOG
|
|
)
|
|
)
|
|
|
|
|
|
menu "task.ti"
|
|
(
|
|
default
|
|
menuitem "Display detailed"
|
|
(
|
|
LOCAL &magic
|
|
&magic=address.offset(track.address())
|
|
TASK.TImer &magic
|
|
)
|
|
menuitem "Display timer struct"
|
|
(
|
|
LOCAL &address &struct
|
|
&address=track.address()
|
|
&struct=task.struct(timer)
|
|
Var.View %Open %String (&struct*)(&address)
|
|
)
|
|
separator
|
|
menuitem "Dump timer entry"
|
|
(
|
|
LOCAL &address
|
|
&address=track.address()
|
|
Data.dump &address /Long /DIALOG
|
|
)
|
|
)
|
|
|
|
|
|
menu "task.eg"
|
|
(
|
|
default
|
|
menuitem "Display detailed"
|
|
(
|
|
LOCAL &magic
|
|
&magic=address.offset(track.address())
|
|
TASK.EvtGrp &magic
|
|
)
|
|
menuitem "Display event group struct"
|
|
(
|
|
LOCAL &address
|
|
&address=track.address()
|
|
&struct=task.struct(eventgroup)
|
|
Var.View %Open (&struct*)(&address)
|
|
)
|
|
separator
|
|
menuitem "Dump event group entry"
|
|
(
|
|
LOCAL &address
|
|
&address=track.address()
|
|
Data.dump &address /Long /DIALOG
|
|
)
|
|
)
|
|
|
|
|
|
menu "task.sb"
|
|
(
|
|
default
|
|
menuitem "Display detailed"
|
|
(
|
|
LOCAL &magic
|
|
&magic=address.offset(track.address())
|
|
TASK.StrBuf &magic
|
|
)
|
|
menuitem "Display stream buffer struct"
|
|
(
|
|
LOCAL &address
|
|
&address=track.address()
|
|
Var.View %Open (StreamBuffer_t*)(&address)
|
|
)
|
|
separator
|
|
menuitem "Dump stream buffer entry"
|
|
(
|
|
LOCAL &address
|
|
&address=track.address()
|
|
Data.dump &address /Long /DIALOG
|
|
)
|
|
)
|
|
|
|
|
|
menu "task.mb"
|
|
(
|
|
default
|
|
menuitem "Display detailed"
|
|
(
|
|
LOCAL &magic
|
|
&magic=address.offset(track.address())
|
|
TASK.MsgBuf &magic
|
|
)
|
|
menuitem "Display message buffer struct"
|
|
(
|
|
LOCAL &address
|
|
&address=track.address()
|
|
Var.View %Open (StreamBuffer_t*)(&address)
|
|
)
|
|
separator
|
|
menuitem "Dump message buffer entry"
|
|
(
|
|
LOCAL &address
|
|
&address=track.address()
|
|
Data.dump &address /Long /DIALOG
|
|
)
|
|
)
|