.\" .\" Copyright (c) 1994 Andrew McRae. All rights reserved. .\" .\" Redistribution and use in source and binary forms, with or without .\" modification, are permitted provided that the following conditions .\" are met: .\" 1. Redistributions of source code must retain the above copyright .\" notice, this list of conditions and the following disclaimer. .\" 2. Redistributions in binary form must reproduce the above copyright .\" notice, this list of conditions and the following disclaimer in the .\" documentation and/or other materials provided with the distribution. .\" 3. The name of the author may not be used to endorse or promote products .\" derived from this software without specific prior written permission. .\" .\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR .\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES .\" OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. .\" IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, .\" INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT .\" NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, .\" DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY .\" THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT .\" (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF .\" THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. .\" .Dd November 1, 1994 .Dt PCCARD 8 .Os FreeBSD .Sh NAME .Nm pccardd .Nd PC-CARD (PCMCIA) management daemon .Sh SYNOPSIS .Nm pccardd .Op Fl d .Op Fl v .Op Fl I .Op Fl i Ar IRQ .Op Fl s Ar pathname .Op Fl f Ar configfile .Sh DESCRIPTION .Nm Pccardd is normally started at boot time, and manages the insertion and removal of PC-CARD cards. .Pp When started, .Nm pccardd will read the configuration file (default name .Pa /etc/pccard.conf ) and scans the available PC-CARD slots for cards. .Nm Pccardd then waits for .Em "card events" , such as the insertion of a new card or the removal of a card. .Pp When a card is inserted, the following actions are taken: .Bl -enum .It The kernel driver detects the card insertion and applies power to the card. .It .Nm Pccardd reads the .Em CIS data from the attribute memory of the card, and uses the manufacturer name and card version to match the card description in the configuration file. .It Once matched, a driver is allocated. .It Once a free driver and device instance is located, .Nm pccardd will (if required) allocate resources such as an ISA memory block and Input/Output ports from a common pool. .It The PC-CARD slot is configured with the I/O and memory contexts allocated, and the kernel driver is attached to this card. .It If the attach succeeds, then specific shell commands may be executed to configure the device, such as .Xr ifconfig 8 to set up a network interface. Separate commands may be specified for each card, driver or device, and are executed in that order. .El .Pp When .Nm pccardd detects that a card has been removed, the following sequence occurs: .Bl -enum .It The shell commands associated with card removal are executed. These are intended to reset any device associated with the removed card. Separate commands may exist for card, driver and device instances. .It The PC-CARD slot resources are freed. .El .Pp Once a card/driver instance is configured, the resources bound to that instance are remembered, and if the card is removed and reinserted, the same driver is allocated. The primary reason is that once a driver is associated with a card, the driver's .Fn probe routine has been called, and this usually causes driver specific data areas to be initialised with the I/O ports or memory resources allocated to the card. Most drivers are not designed to be disassociated from the hardware and then reassociated with different parameters. This will change significantly when loadable kernel modules are supported. .Pp The start options understood by .Nm pccardd are: .Bl -tag -width Ds .It Fl d Do not run as a daemon, but run in the foreground and display error messages. .It Fl v After reading the configuration file, print out a summary of it. .It Fl I By default, .Xr pccardd 8 will query the kernel for the list of irq-s that are not allocated by attached kernel drivers. .Fl I flag overrides the kernel IRQ table by "irq" line in .Pa /etc/pccard.conf. NOTE: "irq" line in .Pa /etc/pccard.conf is deprecated. The use of this option is DISCOURAGED. .It Fl i Ar IRQ Supress the use of .Ar IRQ , even if the kernel says that .Ar IRQ is not occupied. .Fl i Ar IRQ has the same functionality as "ignirq" line in .Xr pccard.conf 5 . .It Fl s Ar pathname Specify the pathname of socket. Default is .Pa /var/tmp/.pccard. .It Fl f Ar configfile Specifies a different configuration file to be used in placed of the default file .Pa /etc/pccard.conf. The file format is detailed in .Xr pccard.conf 5 , and lists the PC-CARD cards recognized by .Nm pccardd , and the kernel drivers and devices that are used to interface to the card. .Pp .Sh FILES .Bl -tag -width /etc/pccard.conf -compact .It Pa /etc/pccard.conf .It Pa /var/tmp/.xpccard .El .Sh SEE ALSO .Xr pccard.conf 5 .Xr pccardc 8 .Xr ifconfig 8 .Sh AUTHOR Developed by Andrew McRae (andrew@mega.com.au). .Sh BUGS .Nm Pccardd can set up card parameters, but cannot guarantee that particular drivers can work with the card. .Pp Since .Nm FreeBSD does not currently support loadable kernel modules, any .Em irq specifications in the configuration file must match the .Nm config entry for the kernel. .Pp Removing cards may cause problems if system resources have been associated with the card, such as network mounted filesystems.