2 .\" Copyright (c) 2000, Sun Microsystems, Inc. All Rights Reserved
3 .\" The contents of this file are subject to the terms of the Common Development and Distribution License (the "License"). You may not use this file except in compliance with the License.
4 .\" You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE or http://www.opensolaris.org/os/licensing. See the License for the specific language governing permissions and limitations under the License.
5 .\" When distributing Covered Code, include this CDDL HEADER in each file and include the License file at usr/src/OPENSOLARIS.LICENSE. If applicable, add the following below this CDDL HEADER, with the fields enclosed by brackets "[]" replaced with your own identifying information: Portions Copyright [yyyy] [name of copyright owner]
6 .TH PCI_REPORT_PMCAP 9F "Aug 13, 1999"
8 pci_report_pmcap \- Report Power Management capability of a PCI device
13 #include <sys/sunddi.h>
17 \fBint\fR \fBpci_report_pmcap\fR(\fBdev_info_t *\fR\fIdip\fR, int \fIcap,\fR void *\fIarg\fR);
23 Solaris DDI specific (Solaris DDI)
31 Pointer to the device's \fBdev_info\fR structure
40 Power management capability
49 Argument for the capability
55 Some PCI devices provide power management capabilities in addition to those
56 provided by the PCI Power Management Specification. The
57 \fBpci_report_pmcap()\fR function reports those Power Management capabilities
58 of the PCI device to the framework. Framework supports dynamic changing of the
59 capability by allowing \fBpci_report_pmcap()\fR to be called multiple times.
60 Following are the supported capabilities as indicated by the \fBcap\fR:
63 \fBPCI_PM_IDLESPEED\fR \(em The \fBPCI_PM_IDLESPEED\fR value indicates the
64 lowest PCI clock speed that a device can tolerate when idle, and is applicable
65 only to 33 MHz PCI bus. \fBarg\fR represents the lowest possible idle speed in
66 KHz (1 KHz is 1000 Hz). The integer value representing the speed should be cast
67 to \fB(void *)\fRbefore passing as \fBarg\fR to \fBpci_report_pmcap()\fR.
70 The special values of \fBarg\fR are:
74 \fB\fBPCI_PM_IDLESPEED_ANY\fR\fR
77 The device can tolerate any idle clock speed.
83 \fB\fBPCI_PM_IDLESPEED_NONE\fR\fR
86 The device cannot tolerate slowing down of PCI clock even when idle.
91 If the driver doesn't make this call, \fBPCI_PM_IDLESPEED_NONE\fR is assumed.
92 In this case, one offending device can keep the entire bus from being power
97 The \fBpci_report_pmcap()\fR function returns:
101 \fB\fBDDI_SUCCESS\fR\fR
104 Successful reporting of the capability
110 \fB\fBDDI_FAILURE\fR\fR
113 Failure to report capability because of invalid argument(s)
119 The \fBpci_report_pmcap()\fR function can be called from user, kernel and
124 1. A device driver knows that the device it controls works with any clock
125 between DC and 33 MHz as specified in \fISection 4.2.3.1: Clock Specification
126 \fR of the \fIPCI Bus Specification Revision 2.1\fR. The device driver makes
127 the following call from its \fBattach\fR(9E):
131 if (pci_report_pmcap(dip, PCI_PM_IDLESPEED, PCI_PM_IDLESPEED_ANY) !=
133 cmn_err(CE_WARN, "%s%d: pci_report_pmcap failed\fB\en\fR",
134 ddi_driver_name(dip), ddi_get_instance(dip));
140 2. A device driver controls a 10/100 Mb Ethernet device which runs the device
141 state machine on the chip from the PCI clock. For the device state machine to
142 receive packets at 100 Mb, the PCI clock cannot drop below 4 MHz. The driver
143 makes the following call whenever it negotiates a 100 Mb Ethernet connection:
147 if (pci_report_pmcap(dip, PCI_PM_IDLESPEED, (void *)4000) !=
149 cmn_err(CE_WARN, "%s%d: pci_report_pmcap failed\fB\en\fR",
150 ddi_driver_name(dip), ddi_get_instance(dip));
157 See \fBattributes\fR(5) for descriptions of the following attributes:
165 ATTRIBUTE TYPE ATTRIBUTE VALUE
167 Interface Stability Committed
173 \fIWriting Device Drivers\fR
176 \fIPCI Bus Power Management Interface Specification Version 1.1\fR
179 \fIPCI Bus Specification Revision 2.1\fR