cvs commit: src/sys/conf files.amd64 files.i386
src/sys/modules/ndis Makefile src/sys/compat/ndis kern_ndis.c
kern_windrv.c ntoskrnl_var.h subr_usbd.c usbd_var.h
src/sys/dev/if_ndis if_ndis.c if_ndis_pccard.c if_ndis_pci.c ...
Bill Paul
wpaul at FreeBSD.org
Thu Feb 24 21:49:15 GMT 2005
wpaul 2005-02-24 21:49:14 UTC
FreeBSD src repository
Modified files:
sys/conf files.amd64 files.i386
sys/modules/ndis Makefile
sys/compat/ndis kern_ndis.c kern_windrv.c ntoskrnl_var.h
sys/dev/if_ndis if_ndis.c if_ndis_pccard.c if_ndis_pci.c
Added files:
sys/compat/ndis subr_usbd.c usbd_var.h
sys/dev/if_ndis if_ndis_usb.c
Log:
- Correct one aspect of the driver_object/device_object/IRP framework:
when we create a PDO, the driver_object associated with it is that
of the parent driver, not the driver we're trying to attach. For
example, if we attach a PCI device, the PDO we pass to the NdisAddDevice()
function should contain a pointer to fake_pci_driver, not to the NDIS
driver itself. For PCI or PCMCIA devices this doesn't matter because
the child never needs to talk to the parent bus driver, but for USB,
the child needs to be able to send IRPs to the parent USB bus driver, and
for that to work the parent USB bus driver has to be hung off the PDO.
This involves modifying windrv_lookup() so that we can search for
bus drivers by name, if necessary. Our fake bus drivers attach themselves
as "PCI Bus," "PCCARD Bus" and "USB Bus," so we can search for them
using those names.
The individual attachment stubs now create and attach PDOs to the
parent bus drivers instead of hanging them off the NDIS driver's
object, and in if_ndis.c, we now search for the correct driver
object depending on the bus type, and use that to find the correct PDO.
With this fix, I can get my sample USB ethernet driver to deliver
an IRP to my fake parent USB bus driver's dispatch routines.
- Add stub modules for USB support: subr_usbd.c, usbd_var.h and
if_ndis_usb.c. The subr_usbd.c module is hooked up the build
but currently doesn't do very much. It provides the stub USB
parent driver object and a dispatch routine for
IRM_MJ_INTERNAL_DEVICE_CONTROL. The only exported function at
the moment is USBD_GetUSBDIVersion(). The if_ndis_usb.c stub
compiles, but is not hooked up to the build yet. I'm putting
these here so I can keep them under source code control as I
flesh them out.
Revision Changes Path
1.67 +4 -0 src/sys/compat/ndis/kern_ndis.c
1.4 +20 -5 src/sys/compat/ndis/kern_windrv.c
1.26 +1 -1 src/sys/compat/ndis/ntoskrnl_var.h
1.1 +156 -0 src/sys/compat/ndis/subr_usbd.c (new)
1.1 +56 -0 src/sys/compat/ndis/usbd_var.h (new)
1.56 +1 -0 src/sys/conf/files.amd64
1.519 +1 -0 src/sys/conf/files.i386
1.80 +32 -11 src/sys/dev/if_ndis/if_ndis.c
1.9 +2 -4 src/sys/dev/if_ndis/if_ndis_pccard.c
1.11 +1 -3 src/sys/dev/if_ndis/if_ndis_pci.c
1.1 +176 -0 src/sys/dev/if_ndis/if_ndis_usb.c (new)
1.9 +1 -1 src/sys/modules/ndis/Makefile
More information about the cvs-src
mailing list