questions about 4.3BSD struct ifnet.if_addrlist

Michael A. Ziober mziober at trocadero.ics.uci.edu
Tue Jan 29 05:20:10 AEST 1991


Hi,
    This is my first posting to these groups (I don't think my
previous attempt made it off campus).  I hope that someone out there
can answer a few questions for me.

    I am working on a project which requires connecting IP to a new
network interface. In order to achieve this we are using the following
scheme:
    - We have a pseudo-device (we call it rawpacket) that receives an
      IP-packet and sends it to a user daemon by calling raw_input()
      (using raw socket).
    - The user daemon then send the packet to a device driver that
      handles placing the packet on the network.
    - Incoming packets are picked up from the device driver by the
      daemon which writes them on the raw socket.
    - The socket's pr_output() routine, rawpacket_output(), calls
      IF_ENQUEUE to pass the data up to IP.

    When implementing the pseudo-device, we had some questions about
the Network interface data structures (described on page 316 of the
book "The Design and Implementation of the 4.3BSD UNIX Operating
System"). The questions are related to the address list field. I will
put the questions in an itemized form.

    - Does my procedure rpattach() (When attaching the pseudo-device
      to the system) initialize this address list?
    - If so, what should it be? Should it be initialized to NULL?
    - If not, who should do the initialization?
    - When using this field in the structure (for example to send a
      packet) how do I find the appropriate address to use from this
      list?
    - In the routine rpioctl() (for the SIOCSIFADDR and SIOCSDSTADDR
      commands), does it add new address to the address list?
    - Does it replace any existing entries by matching address families?

    In summary, we need to know how this field address list is handled.
Who initilizes it? Who modifies it? How is it done? How it it maintained?
Are there any useful support routines?

-Michael Ziober



More information about the Comp.unix.internals mailing list