os/kernelhwsrv/kerneltest/e32test/debug/d_eventtracker.cia
author sl@SLION-WIN7.fritz.box
Fri, 15 Jun 2012 03:10:57 +0200
changeset 0 bde4ae8d615e
permissions -rw-r--r--
First public contribution.
sl@0
     1
// Copyright (c) 2004-2009 Nokia Corporation and/or its subsidiary(-ies).
sl@0
     2
// All rights reserved.
sl@0
     3
// This component and the accompanying materials are made available
sl@0
     4
// under the terms of the License "Eclipse Public License v1.0"
sl@0
     5
// which accompanies this distribution, and is available
sl@0
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
sl@0
     7
//
sl@0
     8
// Initial Contributors:
sl@0
     9
// Nokia Corporation - initial contribution.
sl@0
    10
//
sl@0
    11
// Contributors:
sl@0
    12
//
sl@0
    13
// Description:
sl@0
    14
// e32test\debug\d_eventtracker.cia
sl@0
    15
// 
sl@0
    16
//
sl@0
    17
sl@0
    18
#include <arm.h>
sl@0
    19
#include "d_eventtracker.h"
sl@0
    20
sl@0
    21
//////////////////////////////////////////////////////////////////////////////
sl@0
    22
sl@0
    23
// CIA symbol macros for Gcc98r2
sl@0
    24
#if defined(__GCC32__)
sl@0
    25
sl@0
    26
#define CSM_ZN13DEventTracker11HandleEventE12TKernelEventPvS1 " HandleEvent__13DEventTracker12TKernelEventPvT2"
sl@0
    27
sl@0
    28
// CIA symbol macros for RVCT
sl@0
    29
#elif defined(__ARMCC__)
sl@0
    30
sl@0
    31
#define CSM_ZN13DEventTracker11HandleEventE12TKernelEventPvS1 " __cpp(DEventTracker::HandleEvent)"
sl@0
    32
sl@0
    33
// CIA symbol macros for EABI assemblers
sl@0
    34
#else
sl@0
    35
sl@0
    36
#define CSM_ZN13DEventTracker11HandleEventE12TKernelEventPvS1 " _ZN13DEventTracker11HandleEventE12TKernelEventPvS1_"
sl@0
    37
sl@0
    38
#endif
sl@0
    39
sl@0
    40
//////////////////////////////////////////////////////////////////////////////
sl@0
    41
sl@0
    42
__NAKED__ void DEventTracker::BranchToEventHandler()
sl@0
    43
//
sl@0
    44
// Breakpoint to call our event handler
sl@0
    45
//
sl@0
    46
	{
sl@0
    47
	asm("breakstart: ");													// start of breakpoint.
sl@0
    48
	asm("mov r3, r2");														// set up regs for call to our handler...
sl@0
    49
	asm("mov r2, r1");														//
sl@0
    50
	asm("mov r1, r0");														//
sl@0
    51
	asm("ldr r0, __TheEventTracker ");										// fiddle this pointer
sl@0
    52
	asm("ldr r0, [r0] ");													// load from TheEventTracker
sl@0
    53
	asm("ldr pc, [pc, #-4]" );												// do an absolute jump...
sl@0
    54
	asm(".word " CSM_ZN13DEventTracker11HandleEventE12TKernelEventPvS1 );	//  to DEventTracker::HandleEvent
sl@0
    55
	asm("__TheEventTracker: ");												// address of global variable:
sl@0
    56
	asm(".word %a0" : : "i" (&TheEventTracker));							//  TheEventTracker
sl@0
    57
	asm("breakend: ");														// end of breakpoint.
sl@0
    58
	}
sl@0
    59
sl@0
    60
__NAKED__ TUint DEventTracker::BreakPointSize()
sl@0
    61
//
sl@0
    62
// Size of breakpoint
sl@0
    63
//
sl@0
    64
	{
sl@0
    65
	asm("ldr r0, = breakend - breakstart");
sl@0
    66
	__JUMP(,lr);
sl@0
    67
	}
sl@0
    68
sl@0
    69
__NAKED__ TUint DEventTracker::DummyHandler(TKernelEvent /*aEvent*/, TAny* /*a1*/, TAny* /*a2*/)
sl@0
    70
//
sl@0
    71
// Debugger breakpoint-able callback.  Will be copied into RAM
sl@0
    72
//
sl@0
    73
	{
sl@0
    74
	//
sl@0
    75
	// r0=aEvent, r1=a1, r2=a2
sl@0
    76
	//
sl@0
    77
	asm("dummystart: ");											// start of fn.
sl@0
    78
	asm("nop");														// breakpoint-able instruction for the debugger to replace
sl@0
    79
	asm("nop");														// landing zone
sl@0
    80
	asm("nop");														// landing zone
sl@0
    81
	asm("nop");														// landing zone
sl@0
    82
	asm("nop");														// landing zone
sl@0
    83
	asm("nop");														// landing zone
sl@0
    84
	asm("nop");														// landing zone
sl@0
    85
	asm("mov r0, #%a0" : : "i" (DKernelEventHandler::ERunNext));	// return value
sl@0
    86
	__JUMP(,lr);													// return
sl@0
    87
	asm("dummyend:");												// end of fn.
sl@0
    88
	}
sl@0
    89
sl@0
    90
__NAKED__ TUint DEventTracker::DummyHandlerSize()
sl@0
    91
//
sl@0
    92
// Size of debugger breakpoint-able callback.
sl@0
    93
//
sl@0
    94
	{
sl@0
    95
	asm("ldr r0, = dummyend - dummystart");
sl@0
    96
	__JUMP(,lr);
sl@0
    97
	}