Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 3 May 2005 20:58:04 -0400
From:      Charles Swiger <cswiger@mac.com>
To:        Daniel Valencia <fetrovsky@yahoo.com>
Cc:        freebsd-net@freebsd.org
Subject:   Re: sending MAC packets
Message-ID:  <8253029d47916eaad3e18a1cf92440c9@mac.com>
In-Reply-To: <20050504003321.45603.qmail@web53907.mail.yahoo.com>
References:  <20050504003321.45603.qmail@web53907.mail.yahoo.com>

next in thread | previous in thread | raw e-mail | index | archive | help
On May 3, 2005, at 8:33 PM, Daniel Valencia wrote:
> I'm doing research on network-layer protocols, so I
> need a way to send packets straight into layer 2.  So
> far i've been reffered to raw sockets, but i've read
> the code and i cannot skip header checking and that
> stuff...  Is there a way to interact with the network
> if in a way that I can get network parameters (mtu,
> etc.) and send packets (specify destination mac
> address and payload)??

A non-portable mechanism for doing so is called the BPF, which is used 
by the ISC DHCP software and other programs to create packets at a low 
level.  Another option would be the libnet library, which will use the 
BPF on BSD-derived systems, but will also work on Solaris and other 
platforms which want/need to use other mechanisms to inject packets.

Be aware that the network stack may still alter packets somewhat, 
although less so than trying to go through the raw socket interface.  
This is particularly the case if hardware functionality like TXCSUM is 
enabled; you may not be able to forge the sender MAC address, either, 
although changing the destination MAC addr ought to be fine.

-- 
-Chuck



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?8253029d47916eaad3e18a1cf92440c9>