javamanager/javacaptain/src.linux/pmc.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 27 Apr 2010 16:30:29 +0300
branchRCL_3
changeset 14 04becd199f91
permissions -rw-r--r--
Revision: v2.1.22 Kit: 201017

/*
* Copyright (c) 2008 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of "Eclipse Public License v1.0"
* which accompanies this distribution, and is available
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
*
* Initial Contributors:
* Nokia Corporation - initial contribution.
*
* Contributors:
*
* Description:  Pmc
*
*/


#include <sys/types.h>
#include <signal.h>
#include <sys/wait.h>
#include <errno.h>
#include <string.h>
#include <stdlib.h>

#include "logger.h"

#include "pmc.h"
#include "processmanagementeventsinterface.h"
#include "coreinterface.h"

namespace java
{
namespace captain
{

Pmc::Pmc()
{
    JELOG4(EJavaCaptain, EInfo);
}

Pmc::~Pmc()
{
    JELOG4(EJavaCaptain, EInfo);
}

bool Pmc::start(CoreInterface* /*aCore*/,
                ProcessManagementEventsInterface* /*aProcessManagementEventsDispatcher*/)
{
    JELOG4(EJavaCaptain, EInfo);

    return true;
}

bool Pmc::stop()
{
    JELOG4(EJavaCaptain, EInfo);

    return true;
}

int Pmc::launch(const cmdLine_t& cmdLine, const int& /*options*/)
{
    JELOG4(EJavaCaptain, EInfo);

    int status = 0, pid = 0;

    if (!(pid = fork()))
    {
        sigset_t unblock;
        sigemptyset(&unblock);
        sigaddset(&unblock, SIGINT);
        int rc = pthread_sigmask(SIG_UNBLOCK, &unblock, NULL);
        if (rc)
        {
            ELOG1(EJavaCaptain, "pthread_sigmask(UNBLOCK) for a child failed with %d", rc);
        }

        char** av = new char*[cmdLine.size() + 1];
        unsigned int index;
        for (index = 0; index < cmdLine.size() ; index++)
        {
            av[index] = const_cast<char*>(cmdLine[index].c_str());
            LOG1(EJavaCaptain, EInfo, "Launch command line is: %s", av[index]);
        }
        av[index] = NULL;

        status = execvp(av[0], av);

        if (status == -1)
        {
            LOG1(EJavaCaptain, EError, "execvp() returned %d", status);
            LOG2(EJavaCaptain, EError, "can't start %s, error message: %s", av[0], strerror(errno));
        }
        else
        {
            LOG1(EJavaCaptain, EInfo, "execvp() returned %d", status);
        }
        delete [] av;
        exit(status);
    }

    return pid;
}

int Pmc::terminate(const int& pid)
{
    JELOG4(EJavaCaptain, EInfo);
    LOG1(EJavaCaptain, EInfo, "kill(pid=%d, SIGINT)", pid);
    ::kill(pid, SIGINT);
    return 0;
}

int Pmc::kill(const int& pid)
{
    JELOG4(EJavaCaptain, EInfo);
    LOG1(EJavaCaptain, EInfo, "kill(pid=%d, SIGKILL)", pid);
    ::kill(pid, SIGKILL);
    return 0;
}

} // namespace captain
} // namespace java