Hi,
I''m not convinced I''m facing a bug, I was reading some code
and
also reading some threads and finally reached this conclusion, please 
let me know if it''s not clear enough and also if you don''t
agree :
    - The case it shows the flag with iproute is
because it''s using a single flag set.
      That was working on kernels linux <2.1.x. (2.0 etc.)
      Basically the mechanism was :
             ---
               strncpy(ifr.ifr_name, our_device, IFNAMSIZ);
               ioctl(sock, SIOCGIFFLAGS, &ifr);
               ifr.ifr_flags |= IFF_PROMISC;
               ioctl(sock, SIOCSIFFLAGS, &ifr);
            ---
      And only one could set the IFF_PROMISC, because if another process
decided to set it too, then it was cleared...
   - Now, with kernels 2.2 and onwards, we have a different 
implementation of it, there''s a counter of how many promiscuous
requests
have been set, and therefore a new implementation of the code to handle 
it and remove the one promiscuous limitation, that has been called a 
membership. This allows the kernel to have more than one request and 
remove the above problem.
     Today, a process has to request to be part of that "packet
domain"
and use the interface in promiscuous mode, then the counter will know if
there''s another request (so it can handle unsets), and then, if the
process does not need anymore this mode, it will just request to be 
removed to that membership, decreasing the counter.
     The code nowadays is fairly close to this :
        -----
                  struct packet_mreq mr;
                  [.....]
                  memset(&mr,0,sizeof(mr));
                  mr.mr_ifindex = ifr.ifr_ifindex;
                  mr.mr_type = PACKET_MR_PROMISC;
                  setsockopt(sock, SOL_PACKET, PACKET_ADD_MEMBERSHIP, (char
*)&mr, sizeof(mr));
        -----
That would explain why I can''t see it with ip or older ifconfig, any 
call set by ioctl(SIOCGIFFLAGS) can only bee seen by the same call 
family. I''ve checked pcap, and seems to do the right thing by setting
it :
       ----
       setsockopt(3, SOL_PACKET, PACKET_ADD_MEMBERSHIP,
"\\3\\0\\0\\0\\1\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0", 16) = 0
       ----
Hence I can''t see it with neither ip or ifconfig.
  Is there any reason why (ip) is not using a membership check/set 
instead of using ioctl() ?
Radek