Академический Документы
Профессиональный Документы
Культура Документы
7
Pre-Kernel Initialization Debugging With Tornado
Tornado BSP Training Workshop Copyright Wind River Systems Wind River Systems
7-1
7-2
Pre-Kernel Tornado
Tornado tools may rst be accessed after sysHwInit() completes:
q q
Tools available prior to kernel activation. Tools available after kernel activation but prior to interrupts being enabled for target backend.
Access will require WDB agent to execute in system mode. In system mode either VxWorks executes or WDB agent executes:
q
Similar to ROM monitor, only debug agent statically linked into VxWorks image.
7-3
Tornado Tools
Tornado tools include host based:
q q
Debugger - CrossWind. Shell - WindSh. Conguration tool - WindCong. Object loader/unloader. Symbol table management. Customized tools.
Tools can be modied and enhanced using the Tool Command Language (Tcl). Target server mediates host platform access to target. Target agent (WDB agent) can execute as a VxWorks task or independently of the VxWorks kernel.
Tornado BSP Training Workshop Copyright Wind River Systems Wind River Systems
7-4
For more information about Tornado tools see Tornado Users Guide and Tornado API Guide.
Tool
VxWorks
7-5
Interrupts are masked until kernelInit() executes. Necessary device initialization is performed in sysHwInit().
7-6
The WDB agent can be run in task mode or dual mode after an interrupt mode device with Tornado back-end support has been initialized.
7-7
WDB agent must be congured for the appropriate backend connect strategy. For a serial interface:
q
Appropriate SCC channel must be congured to be accessed in polled mode. usrInit() must be modied to initialize WDB agent and suspend execution.
Copyright Wind River Systems Wind River Systems
7-8
WDB_COMM_NETROM - NetROM interface. WDB_COMM_SERIAL - SCC interface. WDB_COMM_CUSTOM - Custom interface. WDB_MODE_EXTERN
7-9
Prior to kernel activation the macro INCLUDE_WDB_VIO must be undened in cong.h as the virtual I/O driver requires the kernel. Size of the WDB agent target memory pool is controlled by the macro WDB_POOL_SIZE. LAN devices may be accessible in system mode through a polled driver, but only after the kernel is activated. Code for wdbCong() is in the le ../src/cong/usrWdb.c.
wdbCong() sets up the external agents context and returns. wdbSuspendSystemHere() transfers control of the CPU to the external agent. Tornado tools can then access target.
Tornado BSP Training Workshop Copyright Wind River Systems Wind River Systems
7-10
wdbCong() is normally called after kernel activation for default VxWorks images. This call should be commented out in usrRoot() (usrRoot() will be discussed in the next section).
Modications to usrInit()
In usrCong.c insert the following code:
.... sysHwInit (); /* initialize system hardware */
/* System debug mode */ wdbConfig(); wdbSuspendSystemHere(NULL, 0); usrKernelInit (); /*configure the Wind kernel*/
7-11
WDB conguration and activation can also be performed at the end of sysHwInit().
q
Modifying sysHwInit() (in sysLib.c) will not require relocating usrCong.c to the <bspName> directory. Dene debug macro to control system level serial debug (e.g. WDB_SYSHWINIT_SCC_DEBUG). If usrCong.c is not modied wdbCong() will be called a second time in by tUsrRoot.
Locks interrupts before transferring control to the external agent (this is not relevant here as interrupts are locked). Calls the underlying routine wdbSuspendSystem() which is the routine called by Tornados breakpoint library to halt execution. Allows a callback routine (with one argument) to be executed after system is suspended. Parameters are passed through argument list.
To begin a CrossWind debug session use the attach command as usual: (gdb) attach system
Tornado BSP Training Workshop Copyright Wind River Systems
7-12
The syntax for wdbSuspendSystemHere() is: wdbSuspendSystemHere (void (*callback)(), int arg) Note, before using the GDB continue command, set a break point to ensure that control of the system can be regained by WDB agent.
7-13
Polled serial drivers for input and output. Conguration routines to access serial device.
If target does not contain WRS supported SCC, use template serial driver to develop driver.
Tornado BSP Training Workshop Copyright Wind River Systems Wind River Systems
7-14
Use reference BSP. Obtain driver support from WRS if reference BSP does not support serial driver.
Initialization of serial I/O control structures. Ioctl() routine to set access mode as polled. Input and output poll routines. Identication serial channel to be used. ../src/drv/sio/templateSio.c ../cong/<bspName>/sysSerial.c ../h/drv/sio/templateSio.h
7-15
sysSerial.c, sioLib.h, templateSio.c and templateSio.h are reproduced in appendix G. Replace template with the name of SCC. Source for wdbCong() in le ../src/cong/usrWdb.c. More complete information about WRS SCC drivers can be obtained in the Tornado Device Driver Workshop.
Contains control structure for each SCC channel (TEMPLATE_CHAN). Each channel control structure has a SIO_CHAN structure as its rst member.
SIO_CHAN structure has one member; a pointer to a SIO_DRV_FUNCS structure. SIO_DRV_FUNCS structure has ve members; used to manage serial device. Will be invoked by WDB agent. Both SIO_CHAN and SIO_DRV_FUNCS are dened in sioLib.h.
Tornado BSP Training Workshop Copyright Wind River Systems Wind River Systems
7-16
7-17
Channel control structure contains all information needed by driver to manage a single channel for serial device. Dots indicate missing code.
Note master control register operates on a chip (not channel) level. Separate channel control structure for each channel. Declared in templateSio.h. Can also use array elements for SCC channels.
Copyright Wind River Systems Wind River Systems
7-18
SIO_CHAN Structure
SIO_CHAN structure is a pointer to a structure containing driver callbacks, SIO_DRV_FUNCS:
LOCAL SIO_DRV_FUNCS templateSioDrvFuncs = { templateIoctl, templateTxStartup, templateCallbackInstall, templatePollInput, templatePollOutput };
q
Declared in templateSio.c. Will need to modify templateIoctl(), templatePolloutput(), and templateInput(). Other routines can be NULLed.
Copyright Wind River Systems
7-19
Initialization of SCC
For each SCC device, SCC control structure initialized by sysSerialHwInit() (refer to sysSerial.c):
q
Initialization control structures for each channel of SCC (TEMPLATE_CHAN). Control macros dened in templateSio.h. Call serial driver routine, templateDevInit(), to initialize SIO_DRV_FUNCS structure and hardware (code in driver templateSio.c). Array of channel control structures with one element per channel (refer to sysSerial.c). Structure with one channel control structure member per channel (refer to templateSio.h).
7-20
Get and put callbacks in channel control structures can be initialized with dummy functions because these routines are not used by the WDB agent in system mode. These dummy routines will be installed by templateCallbackInstall() when wdbCong() is called.
SIO_MODE_SET SIO_BAUD_SET Modify TEMPLATE_INT_ENABLE in templateSio.h. If necessary modify interrupt disable code in templateModeSet() routine. Modify code to support setting baud rate. Modify TEMPLATE_BAUD_MIN and TEMPLATE_BAUD_MAX macros in templateSio.h.
Copyright Wind River Systems Wind River Systems
Mode conguration:
q q
7-21
Modify TEMPLATE_TX_READY macro for output. Modify TEMPLATE_RX_AVAIL macro for input.
For many SCCs will not need to modify code. For some SCCs will need to modify data transfer register management code. These routines will be called in a loop by the WDB agent after wdbSuspendSystemHere() is called.
7-22
Channel Access
The WDB agent uses the conguration macro WDB_TTY_CHANNEL to determine which channel it will use to access a SCC. The default value is 1. To congure the SCC access channel the agent must rst obtain address of SIO_CHAN structure for that channel. The routine sysSerialChanGet() converts a channel number to an address of a SIO_CHAN structure. As part of wdbCong(), sysSerialChanGet() will be called with the argument WDB_TTY_CHANNEL. Should not need to modify sysSerialChanGet() in sysSerial.c (except channel control structure name).
Tornado BSP Training Workshop Copyright Wind River Systems Wind River Systems
7-23
7-24
Dynamically allocating memory for new global variables eliminating the need to re-build and reload a VxWorks image. Using lkup to examine the symbol table. Customize CrossWind. Write a new loader to support unsupported OMF. Build and install a custom Tornado tool using WTX protocol.
Copyright Wind River Systems
7-25
See Tornado API Guide for more information about creating and modifying Tornado tools.
CrossWind Customization
Standard system mode debugging facilities available. CrossWind can be modied to support features such as:
q q
Hardware breakpoints. Menu access to customized debug commands. Dening new buttons. Initialization of debug session(s). GUI interface. GDB debug engine.
CrossWind interaction with target server can be customized using the WTX libraries.
Tornado BSP Training Workshop Copyright Wind River Systems
7-26
Modify graphical presentation. Dene new buttons. Provide menu access to customized commands. Dene Tcl procedures for new GDB commands. Initialize a debug session. (This script le is executed each time a GDB session, not just a CrossWind session, is started.)
Copyright Wind River Systems Wind River Systems
7-27
The WRS CrossWind remote debugger has a Tcl interpreter built into the GDB engine.
Low bandwidth serial line load to RAM or Flash. Burning VxWorks ROM image.
Using dynamic callback code may be more efcient. Code can be dynamically replaced using CrossWind:
q
Declare a callback (or hook routine) in loaded Vxworks image. Conditionally call routine in loaded image. Load module with desired code using CrossWind. Use GDB set command to assign desired function to callback.
Copyright Wind River Systems Wind River Systems
7-28
From CrossWind load the module containing routine of interest (e.g. debugRoutine()); and from GDB prompt:
q
7-29
Note, debugRoutine() may even use variables not declared in the VxWorks image if they are dynamically created using WindSh.
Disadvantage of using call command is that original code still executes. If hardware environment has abort switch consider connecting a debug routine to the abort interrupt using intVecSet(). Use CrossWind to set breakpoint in abort debug ISR:
q
Summary
Tornado tools can be accessed prior to kernel activation using the WDB agent:
q q
Congured for external mode. Congured to use appropriate backend connection. Congured not to include virtual I/O.
In system (external) mode either VxWorks executes or WDB agent executes. usrInit() must be modied after the call to sysHwInit() to call:
q q
wdbCong() wdbSuspendSystemHere()
7-31