omxilvideocomps/omxilvideoscheduler/src/buffercopierstatemonitor.cpp
author hgs
Fri, 08 Oct 2010 22:09:17 +0100
changeset 0 5d29cba61097
permissions -rw-r--r--
2010wk38_02
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
     1
/*
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
     2
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
     3
* All rights reserved.
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
     8
*
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
     9
* Initial Contributors:
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    11
*
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    12
* Contributors:
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    13
*
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    14
* Description:
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    15
*
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    16
*/
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    17
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    18
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    19
/**
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    20
@file
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    21
@internalComponent
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    22
*/
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    23
#include "buffercopier.h"
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    24
#include "comxilvideoscheduler.h"
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    25
#include "buffercopierstatemonitor.h"
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    26
#include "log.h"
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    27
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    28
CBufferCopierStateMonitor* CBufferCopierStateMonitor::NewL(MBufferCopierIf& aCallback, COmxILVideoScheduler& aComponent)
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    29
    {
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    30
    CBufferCopierStateMonitor* self = new (ELeave) CBufferCopierStateMonitor(aCallback, aComponent);
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    31
    CleanupStack::PushL(self);
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    32
    self->ConstructL();
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    33
    CleanupStack::Pop(self);
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    34
    return self;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    35
    }
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    36
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    37
CBufferCopierStateMonitor::CBufferCopierStateMonitor(MBufferCopierIf& aCallback, COmxILVideoScheduler& aComponent) :
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    38
CActive(EPriorityNormal),
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    39
iCallback(aCallback),
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    40
iComponent(aComponent),
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    41
iState(ENull)
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    42
    {
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    43
    CActiveScheduler::Add(this);
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    44
    }
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    45
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    46
CBufferCopierStateMonitor::~CBufferCopierStateMonitor()
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    47
    {
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    48
    Cancel();
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    49
    delete iBufferCopier;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    50
    }
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    51
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    52
void CBufferCopierStateMonitor::ConstructL()
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    53
    {
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    54
    RThread me;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    55
    iConstructionThreadId = me.Id();
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    56
    
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    57
    iStatus = KRequestPending;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    58
    SetActive();
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    59
    }
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    60
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    61
void CBufferCopierStateMonitor::RunL()
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    62
    {
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    63
    iStatus = KRequestPending;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    64
    SetActive();
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    65
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    66
    TInt err = DoSetState();
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    67
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    68
    TRequestStatus *status = iCallingStatus;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    69
    RThread callingThread;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    70
    callingThread.Open(iCallingThreadId);
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    71
    callingThread.RequestComplete(status, err);
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    72
    callingThread.Close();
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    73
    }
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    74
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    75
void CBufferCopierStateMonitor::DoCancel()
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    76
    {
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    77
    TRequestStatus* pStat = &iStatus;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    78
    User::RequestComplete(pStat, KErrCancel);
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    79
    }
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    80
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    81
TInt CBufferCopierStateMonitor::RunError(TInt aError)
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    82
    {
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    83
    DEBUG_PRINTF2(_L8("CBufferCopierStateMonitor::RunError %d"), aError);
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    84
    aError=KErrNone; //Do not want to panic the server!
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    85
    return aError; 
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    86
    }
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    87
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    88
TInt CBufferCopierStateMonitor::SetState(TPFState aState)
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    89
    {
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    90
    DEBUG_PRINTF(_L8("CBufferCopierStateMonitor::SetState"));
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    91
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    92
    TInt err = KErrNone;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    93
    iState = aState;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    94
    
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    95
    RThread me;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    96
    if(me.Id() != iConstructionThreadId)
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    97
        {
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    98
        // in different thread to that which 'this' was constructed
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
    99
        err = DoRequest();
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   100
        }
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   101
    else
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   102
        {
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   103
        // in same thread to that which 'this' was constructed therefore
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   104
        // active scheduler must exist and following call is safe
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   105
        err = DoSetState();
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   106
        }
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   107
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   108
    return err;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   109
    }
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   110
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   111
TInt CBufferCopierStateMonitor::DoSetState()
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   112
    {
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   113
    DEBUG_PRINTF(_L8("CBufferCopierStateMonitor::DoSetState"));
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   114
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   115
    TInt err = KErrNone;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   116
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   117
    switch(iState)
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   118
        {
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   119
        case ESubLoadedToIdle:
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   120
            iMaxBuffers = iComponent.BufferCount();
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   121
            delete iBufferCopier;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   122
            iBufferCopier = NULL;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   123
            TRAP(err, iBufferCopier = CBufferCopier::NewL(iCallback, iMaxBuffers));
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   124
            break;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   125
        case ESubIdleToLoaded:
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   126
            delete iBufferCopier;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   127
            iBufferCopier = NULL;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   128
            break;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   129
        default:
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   130
            break;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   131
        };
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   132
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   133
    return err;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   134
    }
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   135
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   136
TInt CBufferCopierStateMonitor::DoRequest()
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   137
    {
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   138
    DEBUG_PRINTF(_L8("CBufferCopierStateMonitor::DoRequest"));
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   139
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   140
    RThread me;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   141
    iCallingThreadId = me.Id();
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   142
    TRequestStatus requestStatus = KRequestPending;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   143
    iCallingStatus = &requestStatus;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   144
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   145
    // send request to active scheduler thread
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   146
    RThread schedulerThread;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   147
    TInt error = schedulerThread.Open(iConstructionThreadId);
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   148
    if(error != KErrNone)
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   149
        {
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   150
        return error;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   151
        }
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   152
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   153
    TRequestStatus* schedulerRequest = &iStatus;
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   154
    schedulerThread.RequestComplete(schedulerRequest, KErrNone);
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   155
    schedulerThread.Close();
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   156
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   157
    // block until request completes
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   158
    User::WaitForRequest(requestStatus);
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   159
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   160
    return requestStatus.Int();
5d29cba61097 2010wk38_02
hgs
parents:
diff changeset
   161
    }