Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

373 lines
8.0 KiB

  1. /*++
  2. Copyright (c) 1989 Microsoft Corporation
  3. Module Name:
  4. ixhwsup.c
  5. Abstract:
  6. This module contains the IoXxx routines for the NT I/O system that
  7. are hardware dependent. Were these routines not hardware dependent,
  8. they would reside in the iosubs.c module.
  9. Author:
  10. Ken Reneris (kenr) July-28-1994
  11. Environment:
  12. Kernel mode
  13. Revision History:
  14. --*/
  15. #include "halp.h"
  16. #define DMALIMIT 7
  17. VOID HalpInitOtherBuses (VOID);
  18. ULONG
  19. HalpNoBusData (
  20. IN PVOID BusHandler,
  21. IN PVOID RootHandler,
  22. IN ULONG SlotNumber,
  23. IN PVOID Buffer,
  24. IN ULONG Offset,
  25. IN ULONG Length
  26. );
  27. ULONG HalpcGetCmosData (
  28. IN PVOID BusHandler,
  29. IN PVOID RootHandler,
  30. IN ULONG SlotNumber,
  31. IN PVOID Buffer,
  32. IN ULONG Offset,
  33. IN ULONG Length
  34. );
  35. ULONG HalpcSetCmosData (
  36. IN PVOID BusHandler,
  37. IN PVOID RootHandler,
  38. IN ULONG SlotNumber,
  39. IN PVOID Buffer,
  40. IN ULONG Offset,
  41. IN ULONG Length
  42. );
  43. ULONG HalpGetCmosData (
  44. IN ULONG BusNumber,
  45. IN ULONG SlotNumber,
  46. IN PVOID Buffer,
  47. IN ULONG Length
  48. );
  49. ULONG HalpSetCmosData (
  50. IN ULONG BusNumber,
  51. IN ULONG SlotNumber,
  52. IN PVOID Buffer,
  53. IN ULONG Length
  54. );
  55. HalpGetEisaData (
  56. IN PVOID BusHandler,
  57. IN PVOID RootHandler,
  58. IN ULONG SlotNumber,
  59. IN PVOID Buffer,
  60. IN ULONG Offset,
  61. IN ULONG Length
  62. );
  63. //
  64. // Prototype for system bus handlers
  65. //
  66. NTSTATUS
  67. HalpAdjustEisaResourceList (
  68. IN PVOID BusHandler,
  69. IN PVOID RootHandler,
  70. IN OUT PIO_RESOURCE_REQUIREMENTS_LIST *pResourceList
  71. );
  72. ULONG
  73. HalpGetEisaInterruptVector (
  74. IN PVOID BusHandler,
  75. IN PVOID RootHandler,
  76. IN ULONG BusInterruptLevel,
  77. IN ULONG BusInterruptVector,
  78. OUT PKIRQL Irql,
  79. OUT PKAFFINITY Affinity
  80. );
  81. BOOLEAN
  82. HalpTranslateIsaBusAddress (
  83. IN PVOID BusHandler,
  84. IN PVOID RootHandler,
  85. IN PHYSICAL_ADDRESS BusAddress,
  86. IN OUT PULONG AddressSpace,
  87. OUT PPHYSICAL_ADDRESS TranslatedAddress
  88. );
  89. BOOLEAN
  90. HalpTranslateEisaBusAddress (
  91. IN PVOID BusHandler,
  92. IN PVOID RootHandler,
  93. IN PHYSICAL_ADDRESS BusAddress,
  94. IN OUT PULONG AddressSpace,
  95. OUT PPHYSICAL_ADDRESS TranslatedAddress
  96. );
  97. VOID
  98. HalpRegisterInternalBusHandlers (
  99. VOID
  100. );
  101. NTSTATUS
  102. HalpHibernateHal (
  103. IN PBUS_HANDLER BusHandler,
  104. IN PBUS_HANDLER RootHandler
  105. );
  106. NTSTATUS
  107. HalpResumeHal (
  108. IN PBUS_HANDLER BusHandler,
  109. IN PBUS_HANDLER RootHandler
  110. );
  111. #ifdef MCA
  112. //
  113. // Default functionality of MCA handlers is the same as the Eisa handlers,
  114. // just use them
  115. //
  116. #define HalpGetMCAInterruptVector HalpGetEisaInterruptVector
  117. #define HalpAdjustMCAResourceList HalpAdjustEisaResourceList;
  118. HalpGetPosData (
  119. IN PVOID BusHandler,
  120. IN PVOID RootHandler,
  121. IN ULONG SlotNumber,
  122. IN PVOID Buffer,
  123. IN ULONG Offset,
  124. IN ULONG Length
  125. );
  126. #endif
  127. #ifdef ALLOC_PRAGMA
  128. #pragma alloc_text(INIT,HalpRegisterInternalBusHandlers)
  129. #pragma alloc_text(INIT,HalpAllocateBusHandler)
  130. #endif
  131. VOID
  132. HalpRegisterInternalBusHandlers (
  133. VOID
  134. )
  135. {
  136. PBUS_HANDLER Bus;
  137. if (KeGetCurrentPrcb()->Number) {
  138. // only need to do this once
  139. return ;
  140. }
  141. //
  142. // Initalize BusHandler data before registering any handlers
  143. //
  144. HalpInitBusHandler ();
  145. //
  146. // Build internal-bus 0, or system level bus
  147. //
  148. Bus = HalpAllocateBusHandler (
  149. Internal,
  150. ConfigurationSpaceUndefined,
  151. 0, // Internal BusNumber 0
  152. InterfaceTypeUndefined, // no parent bus
  153. 0,
  154. 0 // no bus specfic data
  155. );
  156. if (!Bus) {
  157. return;
  158. }
  159. Bus->GetInterruptVector = HalpGetSystemInterruptVector;
  160. Bus->TranslateBusAddress = HalpTranslateSystemBusAddress;
  161. #if 0
  162. //
  163. // Hibernate and resume the hal by getting notifications
  164. // for when this bus is hibernated or resumed. Since it's
  165. // the first bus to be added, it will be the last to hibernate
  166. // and the first to resume
  167. //
  168. Bus->HibernateBus = HalpHibernateHal;
  169. Bus->ResumeBus = HalpResumeHal;
  170. #endif
  171. #if defined(NEC_98)
  172. Bus = HalpAllocateBusHandler (Isa, ConfigurationSpaceUndefined, 0, Internal, 0, 0); // isa as child of Internal
  173. Bus->GetBusData = HalpNoBusData;
  174. Bus->AdjustResourceList = HalpAdjustEisaResourceList;
  175. Bus->TranslateBusAddress = HalpTranslateEisaBusAddress;
  176. #else //defined(NEC_98)
  177. //
  178. // Add handlers for Cmos config space.
  179. //
  180. Bus = HalpAllocateBusHandler (InterfaceTypeUndefined, Cmos, 0, -1, 0, 0);
  181. Bus->GetBusData = HalpcGetCmosData;
  182. Bus->SetBusData = HalpcSetCmosData;
  183. Bus = HalpAllocateBusHandler (InterfaceTypeUndefined, Cmos, 1, -1, 0, 0);
  184. Bus->GetBusData = HalpcGetCmosData;
  185. Bus->SetBusData = HalpcSetCmosData;
  186. #ifndef MCA
  187. //
  188. // Build Isa/Eisa bus #0
  189. //
  190. Bus = HalpAllocateBusHandler (Eisa, EisaConfiguration, 0, Internal, 0, 0);
  191. Bus->GetBusData = HalpGetEisaData;
  192. Bus->GetInterruptVector = HalpGetEisaInterruptVector;
  193. Bus->AdjustResourceList = HalpAdjustEisaResourceList;
  194. Bus->TranslateBusAddress = HalpTranslateEisaBusAddress;
  195. Bus = HalpAllocateBusHandler (Isa, ConfigurationSpaceUndefined, 0, Eisa, 0, 0);
  196. Bus->GetBusData = HalpNoBusData;
  197. Bus->BusAddresses->Memory.Limit = 0xFFFFFF;
  198. Bus->TranslateBusAddress = HalpTranslateIsaBusAddress;
  199. #else
  200. //
  201. // Build MCA bus #0
  202. //
  203. Bus = HalpAllocateBusHandler (MicroChannel, Pos, 0, Internal, 0, 0);
  204. Bus->GetBusData = HalpGetPosData;
  205. Bus->GetInterruptVector = HalpGetMCAInterruptVector;
  206. Bus->AdjustResourceList = HalpAdjustMCAResourceList;
  207. #endif
  208. #endif // defined(NEC_98)
  209. HalpInitOtherBuses ();
  210. }
  211. PBUS_HANDLER
  212. HalpAllocateBusHandler (
  213. IN INTERFACE_TYPE InterfaceType,
  214. IN BUS_DATA_TYPE BusDataType,
  215. IN ULONG BusNumber,
  216. IN INTERFACE_TYPE ParentBusInterfaceType,
  217. IN ULONG ParentBusNumber,
  218. IN ULONG BusSpecificData
  219. )
  220. /*++
  221. Routine Description:
  222. Stub function to map old style code into new HalRegisterBusHandler code.
  223. Note we can add our specific bus handler functions after this bus
  224. handler structure has been added since this is being done during
  225. hal initialization.
  226. --*/
  227. {
  228. PBUS_HANDLER Bus = NULL;
  229. //
  230. // Create bus handler - new style
  231. //
  232. HaliRegisterBusHandler (
  233. InterfaceType,
  234. BusDataType,
  235. BusNumber,
  236. ParentBusInterfaceType,
  237. ParentBusNumber,
  238. BusSpecificData,
  239. NULL,
  240. &Bus
  241. );
  242. if (!Bus) {
  243. return NULL;
  244. }
  245. if (InterfaceType != InterfaceTypeUndefined) {
  246. Bus->BusAddresses = ExAllocatePoolWithTag(SPRANGEPOOL,
  247. sizeof(SUPPORTED_RANGES),
  248. HAL_POOL_TAG);
  249. RtlZeroMemory(Bus->BusAddresses, sizeof(SUPPORTED_RANGES));
  250. Bus->BusAddresses->Version = BUS_SUPPORTED_RANGE_VERSION;
  251. Bus->BusAddresses->Dma.Limit = DMALIMIT;
  252. Bus->BusAddresses->Memory.Limit = 0xFFFFFFFF;
  253. Bus->BusAddresses->IO.Limit = 0xFFFF;
  254. Bus->BusAddresses->IO.SystemAddressSpace = 1;
  255. Bus->BusAddresses->PrefetchMemory.Base = 1;
  256. }
  257. return Bus;
  258. }
  259. //
  260. // C to Asm thunks for CMos
  261. //
  262. ULONG HalpcGetCmosData (
  263. IN PBUS_HANDLER BusHandler,
  264. IN PVOID RootHandler,
  265. IN ULONG SlotNumber,
  266. IN PVOID Buffer,
  267. IN ULONG Offset,
  268. IN ULONG Length
  269. )
  270. {
  271. // this interface should be rev'ed to support non-zero offsets
  272. if (Offset != 0) {
  273. return 0;
  274. }
  275. return HalpGetCmosData (BusHandler->BusNumber, SlotNumber, Buffer, Length);
  276. }
  277. ULONG HalpcSetCmosData (
  278. IN PBUS_HANDLER BusHandler,
  279. IN PVOID RootHandler,
  280. IN ULONG SlotNumber,
  281. IN PVOID Buffer,
  282. IN ULONG Offset,
  283. IN ULONG Length
  284. )
  285. {
  286. // this interface should be rev'ed to support non-zero offsets
  287. if (Offset != 0) {
  288. return 0;
  289. }
  290. return HalpSetCmosData (BusHandler->BusNumber, SlotNumber, Buffer, Length);
  291. }