NAME
ethersubr, 
ether_ifattach,
  
ether_addmulti, 
ether_delmulti,
  
ETHER_FIRST_MULTI, 
ETHER_NEXT_MULTI,
  
ETHER_IS_MULTICAST, 
fddi_ifattach,
  
fddi_addmulti, 
fddi_delmulti —
  
Ethernet and FDDI driver support functions and macros
SYNOPSIS
#include <net/if_ether.h>
void
ether_ifattach(
struct
  ifnet *ifp, 
uint8_t
  *lla);
int
ether_addmulti(
const
  struct sockaddr *sa, 
struct
  ethercom *ec);
int
ether_delmulti(
const
  struct sockaddr *sa, 
struct
  ethercom *ec);
void
ETHER_FIRST_MULTI(
struct
  ether_multistep step,
  
struct ethercom *ec,
  
struct ether_multi *enm);
void
ETHER_NEXT_MULTI(
struct
  ether_multistep step,
  
struct ether_multi *enm);
int
ETHER_IS_MULTICAST(
uint8_t
  *addr);
#include <net/if_fddi.h>
void
fddi_ifattach(
struct
  ifnet *ifp, 
uint8_t
  *lla);
int
fddi_addmulti(
const
  struct sockaddr *sa, 
struct
  ethercom *ec);
int
fddi_delmulti(
const
  struct sockaddr *sa, 
struct
  ethercom *ec);
DESCRIPTION
The 
ethersubr functions provide the interface between the
  
ethersubr module and the network drivers which need Ethernet
  support. Such drivers must request the 
ether attribute
  in their 
files declaration and call the appropriate
  functions as specified below.
FDDI drivers must request the "fddi" attribute in their
  "files" declaration and call the functions tagged with
  "fddi_" or "FDDI_" instead, where different. Some macros
  are shared.
Note that you also need the 
arp(9)
  stuff to support IPv4 on your hardware.
  -  
-  
- ether_ifattach(ifp,
    lla)
- Perform the device-independent, but Ethernet-specific
      initialization of the interface pointed to by ifp.
    
    Among other duties, this function creates a record for the link level
      address in the interface's address list and records the link level address
      pointed to by lla there. Drivers can initialize the
      link level address by themselves by calling the function with
      lla as NULLand calling
      if_set_sadl().
    
    This function must be called from the driver's attach function.
-  
-  
- fddi_ifattach(ifp,
    lla)
- Corresponding function for FDDI devices.
-  
-  
- ether_addmulti(sa,
    ec)
-  
- ether_delmulti(sa,
    ec)
- Add (ether_addmulti()) or delete
      (ether_delmulti()) the address described by the
      sa pointer to the Ethernet multicast list belonging
      to ec.
    
    These functions must be called from the driver's ioctl function to handle
      SIOCADDMULTIandSIOCDELMULTIrequests. If these returnENETRESET, the hardware multicast filter must be
      reinitialized.
    
    These functions acceptAF_UNSPECaddresses, which
      are interpreted as Ethernet addresses, orAF_INETaddresses. In the latter case,INADDR_ANYis
      mapped to a range describing all the Ethernet address space reserved for
      IPv4 multicast addresses.
    
    The ether_addmulti() returnsEAFNOSUPPORTif an unsupported address family is
      specified,EINVALif a non-multicast address is
      specified, orENETRESETif the multicast list
      really changed and the driver should synchronize its hardware filter with
      it.
    
    The ether_delmulti() returns, in addition to the above
      errors,ENXIOif the specified address can't be
      found in the list of multicast addresses.
-  
-  
- fddi_addmulti(sa,
    ec)
-  
- fddi_delmulti(sa,
    ec)
- Corresponding functions for FDDI devices.
-  
-  
- ETHER_NEXT_MULTI(step,
    enm)
- A macro to step through all of the
      ether_multi records, one at a time. The current position
      is remembered in step, which the caller must
      provide.
-  
-  
- ETHER_FIRST_MULTI(step,
    ec, enm)
- A macro that must be called to initialize
      step and get the first record. Both macros return a
      NULLenm when there are no
      remaining records.
-  
-  
- ETHER_IS_MULTICAST(addr)
- A macro that returns 1, if addr
      points to an Ethernet/FDDI multicast (or broadcast) address.
CODE REFERENCES
Ethernet support functions are declared in
  
<net/if_ether.h> and defined (if not
  implemented as macro) in 
sys/net/if_ethersubr.c.
FDDI support functions are declared in
  
<net/if_fddi.h> and defined (if not
  implemented as macro) in 
sys/net/if_fddisubr.c.
SEE ALSO
arp(9)
HISTORY
Rewritten to attach to the new ARP system in 
NetBSD 1.3.
AUTHORS
UCB CSRG (original implementation)
Ignatios Souvatzis (support for new ARP system)