2010-04-01 19:07:40 +00:00
|
|
|
/*
|
|
|
|
* PROJECT: ReactOS PCI Bus Driver
|
|
|
|
* LICENSE: BSD - See COPYING.ARM in the top level directory
|
|
|
|
* FILE: drivers/bus/pci/intrface/routinf.c
|
|
|
|
* PURPOSE: Routing Interface
|
|
|
|
* PROGRAMMERS: ReactOS Portable Systems Group
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* INCLUDES *******************************************************************/
|
|
|
|
|
|
|
|
#include <pci.h>
|
2014-01-04 12:05:02 +00:00
|
|
|
|
2010-04-01 19:07:40 +00:00
|
|
|
#define NDEBUG
|
|
|
|
#include <debug.h>
|
|
|
|
|
|
|
|
/* GLOBALS ********************************************************************/
|
|
|
|
|
2010-09-23 13:24:41 +00:00
|
|
|
PPCI_LEGACY_DEVICE PciLegacyDeviceHead;
|
|
|
|
|
Fix for code to handle IRP dispatching when unrecognized IRP (Thanks you sir_richard)
Add FDO IRP_MN_QUERY_INTERFACE support (it calls PciQueryInterface)
Add all PCI interface descriptor: PciLocationInterface (GUID_PNP_LOCATION_INTERFACE), PciPmeInterface (GUID_PCI_PME_INTERFACE), PciCardbusPrivateInterface (GUID_PCI_CARDBUS_INTERFACE_PRIVATE), PciLegacyDeviceDetectionInterface (GUID_LEGACY_DEVICE_DETECTION_STANDARD), AgpTargetInterface (GUID_AGP_TARGET_BUS_INTERFACE_STANDARD), PciRoutingInterface (GUID_INT_ROUTE_INTERFACE_STANDARD), BusHandlerInterface (GUID_BUS_INTERFACE_STANDARD) and stub initializer and constructor.
Add missing devhere.c interface file
Add all PCI arbiter descritptor: ArbiterInterfaceBusNumber, ArbiterInterfaceMemory, ArbiterInterfaceIo. Write constructor stub but not handled ArbitersInitialized == TRUE
Also add last-resort PCI interface: TranslatorInterfaceInterrupt (GUID_TRANSLATOR_INTERFACE_STANDARD) and part implement tranirq_Constructor
Add PciQueryInterface to find correct FDO/PDO/ROOT interface for a request and call interface constructor
Fix interface signatures, fix interface constructor type and PCI_INTERFACE, add interface flags (Thanks sir_richard)
Fix Aribtriter code (Thanks sir_richard)
Now another 1200 codes added, soon time for enumeration code!
svn path=/trunk/; revision=48074
2010-07-16 00:39:54 +00:00
|
|
|
PCI_INTERFACE PciRoutingInterface =
|
|
|
|
{
|
|
|
|
&GUID_INT_ROUTE_INTERFACE_STANDARD,
|
|
|
|
sizeof(INT_ROUTE_INTERFACE_STANDARD),
|
|
|
|
PCI_INT_ROUTE_INTRF_STANDARD_VER,
|
|
|
|
PCI_INT_ROUTE_INTRF_STANDARD_VER,
|
|
|
|
PCI_INTERFACE_FDO,
|
|
|
|
0,
|
|
|
|
PciInterface_IntRouteHandler,
|
|
|
|
routeintrf_Constructor,
|
|
|
|
routeintrf_Initializer
|
|
|
|
};
|
|
|
|
|
2010-04-01 19:07:40 +00:00
|
|
|
/* FUNCTIONS ******************************************************************/
|
|
|
|
|
Fix for code to handle IRP dispatching when unrecognized IRP (Thanks you sir_richard)
Add FDO IRP_MN_QUERY_INTERFACE support (it calls PciQueryInterface)
Add all PCI interface descriptor: PciLocationInterface (GUID_PNP_LOCATION_INTERFACE), PciPmeInterface (GUID_PCI_PME_INTERFACE), PciCardbusPrivateInterface (GUID_PCI_CARDBUS_INTERFACE_PRIVATE), PciLegacyDeviceDetectionInterface (GUID_LEGACY_DEVICE_DETECTION_STANDARD), AgpTargetInterface (GUID_AGP_TARGET_BUS_INTERFACE_STANDARD), PciRoutingInterface (GUID_INT_ROUTE_INTERFACE_STANDARD), BusHandlerInterface (GUID_BUS_INTERFACE_STANDARD) and stub initializer and constructor.
Add missing devhere.c interface file
Add all PCI arbiter descritptor: ArbiterInterfaceBusNumber, ArbiterInterfaceMemory, ArbiterInterfaceIo. Write constructor stub but not handled ArbitersInitialized == TRUE
Also add last-resort PCI interface: TranslatorInterfaceInterrupt (GUID_TRANSLATOR_INTERFACE_STANDARD) and part implement tranirq_Constructor
Add PciQueryInterface to find correct FDO/PDO/ROOT interface for a request and call interface constructor
Fix interface signatures, fix interface constructor type and PCI_INTERFACE, add interface flags (Thanks sir_richard)
Fix Aribtriter code (Thanks sir_richard)
Now another 1200 codes added, soon time for enumeration code!
svn path=/trunk/; revision=48074
2010-07-16 00:39:54 +00:00
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
routeintrf_Initializer(IN PVOID Instance)
|
|
|
|
{
|
2013-05-10 10:22:01 +00:00
|
|
|
UNREFERENCED_PARAMETER(Instance);
|
Fix for code to handle IRP dispatching when unrecognized IRP (Thanks you sir_richard)
Add FDO IRP_MN_QUERY_INTERFACE support (it calls PciQueryInterface)
Add all PCI interface descriptor: PciLocationInterface (GUID_PNP_LOCATION_INTERFACE), PciPmeInterface (GUID_PCI_PME_INTERFACE), PciCardbusPrivateInterface (GUID_PCI_CARDBUS_INTERFACE_PRIVATE), PciLegacyDeviceDetectionInterface (GUID_LEGACY_DEVICE_DETECTION_STANDARD), AgpTargetInterface (GUID_AGP_TARGET_BUS_INTERFACE_STANDARD), PciRoutingInterface (GUID_INT_ROUTE_INTERFACE_STANDARD), BusHandlerInterface (GUID_BUS_INTERFACE_STANDARD) and stub initializer and constructor.
Add missing devhere.c interface file
Add all PCI arbiter descritptor: ArbiterInterfaceBusNumber, ArbiterInterfaceMemory, ArbiterInterfaceIo. Write constructor stub but not handled ArbitersInitialized == TRUE
Also add last-resort PCI interface: TranslatorInterfaceInterrupt (GUID_TRANSLATOR_INTERFACE_STANDARD) and part implement tranirq_Constructor
Add PciQueryInterface to find correct FDO/PDO/ROOT interface for a request and call interface constructor
Fix interface signatures, fix interface constructor type and PCI_INTERFACE, add interface flags (Thanks sir_richard)
Fix Aribtriter code (Thanks sir_richard)
Now another 1200 codes added, soon time for enumeration code!
svn path=/trunk/; revision=48074
2010-07-16 00:39:54 +00:00
|
|
|
/* PnP Interfaces don't get Initialized */
|
2018-07-04 01:42:04 +00:00
|
|
|
ASSERTMSG("PCI routeintrf_Initializer, unexpected call.\n", FALSE);
|
Fix for code to handle IRP dispatching when unrecognized IRP (Thanks you sir_richard)
Add FDO IRP_MN_QUERY_INTERFACE support (it calls PciQueryInterface)
Add all PCI interface descriptor: PciLocationInterface (GUID_PNP_LOCATION_INTERFACE), PciPmeInterface (GUID_PCI_PME_INTERFACE), PciCardbusPrivateInterface (GUID_PCI_CARDBUS_INTERFACE_PRIVATE), PciLegacyDeviceDetectionInterface (GUID_LEGACY_DEVICE_DETECTION_STANDARD), AgpTargetInterface (GUID_AGP_TARGET_BUS_INTERFACE_STANDARD), PciRoutingInterface (GUID_INT_ROUTE_INTERFACE_STANDARD), BusHandlerInterface (GUID_BUS_INTERFACE_STANDARD) and stub initializer and constructor.
Add missing devhere.c interface file
Add all PCI arbiter descritptor: ArbiterInterfaceBusNumber, ArbiterInterfaceMemory, ArbiterInterfaceIo. Write constructor stub but not handled ArbitersInitialized == TRUE
Also add last-resort PCI interface: TranslatorInterfaceInterrupt (GUID_TRANSLATOR_INTERFACE_STANDARD) and part implement tranirq_Constructor
Add PciQueryInterface to find correct FDO/PDO/ROOT interface for a request and call interface constructor
Fix interface signatures, fix interface constructor type and PCI_INTERFACE, add interface flags (Thanks sir_richard)
Fix Aribtriter code (Thanks sir_richard)
Now another 1200 codes added, soon time for enumeration code!
svn path=/trunk/; revision=48074
2010-07-16 00:39:54 +00:00
|
|
|
return STATUS_UNSUCCESSFUL;
|
|
|
|
}
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
routeintrf_Constructor(IN PVOID DeviceExtension,
|
|
|
|
IN PVOID Instance,
|
|
|
|
IN PVOID InterfaceData,
|
|
|
|
IN USHORT Version,
|
|
|
|
IN USHORT Size,
|
|
|
|
IN PINTERFACE Interface)
|
|
|
|
{
|
2013-05-10 10:22:01 +00:00
|
|
|
UNREFERENCED_PARAMETER(DeviceExtension);
|
|
|
|
UNREFERENCED_PARAMETER(Instance);
|
|
|
|
UNREFERENCED_PARAMETER(InterfaceData);
|
|
|
|
UNREFERENCED_PARAMETER(Size);
|
|
|
|
UNREFERENCED_PARAMETER(Interface);
|
|
|
|
|
Fix for code to handle IRP dispatching when unrecognized IRP (Thanks you sir_richard)
Add FDO IRP_MN_QUERY_INTERFACE support (it calls PciQueryInterface)
Add all PCI interface descriptor: PciLocationInterface (GUID_PNP_LOCATION_INTERFACE), PciPmeInterface (GUID_PCI_PME_INTERFACE), PciCardbusPrivateInterface (GUID_PCI_CARDBUS_INTERFACE_PRIVATE), PciLegacyDeviceDetectionInterface (GUID_LEGACY_DEVICE_DETECTION_STANDARD), AgpTargetInterface (GUID_AGP_TARGET_BUS_INTERFACE_STANDARD), PciRoutingInterface (GUID_INT_ROUTE_INTERFACE_STANDARD), BusHandlerInterface (GUID_BUS_INTERFACE_STANDARD) and stub initializer and constructor.
Add missing devhere.c interface file
Add all PCI arbiter descritptor: ArbiterInterfaceBusNumber, ArbiterInterfaceMemory, ArbiterInterfaceIo. Write constructor stub but not handled ArbitersInitialized == TRUE
Also add last-resort PCI interface: TranslatorInterfaceInterrupt (GUID_TRANSLATOR_INTERFACE_STANDARD) and part implement tranirq_Constructor
Add PciQueryInterface to find correct FDO/PDO/ROOT interface for a request and call interface constructor
Fix interface signatures, fix interface constructor type and PCI_INTERFACE, add interface flags (Thanks sir_richard)
Fix Aribtriter code (Thanks sir_richard)
Now another 1200 codes added, soon time for enumeration code!
svn path=/trunk/; revision=48074
2010-07-16 00:39:54 +00:00
|
|
|
/* Only version 1 is supported */
|
|
|
|
if (Version != PCI_INT_ROUTE_INTRF_STANDARD_VER) return STATUS_NOINTERFACE;
|
|
|
|
|
|
|
|
/* Not yet implemented */
|
2013-01-10 01:45:22 +00:00
|
|
|
UNIMPLEMENTED_DBGBREAK();
|
2013-01-04 11:47:19 +00:00
|
|
|
return STATUS_NOT_IMPLEMENTED;
|
Fix for code to handle IRP dispatching when unrecognized IRP (Thanks you sir_richard)
Add FDO IRP_MN_QUERY_INTERFACE support (it calls PciQueryInterface)
Add all PCI interface descriptor: PciLocationInterface (GUID_PNP_LOCATION_INTERFACE), PciPmeInterface (GUID_PCI_PME_INTERFACE), PciCardbusPrivateInterface (GUID_PCI_CARDBUS_INTERFACE_PRIVATE), PciLegacyDeviceDetectionInterface (GUID_LEGACY_DEVICE_DETECTION_STANDARD), AgpTargetInterface (GUID_AGP_TARGET_BUS_INTERFACE_STANDARD), PciRoutingInterface (GUID_INT_ROUTE_INTERFACE_STANDARD), BusHandlerInterface (GUID_BUS_INTERFACE_STANDARD) and stub initializer and constructor.
Add missing devhere.c interface file
Add all PCI arbiter descritptor: ArbiterInterfaceBusNumber, ArbiterInterfaceMemory, ArbiterInterfaceIo. Write constructor stub but not handled ArbitersInitialized == TRUE
Also add last-resort PCI interface: TranslatorInterfaceInterrupt (GUID_TRANSLATOR_INTERFACE_STANDARD) and part implement tranirq_Constructor
Add PciQueryInterface to find correct FDO/PDO/ROOT interface for a request and call interface constructor
Fix interface signatures, fix interface constructor type and PCI_INTERFACE, add interface flags (Thanks sir_richard)
Fix Aribtriter code (Thanks sir_richard)
Now another 1200 codes added, soon time for enumeration code!
svn path=/trunk/; revision=48074
2010-07-16 00:39:54 +00:00
|
|
|
}
|
|
|
|
|
2010-09-23 13:24:41 +00:00
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
PciCacheLegacyDeviceRouting(IN PDEVICE_OBJECT DeviceObject,
|
|
|
|
IN ULONG BusNumber,
|
|
|
|
IN ULONG SlotNumber,
|
|
|
|
IN UCHAR InterruptLine,
|
|
|
|
IN UCHAR InterruptPin,
|
|
|
|
IN UCHAR BaseClass,
|
|
|
|
IN UCHAR SubClass,
|
|
|
|
IN PDEVICE_OBJECT PhysicalDeviceObject,
|
|
|
|
IN PPCI_PDO_EXTENSION PdoExtension,
|
|
|
|
OUT PDEVICE_OBJECT *pFoundDeviceObject)
|
|
|
|
{
|
|
|
|
PPCI_LEGACY_DEVICE *Link;
|
|
|
|
PPCI_LEGACY_DEVICE LegacyDevice;
|
|
|
|
PDEVICE_OBJECT FoundDeviceObject;
|
|
|
|
PAGED_CODE();
|
|
|
|
|
|
|
|
/* Scan current registered devices */
|
|
|
|
LegacyDevice = PciLegacyDeviceHead;
|
|
|
|
Link = &PciLegacyDeviceHead;
|
|
|
|
while (LegacyDevice)
|
|
|
|
{
|
|
|
|
/* Find a match */
|
|
|
|
if ((BusNumber == LegacyDevice->BusNumber) &&
|
|
|
|
(SlotNumber == LegacyDevice->SlotNumber))
|
|
|
|
{
|
|
|
|
/* We already know about this routing */
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* We know about device already, but for a different location */
|
|
|
|
if (LegacyDevice->DeviceObject == DeviceObject)
|
|
|
|
{
|
|
|
|
/* Free the existing structure, move to the next one */
|
|
|
|
*Link = LegacyDevice->Next;
|
|
|
|
ExFreePoolWithTag(LegacyDevice, 0);
|
|
|
|
LegacyDevice = *Link;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
/* Keep going */
|
|
|
|
Link = &LegacyDevice->Next;
|
|
|
|
LegacyDevice = LegacyDevice->Next;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Did we find a match? */
|
|
|
|
if (!LegacyDevice)
|
|
|
|
{
|
|
|
|
/* Allocate a new cache structure */
|
|
|
|
LegacyDevice = ExAllocatePoolWithTag(PagedPool,
|
|
|
|
sizeof(PCI_LEGACY_DEVICE),
|
|
|
|
'PciR');
|
|
|
|
if (!LegacyDevice) return STATUS_INSUFFICIENT_RESOURCES;
|
|
|
|
|
|
|
|
/* Save all the data in it */
|
|
|
|
RtlZeroMemory(LegacyDevice, sizeof(PCI_LEGACY_DEVICE));
|
|
|
|
LegacyDevice->BusNumber = BusNumber;
|
|
|
|
LegacyDevice->SlotNumber = SlotNumber;
|
|
|
|
LegacyDevice->InterruptLine = InterruptLine;
|
|
|
|
LegacyDevice->InterruptPin = InterruptPin;
|
|
|
|
LegacyDevice->BaseClass = BaseClass;
|
|
|
|
LegacyDevice->SubClass = SubClass;
|
|
|
|
LegacyDevice->PhysicalDeviceObject = PhysicalDeviceObject;
|
|
|
|
LegacyDevice->DeviceObject = DeviceObject;
|
|
|
|
LegacyDevice->PdoExtension = PdoExtension;
|
|
|
|
|
|
|
|
/* Link it in the list */
|
|
|
|
LegacyDevice->Next = PciLegacyDeviceHead;
|
|
|
|
PciLegacyDeviceHead = LegacyDevice;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Check if we found, or created, a matching caching structure */
|
|
|
|
FoundDeviceObject = LegacyDevice->DeviceObject;
|
|
|
|
if (FoundDeviceObject == DeviceObject)
|
|
|
|
{
|
|
|
|
/* Return the device object and success */
|
|
|
|
if (pFoundDeviceObject) *pFoundDeviceObject = DeviceObject;
|
|
|
|
return STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Otherwise, this is a new device object for this location */
|
|
|
|
LegacyDevice->DeviceObject = DeviceObject;
|
|
|
|
if (pFoundDeviceObject) *pFoundDeviceObject = FoundDeviceObject;
|
|
|
|
return STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2010-04-01 19:07:40 +00:00
|
|
|
/* EOF */
|