All of lore.kernel.org
 help / color / mirror / Atom feed
* IP packets routing
@ 2003-12-25  3:26 Dmytro Bablinyuk
  0 siblings, 0 replies; only message in thread
From: Dmytro Bablinyuk @ 2003-12-25  3:26 UTC (permalink / raw)
  To: dheeraj, linux-kernel

There is a little code that sends an IP packet from the kernel (see at 
the bottom)

The problem is that I have a errors (kernel 2.4.22):

dstip = ac198c13, 0
eth0
h_h_len :: 4
Allocated 48 bytes
Length :: 12
ip_finish_output: bad unowned skb(nf_debug=10) = c0794120: POST_ROUTING
skb: pf=2 (unowned) dev=eth0 len=32
PROTO=1 172.25.206.4:0 172.25.140.19:0 L=32 S=0x00 I=0 F=0x4000 T=128
retval :: 0

Could anybody please give me a hand on how to get around of that problem 
and to send IP packets out for 2.4.22 kernel.

Thank you

_IFCONFIG_OUTPUT_

/home # ifconfig
eth0      Link encap:Ethernet  HWaddr 00:0D:CA:01:00:04
          inet addr:172.25.206.4  Bcast:172.25.255.255  Mask:255.255.0.0
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:1375 errors:0 dropped:0 overruns:0 frame:0
          TX packets:814 errors:0 dropped:0 overruns:0 carrier:0
          collisions:1 txqueuelen:100
          RX bytes:1055067 (1.0 MiB)  TX bytes:118312 (115.5 KiB)
          Base address:0xe00
...


__CODE_THAT_SENDS_THE_PACKET__

  struct curr_lbts {
    int i;
  } curr_lbts;
  ...// __declaration__

  struct rt_key key = {.dst = packet->data.dstip, .src=packet->data.srcip};
  total_len = sizeof(struct iphdr) + sizeof(struct icmphdr) + 
sizeof(curr_lbts);

  retval = ip_route_output_key(&rt, &key);
  printk("dstip = %x, %d\n", packet->data.dstip, retval);
  printk("%s\n", (rt->u.dst.dev)->name);

  hh_len =  ((rt->u.dst.dev->hard_header_len + 15) & ~15);
 
  printk ("h_h_len :: %d \n", sizeof(curr_lbts));
  skb = dev_alloc_skb(total_len + hh_len);
  printk("Allocated %d bytes \n", total_len + hh_len);
  skb->priority = 0;
  skb->dst = dst_clone(&rt->u.dst);
  skb_reserve(skb, hh_len);
       
  skb->nh.iph = iph = (struct iphdr *) skb_put(skb,
                                               (sizeof(struct iphdr) +
                                                sizeof(struct icmphdr)));
  iph->ihl = 5;
  iph->version = 4;
  iph->tos = 0x00;
  iph->tot_len = htons(total_len);
  iph->id = 0;
  iph->frag_off = htons(IP_DF);
  iph->ttl = 128;
  iph->protocol = IPPROTO_ICMP;
  iph->saddr = rt->rt_src;
  iph->daddr = rt->rt_dst;
  iph->check = 0;
  iph->check = ip_fast_csum((unsigned char*) iph, iph->ihl);
 
  skb->h.icmph = icmph = (struct icmphdr *)((char *)iph + iph->ihl * 4);
  icmph->type = ICMP_ECHO;
  icmph->code = code;
  icmph->un.echo.id = 0x42;
  icmph->un.echo.sequence = 0x42;
  icmph->checksum = 0x0000;
  printk("Length :: %d \n", total_len - sizeof(struct iphdr));
 
  data = (unsigned char*) icmph + sizeof(struct icmphdr) ;
  memcpy(skb_put(skb, sizeof(curr_lbts)), &curr_lbts, sizeof(curr_lbts));
  icmph->checksum = ip_compute_csum((unsigned char *)icmph,
                                    total_len - (iph->ihl * 4));
 
  retval = rt->u.dst.output(skb);
  printk("retval :: %d \n", retval);



^ permalink raw reply	[flat|nested] only message in thread

only message in thread, other threads:[~2003-12-25  3:26 UTC | newest]

Thread overview: (only message) (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2003-12-25  3:26 IP packets routing Dmytro Bablinyuk

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.