For using promiscuous mode in AODV NS2
Intro:-
          In Promiscuous mode each node in the network listens the packets transmitted by its own neighbor nodes. 
          In NS-2, some time we have to calculate the 
packet drops or
 analyze the process. For the same we need to set the network to operate
 in promiscuous mode. Here, I am going to explain how we can set our 
wireless network in promiscuous mode with AODV as Routing protocol using
 NS2 simulator.
1) We need to modify in total 3 files, so it's good to take a backup of it.
    Files are:
- ns-allinone-2.34/ns-2.34/aodv/aodv.cc
- ns-allinone-2.34/ns-2.34/aodv/aodv.h
- ns-allinone-2.34/ns-2.34/tcl/lib/ns-mobilenode.tcl
2) Open the file ns-allinone-2.34/ns-2.34/aodv/aodv.h in your favorite editor
    and make the changes as shown in blue color.
  #include <mac.h>
  class AODV: public Tap, public Agent {
  public:
  void tap(const Packet *p);
  ......
  protected:
  Mac *mac_; 
  ......
 }
 
3) Open the file ns-allinone-2.34/ns-2.34/aodv/aodv.cc and make the changes as  
    shown in blue color.
int
AODV::command(int argc, const char* const * argv) {
......
else if(argc == 3) {
......
else if (strcmp(argv[1], "install-tap") == 0) {
mac_ = (Mac*)TclObject::lookup(argv[2]);
if (mac_ == 0) return TCL_ERROR;
mac_->installTap(this);
return TCL_OK;
}
} 
return Agent::command(argc, argv);
}
void
                AODV::tap(const Packet *p) {
// put your code here
}  
   
4) Open the file ns-allinone-2.34/ns-2.34/tcl/lib/ns-mobilenode.tcl and make the  
    changes as shown in blue color.
Node/MobileNode instproc add-target { agent port } {
$self instvar dmux_ imep_ toraDebug_ mac_
......
# Special processing for AODV
                    set aodvonly [string first "AODV" [$agent info class]] 
  if {$aodvonly != -1 } {
  $agent if-queue [$self set ifq_(0)] ; # ifq between LL and MAC
      $agent install-tap $mac_(0)
......
                  
                  }
Explanation:-
         The above procedure will put all the nodes in the wireless network in promiscuous mode. If a node A wants to listen the packets from a node B in promiscuous mode to check whether to check B is forwarding the packets which are sent by A to B or not we can write the code in function tap()
5) To simulate a node as a malicious node in AODV see below (not yours but blogs)
Many people have asked me how to implement malicious drop in AODV. I 
have decided to write simple code for adding malicious node in AODV ( or
 in any routing protocol).
First you need to modify aodv.cc and aodv.h files.  In aodv.h after
| 2 | classAODV: publicAgent { | 
 
| 7 | doublePerHopTime(aodv_rt_entry *rt); | 
 
 
 
add following line
With this variable we are trying to define if the node is malicious or not. In 
aodv.cc after
| 4 | AODV::AODV(nsaddr_t id) : Agent(PT_AODV),btimer(this), htimer(this), ntimer(this), rtimer(this), lrtimer(this), rqueue() { | 
 
 
 
add following line
The above code is needed to initialize, and all nodes are initially 
not malicious.  Then we will write a code to catch which node is set as 
malicious. In 
aodv.cc after
| 2 |   Tcl& tcl = Tcl::instance(); | 
 
| 4 |     if(strncasecmp(argv[1], "id", 2) == 0) { | 
 
| 5 |       tcl.resultf("%d", index); | 
 
 
 
add following line
| 1 | if(strcmp(argv[1], "hacker") == 0) { | 
 
 
 
Now we will do some work in TCL to set a malicious node. Using script in 
my post , we add following line to set 
node 5 as malicious node.
| 1 | $ns at 0.0"[$mnode_(5) set ragent_] hacker" | 
 
 
 
You may add this line after
| 1 | for{seti 0} {$i < $val(nn)} { incr i } { | 
 
| 2 | $ns initial_node_pos $mnode_($i) 10 | 
 
 
 
Alright, we have set malicious node but we did not tell malicious node what to do. As it is known, 
rt_resolve(Packet *p)
 function is used to select next hop node when routing data packets. So,
 we tell malicious node just drop any packet when it receives. To do 
that after
| 5 | AODV::rt_resolve(Packet *p) { | 
 
| 6 | structhdr_cmn *ch = HDR_CMN(p); | 
 
| 7 | structhdr_ip *ih = HDR_IP(p); | 
 
 
 
We add a few lines
| 2 |  if(malicious == true) { | 
 
| 3 |     drop(p, DROP_RTR_ROUTE_LOOP); | 
 
 
 
And implementing malicious node is done. I hope the post will be helpful to design your secure routing protocol.
P.S. Guys please don’t ask me c/c++ questions,