All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH 0/3] ioc4: Driver rework
@ 2005-05-24  0:48 Brent Casavant
  2005-05-24  1:56 ` Jeff Garzik
  0 siblings, 1 reply; 4+ messages in thread
From: Brent Casavant @ 2005-05-24  0:48 UTC (permalink / raw)
  To: Andrew Morton; +Cc: linux-kernel

This series of patches reworks the configuration and internal structure
of the SGI IOC4 I/O controller device drivers.  These patches are against
2.6.12-rc4, however acceptance into 2.6.13 is my actual goal.

These changes are motivated by several factors:

- The IOC4 chip PCI resources are of mixed use between functions (i.e.
  multiple functions are handled in the same address range, sometimes
  within the same register), muddling resource ownership and initialization
  issues.  Centralizing this ownership in a core driver is desirable.

- The IOC4 chip implements multiple functions (serial, IDE, others not
  yet implemented in the mainline kernel) but is not a multifunction
  PCI device.  In order to properly handle device addition and removal
  as well as module insertion and deletion, an intermediary IOC4-specific
  driver layer is needed to handle these operations cleanly.

- All IOC4 drivers are currently enabled by a single CONFIG value.  As
  not all systems need all IOC4 functions, it is desireable to enable
  these drivers independently.

- The current IOC4 core driver will trigger loading of all function-level
  drivers, as it makes direct calls to them.  This situation should be
  reversed (i.e. function-level drivers cause loading of core driver)
  in order to maintain a clear and least-surprise driver loading model.

- IOC4 hardware design necessitates some driver-level dependency on
  the PCI bus clock speed.  Current code assumes a 66MHz bus, but the
  speed should be autodetected and appropriate compensation taken.

This patch series effects the above changes by a newly and better designed
IOC4 core driver with which the function-level drivers can register and
deregister themselves upon module insertion/removal.  By tracking these
modules, device addition/removal is also handled properly.  PCI resource
management and ownership issues are centralized in this core driver, and
IOC4-wide configuration actions such as bus speed detection are also
handled in this core driver.

Brent Casavant

-- 
Brent Casavant                          If you had nothing to fear,
bcasavan@sgi.com                        how then could you be brave?
Silicon Graphics, Inc.                    -- Queen Dama, Source Wars

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

end of thread, other threads:[~2005-05-24 19:40 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2005-05-24  0:48 [PATCH 0/3] ioc4: Driver rework Brent Casavant
2005-05-24  1:56 ` Jeff Garzik
2005-05-24 16:22   ` Brent Casavant
2005-05-24 19:39   ` Brent Casavant

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.