00001 /* 00002 * ################################################################ 00003 * 00004 * ProActive: The Java(TM) library for Parallel, Distributed, 00005 * Concurrent computing with Security and Mobility 00006 * 00007 * Copyright (C) 1997-2007 INRIA/University of Nice-Sophia Antipolis 00008 * Contact: proactive@objectweb.org 00009 * 00010 * This library is free software; you can redistribute it and/or 00011 * modify it under the terms of the GNU Lesser General Public 00012 * License as published by the Free Software Foundation; either 00013 * version 2.1 of the License, or any later version. 00014 * 00015 * This library is distributed in the hope that it will be useful, 00016 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00017 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00018 * Lesser General Public License for more details. 00019 * 00020 * You should have received a copy of the GNU Lesser General Public 00021 * License along with this library; if not, write to the Free Software 00022 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 00023 * USA 00024 * 00025 * Initial developer(s): The ProActive Team 00026 * http://www.inria.fr/oasis/ProActive/contacts.html 00027 * Contributor(s): 00028 * 00029 * ################################################################ 00030 */ 00031 package org.objectweb.proactive.core.group.spmd; 00032 00033 import java.lang.reflect.InvocationTargetException; 00034 00035 import org.objectweb.proactive.ProActive; 00036 import org.objectweb.proactive.core.body.AbstractBody; 00037 import org.objectweb.proactive.core.group.MethodCallControlForGroup; 00038 import org.objectweb.proactive.core.mop.MethodCallExecutionFailedException; 00039 00040 00045 public class MethodCallBarrier extends MethodCallControlForGroup { 00046 00048 private String IDName; 00049 00054 public MethodCallBarrier(String idname) { 00055 this.IDName = idname; 00056 } 00057 00062 public String getName() { 00063 return "MethodCallBarrier"; 00064 } 00065 00070 public String getIDName() { 00071 return this.IDName; 00072 } 00073 00079 public Object execute(Object target) 00080 throws InvocationTargetException, MethodCallExecutionFailedException { 00081 ProActiveSPMDGroupManager spmdManager = ((AbstractBody) ProActive.getBodyOnThis()).getProActiveSPMDGroupManager(); 00082 BarrierState bs = (BarrierState) spmdManager.getBarrierStateFor(this.getIDName()); 00083 00084 // bs == null => state not found => first barrier encountered for ID name 00085 if (bs == null) { 00086 bs = new BarrierState(); 00087 spmdManager.addToCurrentBarriers(this.getIDName(), bs); 00088 } 00089 bs.incrementReceivedCalls(); 00090 // if there is no others waiting calls, release the barrier 00091 if ((bs.getAwaitedCalls() - bs.getReceivedCalls()) == 0) { 00092 spmdManager.remove(this.getIDName()); 00093 } 00094 return null; 00095 } 00096 }