/*******************************************************************************
* Copyright (c) 2015 Ericsson
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* Matthew Khouzam - Initial API and implementation
*******************************************************************************/
package org.eclipse.tracecompass.internal.analysis.os.linux.core.kernel.handlers;
import org.eclipse.tracecompass.analysis.os.linux.core.kernel.StateValues;
import org.eclipse.tracecompass.analysis.os.linux.core.trace.IKernelAnalysisEventLayout;
import org.eclipse.tracecompass.internal.analysis.os.linux.core.kernel.Attributes;
import org.eclipse.tracecompass.statesystem.core.ITmfStateSystemBuilder;
import org.eclipse.tracecompass.statesystem.core.exceptions.AttributeNotFoundException;
import org.eclipse.tracecompass.statesystem.core.statevalue.ITmfStateValue;
import org.eclipse.tracecompass.statesystem.core.statevalue.TmfStateValue;
import org.eclipse.tracecompass.tmf.core.event.ITmfEvent;
/**
* System call entry handler
*/
public class SysEntryHandler extends KernelEventHandler {
/**
* Constructor
*
* @param layout
* event layout
*/
public SysEntryHandler(IKernelAnalysisEventLayout layout) {
super(layout);
}
@Override
public void handleEvent(ITmfStateSystemBuilder ss, ITmfEvent event) throws AttributeNotFoundException {
Integer cpu = KernelEventHandlerUtils.getCpu(event);
if (cpu == null) {
return;
}
/* Assign the new system call to the process */
int currentThreadNode = KernelEventHandlerUtils.getCurrentThreadNode(cpu, ss);
int quark = ss.getQuarkRelativeAndAdd(currentThreadNode, Attributes.SYSTEM_CALL);
ITmfStateValue value = TmfStateValue.newValueString(event.getName());
long timestamp = KernelEventHandlerUtils.getTimestamp(event);
ss.modifyAttribute(timestamp, value, quark);
/* Put the process in system call mode */
value = StateValues.PROCESS_STATUS_RUN_SYSCALL_VALUE;
ss.modifyAttribute(timestamp, value, currentThreadNode);
/* Put the CPU in system call (kernel) mode */
int currentCPUNode = KernelEventHandlerUtils.getCurrentCPUNode(cpu, ss);
value = StateValues.CPU_STATUS_RUN_SYSCALL_VALUE;
ss.modifyAttribute(timestamp, value, currentCPUNode);
}
}