added method for checking if radio is on/off. the method is currently only used by contikradio:s.

changed UDGM coloring:
dead/non-existing radios are black.
turned off radios are gray.
This commit is contained in:
fros4943 2008-02-23 10:10:42 +00:00
parent f5e7da082c
commit 2c5e167b20
2 changed files with 34 additions and 19 deletions

View file

@ -26,7 +26,7 @@
* 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: ContikiRadio.java,v 1.16 2007/05/31 07:19:11 fros4943 Exp $ * $Id: ContikiRadio.java,v 1.17 2008/02/23 10:10:42 fros4943 Exp $
*/ */
package se.sics.cooja.contikimote.interfaces; package se.sics.cooja.contikimote.interfaces;
@ -143,9 +143,10 @@ public class ContikiRadio extends Radio implements ContikiMoteInterface,
this.myMoteMemory = (SectionMoteMemory) mote.getMemory(); this.myMoteMemory = (SectionMoteMemory) mote.getMemory();
// Calculate energy consumption of a listening radio // Calculate energy consumption of a listening radio
if (energyListeningRadioPerTick < 0) if (energyListeningRadioPerTick < 0) {
energyListeningRadioPerTick = ENERGY_CONSUMPTION_RADIO_mA energyListeningRadioPerTick = ENERGY_CONSUMPTION_RADIO_mA
* mote.getSimulation().getTickTimeInSeconds(); * mote.getSimulation().getTickTimeInSeconds();
}
radioOn = myMoteMemory.getByteValueOf("simRadioHWOn") == 1; radioOn = myMoteMemory.getByteValueOf("simRadioHWOn") == 1;
} }
@ -169,13 +170,18 @@ public class ContikiRadio extends Radio implements ContikiMoteInterface,
} }
/* General radio support */ /* General radio support */
public boolean isOn() {
return radioOn;
}
public boolean isTransmitting() { public boolean isTransmitting() {
return isTransmitting; return isTransmitting;
} }
public boolean isReceiving() { public boolean isReceiving() {
if (isLockedAtReceiving()) if (isLockedAtReceiving()) {
return true; return true;
}
return myMoteMemory.getIntValueOf("simInSize") != 0; return myMoteMemory.getIntValueOf("simInSize") != 0;
} }
@ -252,7 +258,7 @@ public class ContikiRadio extends Radio implements ContikiMoteInterface,
} }
public int getCurrentOutputPowerIndicator() { public int getCurrentOutputPowerIndicator() {
return (int) myMoteMemory.getByteValueOf("simPower"); return myMoteMemory.getByteValueOf("simPower");
} }
public double getCurrentSignalStrength() { public double getCurrentSignalStrength() {
@ -290,11 +296,13 @@ public class ContikiRadio extends Radio implements ContikiMoteInterface,
private void lockInReceivingMode() { private void lockInReceivingMode() {
// If mote is inactive, try to wake it up // If mote is inactive, try to wake it up
if (myMote.getState() != Mote.State.ACTIVE) { if (myMote.getState() != Mote.State.ACTIVE) {
if (RAISES_EXTERNAL_INTERRUPT) if (RAISES_EXTERNAL_INTERRUPT) {
myMote.setState(Mote.State.ACTIVE); myMote.setState(Mote.State.ACTIVE);
if (myMote.getState() != Mote.State.ACTIVE) }
if (myMote.getState() != Mote.State.ACTIVE) {
return; return;
} }
}
// Lock core radio in receiving loop // Lock core radio in receiving loop
myMoteMemory.setByteValueOf("simReceiving", (byte) 1); myMoteMemory.setByteValueOf("simReceiving", (byte) 1);
@ -317,8 +325,9 @@ public class ContikiRadio extends Radio implements ContikiMoteInterface,
myMoteMemory.setIntValueOf("simOutSize", 0); myMoteMemory.setIntValueOf("simOutSize", 0);
isTransmitting = false; isTransmitting = false;
lastEvent = RadioEvent.HW_OFF; lastEvent = RadioEvent.HW_OFF;
} else } else {
lastEvent = RadioEvent.HW_ON; lastEvent = RadioEvent.HW_ON;
}
lastEventTime = myMote.getSimulation().getSimulationTime(); lastEventTime = myMote.getSimulation().getSimulationTime();
this.setChanged(); this.setChanged();
@ -371,7 +380,7 @@ public class ContikiRadio extends Radio implements ContikiMoteInterface,
isTransmitting = true; isTransmitting = true;
// Calculate transmission duration (ms) // Calculate transmission duration (ms)
int duration = (int) ((double) (280 + 10 * size) / RADIO_TRANSMISSION_RATE_kbps); int duration = (int) ((280 + 10 * size) / RADIO_TRANSMISSION_RATE_kbps);
transmissionEndTime = myMote.getSimulation().getSimulationTime() transmissionEndTime = myMote.getSimulation().getSimulationTime()
+ Math.max(1, duration); + Math.max(1, duration);
lastEventTime = myMote.getSimulation().getSimulationTime(); lastEventTime = myMote.getSimulation().getSimulationTime();
@ -414,14 +423,15 @@ public class ContikiRadio extends Radio implements ContikiMoteInterface,
Observer observer; Observer observer;
this.addObserver(observer = new Observer() { this.addObserver(observer = new Observer() {
public void update(Observable obs, Object obj) { public void update(Observable obs, Object obj) {
if (isTransmitting()) if (isTransmitting()) {
statusLabel.setText("Transmitting packet now!"); statusLabel.setText("Transmitting packet now!");
else if (isReceiving()) } else if (isReceiving()) {
statusLabel.setText("Receiving packet now!"); statusLabel.setText("Receiving packet now!");
else if (radioOn) } else if (radioOn) {
statusLabel.setText("Listening..."); statusLabel.setText("Listening...");
else } else {
statusLabel.setText("HW turned off"); statusLabel.setText("HW turned off");
}
lastEventLabel.setText("Last event (time=" + lastEventTime + "): " lastEventLabel.setText("Last event (time=" + lastEventTime + "): "
+ lastEvent); + lastEvent);

View file

@ -26,7 +26,7 @@
* 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: UDGM.java,v 1.13 2008/02/12 15:31:22 fros4943 Exp $ * $Id: UDGM.java,v 1.14 2008/02/23 10:10:42 fros4943 Exp $
*/ */
package se.sics.cooja.radiomediums; package se.sics.cooja.radiomediums;
@ -40,6 +40,7 @@ import org.jdom.Element;
import org.apache.log4j.Logger; import org.apache.log4j.Logger;
import se.sics.cooja.*; import se.sics.cooja.*;
import se.sics.cooja.contikimote.interfaces.ContikiRadio;
import se.sics.cooja.interfaces.*; import se.sics.cooja.interfaces.*;
import se.sics.cooja.plugins.Visualizer2D; import se.sics.cooja.plugins.Visualizer2D;
@ -315,17 +316,21 @@ public class UDGM extends AbstractRadioMedium {
public Color[] getColorOf(Mote mote) { public Color[] getColorOf(Mote mote) {
Radio moteRadio = mote.getInterfaces().getRadio(); Radio moteRadio = mote.getInterfaces().getRadio();
if (moteRadio == null) { if (moteRadio == null) {
return new Color[] { Color.GRAY }; return new Color[] { Color.BLACK };
} }
if (mote.getState() == Mote.State.DEAD) { if (mote.getState() == Mote.State.DEAD) {
return new Color[] { Color.GRAY }; return new Color[] { Color.BLACK };
} }
if (selectedMote != null && mote == selectedMote) { if (selectedMote != null && mote == selectedMote) {
return new Color[] { Color.CYAN }; return new Color[] { Color.CYAN };
} }
if (moteRadio instanceof ContikiRadio && !((ContikiRadio) moteRadio).isOn()) {
return new Color[] { Color.GRAY };
}
if (moteRadio.isTransmitting()) { if (moteRadio.isTransmitting()) {
return new Color[] { Color.BLUE }; return new Color[] { Color.BLUE };
} }