[PATCHES] suggestion for a patchset "14"
Dominik Brodowski
linux at dominikbrodowski.de
Sun Apr 4 15:09:32 BST 2004
The following patchset depends on
kernel 2.6.5-rc3 or later
Russell's 11-pcmcia patchset
(available at http://pcmcia.arm.linux.org.uk)
my pcmcia-b12 patchset
(available at http://www.brodo.de/patches/2004-03-28/pcmcia-b12.tar.bz2)
my pcmcia-b13 patchset
(available at http://www.brodo.de/patches/2004-04-01/pcmcia-b13.tar.bz2)
The aim of this patchset is to assert only PCMCIA device drivers are registered
as clients, PCMCIA devices (one PCMCIA device for each function on a PCMCIA
card) are registered with the driver model core, and to remove the special
"bind information" in ds.c.
An example of the (beginning) integration with the driver model core.
sonnenschein root # tree /sys/bus/pcmcia/
/sys/bus/pcmcia/
|-- devices
| `-- pcmcia0.0 -> ../../../devices/pci0000:00/0000:00:0c.0/pcmcia0.0
`-- drivers
`-- pcnet_cs
`-- pcmcia0.0 -> ../../../../devices/pci0000:00/0000:00:0c.0/pcmcia0.0
5 directories, 0 files
The single patches are available in compressed form
at:
http://www.brodo.de/patches/2004-04-04/pcmcia-b14.tar.bz2
or
http://www.brodo.de/patches/2004-04-04/pcmcia-b14.tar.gz ,
the combined patch at
http://www.brodo.de/patches/2004-04-04/14-pcmcia-complete ,
and as single patches as follows:
http://www.brodo.de/patches/2004-04-04/01-new_ds_registration
Add a new registration function to register the PCMCIA 16-bit subsystem
(ds a.k.a. pcmcia) with the PCMICA core (cs a.k.a. pcmcia_core).
As send_event is only called with skt->sem held, we can use that to safeguard
skt->callback(), too.
drivers/pcmcia/cs.c | 56 +++++++++++++++++++++++++++++++++++++++++--
drivers/pcmcia/cs_internal.h | 8 ++++++
drivers/pcmcia/ds.c | 51 +++++++++++----------------------------
include/pcmcia/ss.h | 2 +
4 files changed, 79 insertions(+), 38 deletions(-)
http://www.brodo.de/patches/2004-04-04/02-send_event
Call the PCMCIA 16-bit device drivers from ds.c instead of cs.c. Also,
remove the delayed handling of CS_REMOVAL events, but keep the ordering
the same as it used to be due to the delay.
drivers/pcmcia/cs.c | 41 ++++++-------------------
drivers/pcmcia/ds.c | 84 ++++++++++++++++++++++++++++++----------------------
2 files changed, 60 insertions(+), 65 deletions(-)
http://www.brodo.de/patches/2004-04-04/03-unify_bind_mtd
Unify the pcmcia_bind_mtd and bind_mtd functions.
drivers/pcmcia/ds.c | 73 ++++++++++++----------------------------------------
include/pcmcia/cs.h | 7 ----
2 files changed, 18 insertions(+), 62 deletions(-)
http://www.brodo.de/patches/2004-04-04/04-unify_bind_device
Unify bind_device and pcmcia_bind_device. Also, change bind_device so
that it conforms to CodingStyle.
drivers/pcmcia/ds.c | 159 +++++++++++++++++++++-------------------------------
include/pcmcia/cs.h | 9 --
2 files changed, 68 insertions(+), 100 deletions(-)
http://www.brodo.de/patches/2004-04-04/05-license
As discussed previously, my integration of ds.c with the driver model
can[*] and will only be available under the GPL, as it's too much
derived of other buses' implementation of integration with the driver model.
drivers/pcmcia/ds.c | 48 +++++++++++++++---------------------------------
include/pcmcia/ds.h | 26 ++++++--------------------
2 files changed, 21 insertions(+), 53 deletions(-)
http://www.brodo.de/patches/2004-04-04/06-pcmcia_device
Add pcmcia_device(s).
drivers/pcmcia/ds.c | 66 ++++++++++++++++++++++++++++++++++++++++++++++++++++
include/pcmcia/ds.h | 17 +++++++++++++
2 files changed, 83 insertions(+)
http://www.brodo.de/patches/2004-04-04/07-remove_bind_t
Remove struct socket_bind_t by moving "dev_link_t *instance" to struct
pcmcia_device, and transforming all users of socket_bind_t to use struct
pcmcia_device instead. Also, CodingStyle updates for
get_device_info and unbind_request.
drivers/pcmcia/ds.c | 302 +++++++++++++++++++++++++++-------------------------
include/pcmcia/ds.h | 4
2 files changed, 163 insertions(+), 143 deletions(-)
http://www.brodo.de/patches/2004-04-04/08-remove_use_count
Remove the internal driver use_count in ds.c, as the reference counting
is done in the module core anyways, and that reference count is available
for cardmgr's usage by a call to module_refcount. And if
!CONFIG_MODULE_UNLOAD, rmmod is useless anyways, so avoid that call by
cardmgr at all.
drivers/pcmcia/ds.c | 13 ++++++++-----
include/pcmcia/ds.h | 1 -
2 files changed, 8 insertions(+), 6 deletions(-)
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 189 bytes
Desc: not available
Url : http://lists.infradead.org/pipermail/linux-pcmcia/attachments/20040404/31226b48/attachment.bin
More information about the linux-pcmcia
mailing list