command error_t AMSend.send[am_id_t id](am_addr_t addr,
message_t* amsg,
uint8_t len) {
+ error_t err;
tossim_header_t* header = getHeader(amsg);
+ dbg("AM", "AM: Sending packet (id=%hhu, len=%hhu) to %hu\n", id, len, addr);
header->type = id;
- header->addr = addr;
+ header->dest = addr;
+ header->src = call AMPacket.address();
header->length = len;
- return call Model.send((int)addr, amsg, len + sizeof(tossim_header_t));
+ err = call Model.send((int)addr, amsg, len + sizeof(tossim_header_t));
+ return err;
}
command error_t AMSend.cancel[am_id_t id](message_t* msg) {
event void Model.receive(message_t* msg) {
uint8_t len;
void* payload;
-
+
memcpy(bufferPointer, msg, sizeof(message_t));
payload = call Packet.getPayload(bufferPointer, &len);
event bool Model.shouldAck(message_t* msg) {
tossim_header_t* header = getHeader(msg);
- if (header->addr == call amAddress()) {
- dbg("Acks", "addressed to me so ack it,");
+ if (header->dest == call amAddress()) {
+ dbg("Acks", "Received packet addressed to me so ack it\n");
return TRUE;
}
return FALSE;
command am_addr_t AMPacket.destination(message_t* amsg) {
tossim_header_t* header = getHeader(amsg);
- return header->addr;
+ return header->dest;
}
command void AMPacket.setDestination(message_t* amsg, am_addr_t addr) {
tossim_header_t* header = getHeader(amsg);
- header->addr = addr;
+ header->dest = addr;
+ }
+
+ command am_addr_t AMPacket.source(message_t* amsg) {
+ tossim_header_t* header = getHeader(amsg);
+ return header->src;
}
+ command void AMPacket.setSource(message_t* amsg, am_addr_t addr) {
+ tossim_header_t* header = getHeader(amsg);
+ header->src = addr;
+ }
+
command bool AMPacket.isForMe(message_t* amsg) {
return (call AMPacket.destination(amsg) == call AMPacket.address() ||
call AMPacket.destination(amsg) == AM_BROADCAST_ADDR);
return msg->data;
}
- //command am_group_t AMPacket.group(message_t* amsg) {
- // return amsg->header.group;
- //}
+ command am_group_t AMPacket.group(message_t* amsg) {
+ tossim_header_t* header = getHeader(amsg);
+ return header->group;
+ }
+ command void AMPacket.setGroup(message_t* msg, am_group_t group) {
+ tossim_header_t* header = getHeader(msg);
+ header->group = group;
+ }
+
+ command am_group_t AMPacket.localGroup() {
+ return TOS_AM_GROUP;
+ }
+
default event message_t* Receive.receive[am_id_t id](message_t* msg, void* payload, uint8_t len) {
return msg;
}