Re: [PATCH] [RFC] firewire: Add ohci1394 PCI runtime power management support

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Matthew Garrett wrote:
> On Wed, Jan 13, 2010 at 01:56:15AM +0100, Stefan Richter wrote:
>> Matthew Garrett wrote:
>>> +	for (i = 0; i < OHCI_LOOP_COUNT; i++) {
>>> +		*val = reg_read(ohci, OHCI1394_PhyControl);
>>> +		if (*val & OHCI1394_PhyControl_ReadDone)
>>> +			break;
>>> +		mdelay(1);
>>> +	}
>> Gone is the msleep, here comes the mdelay.  I suspect all that can be
>> implemented in a non-atomic context, can't it?  I.e. tasklet ->
>> worklet...  May possibly require to convert the bus reset tasklet to a
>> worklet too, which may have a few benefits on its own right.
> 
> Yeah, that might well be a bonus. The phy accesses should only be at 
> startup or in response to a bus reset or cable connection state change, 
> so I wouldn't have thought that there'd be any noticable performance 
> impact. I'll look at changing it in a followup patch.

Bus resets may happen for various reasons.  Ongoing isochronous
transmissions are supposed to continue after a bus reset and self
identification phase as seamlessly as possible.  Especially with an eye
on audio streams, new latency sources should be avoided.  (People who
are into studio audio or live audio will avoid causes for bus resets
during sessions though.)

>> Furthermore, these polling loops --- at least the ones after a
>> reg_write(..., OHCI1394_PhyControl_Read(..)) --- could then be replaced
>> by an interrupt driven mechanism.  (Except in those usages of
>> ohci_update_phy_reg() when we do not have interrupts enabled.)
> 
> Oh, ok - I hadn't realised there was an interrupt to indicate that.

Might turn out too awkward though due to the interrupts off situation in
ohci_enable().

[...]
>>> +		  OHCI1394_PhyControl_Write(addr, r));
>>> +
>>> +	for (i = 0; i < OHCI_LOOP_COUNT; i++) {
>>> +		r = reg_read(ohci, OHCI1394_PhyControl);
>>> +		if (!(r & OHCI1394_PhyControl_WriteDone))
>>> +			break;
>>> +	}
>> Forgot an mdelay?
> 
> I wondered about that, but there wasn't one in the ieee1394 code. 
> Presumably the register reads take long enough that it settles within 
> the loop count?

Hmm, drivers/ieee1394/ohci1394.c::get_phy_reg and set_phy_reg both have
an mdelay in their poll loops.  I don't see other OHCI1394_PhyControl
accesses.

[...]
>> [BTW, some cards may actually have a second PHY hardwired to the PHY
>> which is attached to the link.  For example, Mac Pro have a second PHY
>> for the front panel ports.  But your approach is unable to figure that
>> out either.  And it doesn't matter because battery powered devices do
>> not have more than one PHY per link.]
> 
> Hrm. That's potentially a problem. Will this always show up as a 
> connection being present on the first PHY?

Yes.  It is indistinguishable from an externally plugged-in hub or
repeater, or some kinds of external node whose link is powered down.

> If so it'll just effectively 
> disable the power management, which isn't ideal but at least doesn't 
> break anything.

Yep.

>>> +
>>> +	if (ohci_read_phy_reg(card, 2, &val))
>>> +		return -EBUSY;
>> Since its caller does not check for error return,
>> ohci_configure_wakeup() can just return void.
> 
> Hm. Should probably actually check the return value instead.

Should it?  I understood that this just enables or disables runtime PM
capability for this ohci instance, without a need for further error
handling.
-- 
Stefan Richter
-=====-==-=- ---= -==-=
http://arcgraph.de/sr/
--
To unsubscribe from this list: send the line "unsubscribe linux-acpi" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux IBM ACPI]     [Linux Power Management]     [Linux Kernel]     [Linux Laptop]     [Kernel Newbies]     [Share Photos]     [Security]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Samba]     [Video 4 Linux]     [Device Mapper]     [Linux Resources]

  Powered by Linux