All of lore.kernel.org
 help / color / mirror / Atom feed
* Re: [linux-usb-devel] Re: device model documentation 2/3
@ 2002-06-06 19:15 David Brownell
  2002-06-06 19:24 ` Pavel Machek
  2002-06-06 20:00 ` Oliver Neukum
  0 siblings, 2 replies; 6+ messages in thread
From: David Brownell @ 2002-06-06 19:15 UTC (permalink / raw)
  To: linux-hotplug

 > > All calls are made with interrupts enabled, except for the
 > > SUSPEND_POWER_DOWN level.
 >
 > This is a slight problem for USB. We need to switch on interupts
 > to send a message to the device.

For example, to enable remote wakeup (whenever we start to
support that).  I understand that a lot of USB hardware does
not work reliably if that's enabled much before a USB suspend.
If only SUSPEND_POWER_DOWN notification was delivered, that'd
have to be enabled at that point.


>>Why would you allocate memory on a resume transition? 

One example comes to mind.  There are systems that, rather
than supporting a "suspend to reduced power", are actually
set up so they "suspend to no power".  Or in short, they
power off in cases when other systems don't ... saving even
more power.  (I think that is the difference between D3hot
and D3cold, or somesuch, but there are so many different
names for the various states and contexts that I've been
known to get them wrong.)

In that case, a "resume" needs to be able to completely
re-initialize the hardware.  As a rule, that's going to
want to be able to allocate memory.

... though FWIW I missed seeing anything that showed how
those API summaries would place constraints on allocating
memory, so I didn't assume there could be any.


What did seem to be missing was anything saying whether
those device methods would be called in_interrupt() or
whether instead they could sleep.  I'd hope all of them
would be specified to allow blocking as needed, like their
current analogues in PCI and USB.

Also, there was some mention not that long ago about
desirability of some kind of device abort() call.  That
would differ from the current remove() call because an
abort() would pass the explicit knowledge that hardware
was gone ... unplugged before driver shutdown, for one
example.  That could also be achieved using some kind
of mode parameter to remove() -- perhaps three values,
saying whether the hardware was present, removed, or
in some indeterminate state.

- Dave


_______________________________________________________________

Don't miss the 2002 Sprint PCS Application Developer's Conference
August 25-28 in Las Vegas -- http://devcon.sprintpcs.com/adp/index.cfm

_______________________________________________
Linux-hotplug-devel mailing list  http://linux-hotplug.sourceforge.net
Linux-hotplug-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/linux-hotplug-devel

^ permalink raw reply	[flat|nested] 6+ messages in thread
* Re: device model documentation 2/3
@ 2002-06-05 12:51 Oliver Neukum
  2002-06-05 19:11 ` Patrick Mochel
  0 siblings, 1 reply; 6+ messages in thread
From: Oliver Neukum @ 2002-06-05 12:51 UTC (permalink / raw)
  To: Patrick Mochel, linux-kernel; +Cc: linux-hotplug-devel, linux-usb-devel


> SUSPEND_DISABLE tells the device to stop I/O transactions. When it
> stops transactions, or what it should do with unfinished transactions
> is a policy of the driver. After this call, the driver should not
> accept any other I/O requests.

Does this mean that memory allocations in the suspend/resume
implementations must be made with GFP_NOIO respectively
GFP_ATOMIC ?
It would seem so.

	Regards
		Oliver

^ permalink raw reply	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2002-06-06 20:12 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2002-06-06 19:15 [linux-usb-devel] Re: device model documentation 2/3 David Brownell
2002-06-06 19:24 ` Pavel Machek
2002-06-06 20:00 ` Oliver Neukum
  -- strict thread matches above, loose matches on Subject: below --
2002-06-05 12:51 Oliver Neukum
2002-06-05 19:11 ` Patrick Mochel
2002-06-02  4:49   ` Pavel Machek
2002-06-06 19:15     ` [linux-usb-devel] " David Brownell
2002-06-06 19:24       ` Pavel Machek
2002-06-06 20:00       ` Oliver Neukum

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.