extending abstract wakeup mote
This commit is contained in:
parent
ed8867bcb5
commit
38dcc8ed93
@ -26,16 +26,25 @@
|
|||||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
* SUCH DAMAGE.
|
* SUCH DAMAGE.
|
||||||
*
|
*
|
||||||
* $Id: ContikiMote.java,v 1.14 2009/09/17 13:20:03 fros4943 Exp $
|
* $Id: ContikiMote.java,v 1.15 2009/10/27 10:12:33 fros4943 Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package se.sics.cooja.contikimote;
|
package se.sics.cooja.contikimote;
|
||||||
|
|
||||||
import java.util.*;
|
import java.util.Collection;
|
||||||
|
import java.util.Vector;
|
||||||
|
|
||||||
import org.apache.log4j.Logger;
|
import org.apache.log4j.Logger;
|
||||||
import org.jdom.Element;
|
import org.jdom.Element;
|
||||||
|
|
||||||
import se.sics.cooja.*;
|
import se.sics.cooja.Mote;
|
||||||
|
import se.sics.cooja.MoteInterface;
|
||||||
|
import se.sics.cooja.MoteInterfaceHandler;
|
||||||
|
import se.sics.cooja.MoteMemory;
|
||||||
|
import se.sics.cooja.MoteType;
|
||||||
|
import se.sics.cooja.SectionMoteMemory;
|
||||||
|
import se.sics.cooja.Simulation;
|
||||||
|
import se.sics.cooja.motes.AbstractWakeupMote;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A Contiki mote executes an actual Contiki system via
|
* A Contiki mote executes an actual Contiki system via
|
||||||
@ -52,13 +61,13 @@ import se.sics.cooja.*;
|
|||||||
*
|
*
|
||||||
* @author Fredrik Osterlind
|
* @author Fredrik Osterlind
|
||||||
*/
|
*/
|
||||||
public class ContikiMote implements Mote {
|
public class ContikiMote extends AbstractWakeupMote implements Mote {
|
||||||
private static Logger logger = Logger.getLogger(ContikiMote.class);
|
private static Logger logger = Logger.getLogger(ContikiMote.class);
|
||||||
|
|
||||||
private ContikiMoteType myType = null;
|
private ContikiMoteType myType = null;
|
||||||
private SectionMoteMemory myMemory = null;
|
private SectionMoteMemory myMemory = null;
|
||||||
private MoteInterfaceHandler myInterfaceHandler = null;
|
private MoteInterfaceHandler myInterfaceHandler = null;
|
||||||
private Simulation mySim = null;
|
private Simulation simulation = null;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a new uninitialized Contiki mote.
|
* Creates a new uninitialized Contiki mote.
|
||||||
@ -78,12 +87,12 @@ public class ContikiMote implements Mote {
|
|||||||
* @param sim Mote's simulation
|
* @param sim Mote's simulation
|
||||||
*/
|
*/
|
||||||
public ContikiMote(ContikiMoteType moteType, Simulation sim) {
|
public ContikiMote(ContikiMoteType moteType, Simulation sim) {
|
||||||
this.mySim = sim;
|
this.simulation = sim;
|
||||||
this.myType = moteType;
|
this.myType = moteType;
|
||||||
this.myMemory = moteType.createInitialMemory();
|
this.myMemory = moteType.createInitialMemory();
|
||||||
this.myInterfaceHandler = new MoteInterfaceHandler(this, moteType.getMoteInterfaceClasses());
|
this.myInterfaceHandler = new MoteInterfaceHandler(this, moteType.getMoteInterfaceClasses());
|
||||||
|
|
||||||
scheduleNextWakeup(mySim.getSimulationTime());
|
requestImmediateWakeup();
|
||||||
}
|
}
|
||||||
|
|
||||||
public int getID() {
|
public int getID() {
|
||||||
@ -115,11 +124,11 @@ public class ContikiMote implements Mote {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public Simulation getSimulation() {
|
public Simulation getSimulation() {
|
||||||
return mySim;
|
return simulation;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setSimulation(Simulation simulation) {
|
public void setSimulation(Simulation simulation) {
|
||||||
mySim = simulation;
|
this.simulation = simulation;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -132,7 +141,7 @@ public class ContikiMote implements Mote {
|
|||||||
*
|
*
|
||||||
* @param simTime Current simulation time
|
* @param simTime Current simulation time
|
||||||
*/
|
*/
|
||||||
public boolean tick(long simTime) {
|
public void execute(long simTime) {
|
||||||
|
|
||||||
/* Poll mote interfaces */
|
/* Poll mote interfaces */
|
||||||
myInterfaceHandler.doActiveActionsBeforeTick();
|
myInterfaceHandler.doActiveActionsBeforeTick();
|
||||||
@ -141,7 +150,7 @@ public class ContikiMote implements Mote {
|
|||||||
/* Check if pre-boot time */
|
/* Check if pre-boot time */
|
||||||
if (myInterfaceHandler.getClock().getTime() < 0) {
|
if (myInterfaceHandler.getClock().getTime() < 0) {
|
||||||
scheduleNextWakeup(simTime + -myInterfaceHandler.getClock().getTime());
|
scheduleNextWakeup(simTime + -myInterfaceHandler.getClock().getTime());
|
||||||
return false;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Copy mote memory to Contiki */
|
/* Copy mote memory to Contiki */
|
||||||
@ -156,8 +165,6 @@ public class ContikiMote implements Mote {
|
|||||||
/* Poll mote interfaces */
|
/* Poll mote interfaces */
|
||||||
myInterfaceHandler.doActiveActionsAfterTick();
|
myInterfaceHandler.doActiveActionsAfterTick();
|
||||||
myInterfaceHandler.doPassiveActionsAfterTick();
|
myInterfaceHandler.doPassiveActionsAfterTick();
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -181,7 +188,7 @@ public class ContikiMote implements Mote {
|
|||||||
element = new Element("interface_config");
|
element = new Element("interface_config");
|
||||||
element.setText(moteInterface.getClass().getName());
|
element.setText(moteInterface.getClass().getName());
|
||||||
|
|
||||||
Collection interfaceXML = moteInterface.getConfigXML();
|
Collection<Element> interfaceXML = moteInterface.getConfigXML();
|
||||||
if (interfaceXML != null) {
|
if (interfaceXML != null) {
|
||||||
element.addContent(interfaceXML);
|
element.addContent(interfaceXML);
|
||||||
config.add(element);
|
config.add(element);
|
||||||
@ -192,7 +199,7 @@ public class ContikiMote implements Mote {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public boolean setConfigXML(Simulation simulation, Collection<Element> configXML, boolean visAvailable) {
|
public boolean setConfigXML(Simulation simulation, Collection<Element> configXML, boolean visAvailable) {
|
||||||
mySim = simulation;
|
this.simulation = simulation;
|
||||||
|
|
||||||
for (Element element: configXML) {
|
for (Element element: configXML) {
|
||||||
String name = element.getName();
|
String name = element.getName();
|
||||||
@ -220,7 +227,7 @@ public class ContikiMote implements Mote {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
scheduleNextWakeup(mySim.getSimulationTime());
|
requestImmediateWakeup();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -228,29 +235,7 @@ public class ContikiMote implements Mote {
|
|||||||
return "Contiki " + getID();
|
return "Contiki " + getID();
|
||||||
}
|
}
|
||||||
|
|
||||||
private TimeEvent tickMoteEvent = new MoteTimeEvent(this, 0) {
|
public boolean tick(long simTime) {
|
||||||
public void execute(long t) {
|
throw new RuntimeException("Obsolete method");
|
||||||
/* Tick Contiki mote */
|
|
||||||
tick(mySim.getSimulationTime());
|
|
||||||
}
|
|
||||||
public String toString() {
|
|
||||||
return "CONTIKI TICK " + ContikiMote.this;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
public void scheduleImmediateWakeup() {
|
|
||||||
scheduleNextWakeup(mySim.getSimulationTime());
|
|
||||||
}
|
|
||||||
|
|
||||||
public void scheduleNextWakeup(long time) {
|
|
||||||
if (tickMoteEvent.isScheduled() &&
|
|
||||||
tickMoteEvent.getTime() <= time) {
|
|
||||||
/* Native tick events already scheduled */
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Reschedule native mote event */
|
|
||||||
/*logger.info("Rescheduled tick from " + tickMoteEvent.time + " to " + time);*/
|
|
||||||
mySim.scheduleEventUnsafe(tickMoteEvent, time);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user