GLD_MAC_INFO(9S) Data Structures for Drivers GLD_MAC_INFO(9S)
NAME
gld_mac_info - Generic LAN Driver MAC info data structure
SYNOPSIS
#include <sys/gld.h>
INTERFACE LEVEL
illumos architecture specific (illumos DDI).
DESCRIPTION
The Generic LAN Driver (GLD) Media Access Control (MAC) information
(
gld_mac_info) structure is the main data interface between the
device-specific driver and GLD. It contains data required by GLD and
a pointer to an optional additional driver-specific information
structure.
The
gld_mac_info structure should be allocated using
gld_mac_alloc() and deallocated using
gld_mac_free(). Drivers can make no assumptions
about the length of this structure, which might be different in
different releases of illumos and/or GLD. Structure members private
to GLD, not documented here, should not be set or read by the device-
specific driver.
STRUCTURE MEMBERS
caddr_t gldm_private; /* Driver private data */
int (*gldm_reset)(); /* Reset device */
int (*gldm_start)(); /* Start device */
int (*gldm_stop)(); /* Stop device */
int (*gldm_set_mac_addr)(); /* Set device phys addr */
int (*gldm_set_multicast)(); /* Set/delete */
/* multicast address */
int (*gldm_set_promiscuous)();
/* Set/reset promiscuous */
/* mode*/
int (*gldm_send)(); /* Transmit routine */
u_int (*gldm_intr)(); /* Interrupt handler */
int (*gldm_get_stats)(); /* Get device statistics */
int (*gldm_ioctl)(); /* Driver-specific ioctls */
char *gldm_ident; /* Driver identity string */
uint32_t gldm_type; /* Device type */
uint32_t gldm_minpkt; /* Minimum packet size */
/* accepted by driver */
uint32_t gldm_maxpkt; /* Maximum packet size */
/* accepted by driver */
uint32_t gldm_addrlen; /* Physical address */
/* length */
int32_t gldm_saplen; /* SAP length for */
/* DL_INFO_ACK */
unsigned char *gldm_broadcast_addr; /* Physical broadcast */
/* addr */
unsigned char *gldm_vendor_addr; /* Factory MAC address */
t_uscalar_t gldm_ppa; /* Physical Point of */
/* Attachment (PPA) number */
dev_info_t *gldm_devinfo; /* Pointer to device's */
/* dev_info node */
ddi_iblock_cookie_tgldm_cookie; /* Device's interrupt */
/* block cookie */
int gldm_margin /* accepted data beyond */
/*gldm_maxpkt */
uint32_t gldm_capabilities; /* Device capabilities */
Below is a description of the members of the
gld_mac_info structure
that are visible to the device driver.
gldm_private This structure member is private to the device-
specific driver and is not used or modified by GLD.
Conventionally, this is used as a pointer to private
data, pointing to a driver-defined and driver-
allocated per-instance data structure.
The following group of structure members must be set by the driver
before calling
gld_register(), and should not thereafter be modified
by the driver;
gld_register() can use or cache the values of some of
these structure members, so changes made by the driver after calling
gld_register() might cause unpredicted results.
gldm_reset Pointer to driver entry point; see
gld(9E).
gldm_start Pointer to driver entry point; see
gld(9E).
gldm_stop Pointer to driver entry point; see
gld(9E).
gldm_set_mac_addr Pointer to driver entry point; see
gld(9E).
gldm_set_multicast Pointer to driver entry point; see
gld(9E).
gldm_set_promiscuous Pointer to driver entry point; see
gld(9E).
gldm_send Pointer to driver entry point; see
gld(9E).
gldm_intr Pointer to driver entry point; see
gld(9E).
gldm_get_stats Pointer to driver entry point; see
gld(9E).
gldm_ioctl Pointer to driver entry point; can be
NULL;
see
gld(9E).
gldm_ident Pointer to a string containing a short
description of the device. It is used to
identify the device in system messages.
gldm_type The type of device the driver handles. The
values currently supported by GLD are
DL_ETHER (IEEE 802.3 and Ethernet Bus),
DL_TPR (IEEE 802.5 Token Passing Ring), and
DL_FDDI (ISO 9314-2 Fibre Distributed Data
Interface). This structure member must be
correctly set for GLD to function properly.
Support for the DL_TPR and DL_FDDI media
types is obsolete and may be removed in a
future release of illumos.
gldm_minpkt Minimum
Service Data Unit size -- the minimum
packet size, not including the MAC header,
that the device will transmit. This can be
zero if the device-specific driver can handle
any required padding.
gldm_maxpkt Maximum
Service Data Unit size -- the maximum
size of packet, not including the MAC header,
that can be transmitted by the device. For
Ethernet, this number is 1500.
gldm_addrlen The length in bytes of physical addresses
handled by the device. For Ethernet, Token
Ring, and FDDI, the value of this structure
member should be 6.
gldm_saplen The length in bytes of the Service Access
Point (SAP) address used by the driver. For
GLD-based drivers, this should always be set
to -2, to indicate that two-byte SAP values
are supported and that the SAP appears
after the physical address in a DLSAP address. See
the description under ``Message DL_INFO_ACK''
in the DLPI specification for more details.
gldm_broadcast_addr Pointer to an array of bytes of length
gldm_addrlen containing the broadcast address
to be used for transmit. The driver must
allocate space to hold the broadcast address,
fill it in with the appropriate value, and
set
gldm_broadcast_addr to point at it. For
Ethernet, Token Ring, and FDDI, the broadcast
address is normally 0xFF-FF-FF-FF-FF-FF.
gldm_vendor_addr Pointer to an array of bytes of length
gldm_addrlen containing the vendor-provided
network physical address of the device. The
driver must allocate space to hold the
address, fill it in with information read
from the device, and set
gldm_vendor_addr to
point at it.
gldm_ppa The Physical Point of Attachment (PPA) number
for this instance of the device. Normally
this should be set to the instance number,
returned from
ddi_get_instance(9F).
gldm_devinfo Pointer to the
dev_info node for this device.
gldm_cookie The interrupt block cookie returned by
ddi_get_iblock_cookie(9F),
ddi_add_intr(9F),
ddi_get_soft_iblock_cookie(9F), or
ddi_add_softintr(9F). This must correspond to
the device's receive interrupt, from which
gld_recv() is called.
gldm_margin Drivers set this value to the amount of data
in bytes that the device can transmit beyond
gldm_maxpkt. For example, if an Ethernet
device can handle packets whose payload
section is no greater than 1522 bytes and the
gldm_maxpkt is set to 1500 (as is typical for
Ethernet), then
gldm_margin is set to 22. The
registered
gldm_margin value is reported in
acknowledgements of the DLIOCMARGININFO ioctl
(see
dlpi(4P)).
gldm_capabilities Bit-field of device capabilities. If the
device is capable of reporting media link
state, the GLD_CAP_LINKSTATE bit should be
set.
SEE ALSO
gld(4D),
dlpi(4P),
attach(9E),
gld(9E),
ddi_add_intr(9F),
gld(9F),
gld_stats(9S) Writing Device Drivers June 7, 2004 GLD_MAC_INFO(9S)