Re: Fighting for the power.

From: Paul B. Mahol <onemda_at_gmail.com>
Date: Fri, 8 May 2009 10:34:52 +0000
On 5/7/09, M. Warner Losh <imp_at_bsdimp.com> wrote:
> In message: <3a142e750905040240g58152e69p6fcb797a5e026426_at_mail.gmail.com>
>             "Paul B. Mahol" <onemda_at_gmail.com> writes:
> : On 5/4/09, Alexander Motin <mav_at_freebsd.org> wrote:
> : > 2. PCI devices
> : > PCI bus provides method to control device power. For example, I have
> : > completely no use for my FireWire controller and most of time - EHCI USB
> : > controller. Disabling them allows me to save about 3W of power. To
> : > disable all unneeded PCI devices you should build kernel without their
> : > drivers and add to loader.conf:
> : > hw.pci.do_power_nodriver=3
> : > To enable devices back all you need to do is just load their drivers as
> : > modules.
> :
> : Unloading modules doesnt put them back into into D3 state.
> : You are forced to load some another module again to put wanted device
> : into D3 state.
>
> It should.  If it isn't, that's a bug.

It's a bug.

On machine resume(pci_resume), pci_cfg_restore() is called causing D3 -> D0 for
all devices(including not attached ones).
Unloading module/detaching device doesn't call pci_cfg_save.

Should device_detach routine be used or new one like
pci_driver_removed() implemented?

-- 
Paul
Received on Fri May 08 2009 - 08:34:54 UTC

This archive was generated by hypermail 2.4.0 : Wed May 19 2021 - 11:39:47 UTC