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.

182 lines
6.0 KiB

  1. /*++
  2. Copyright (c) 2000 Microsoft Corporation
  3. Module Name:
  4. debug.c
  5. Abstract: This module contains all the debug functions.
  6. Environment:
  7. Kernel mode
  8. Author:
  9. Michael Tsang (MikeTs) 13-Mar-2000
  10. Revision History:
  11. --*/
  12. #include "pch.h"
  13. #ifdef DEBUG
  14. NAMETABLE MajorFnNames[] =
  15. {
  16. IRP_MJ_CREATE, "Create",
  17. IRP_MJ_CREATE_NAMED_PIPE, "CreateNamedPipe",
  18. IRP_MJ_CLOSE, "Close",
  19. IRP_MJ_READ, "Read",
  20. IRP_MJ_WRITE, "Write",
  21. IRP_MJ_QUERY_INFORMATION, "QueryInfo",
  22. IRP_MJ_SET_INFORMATION, "SetInfo",
  23. IRP_MJ_QUERY_EA, "QueryEA",
  24. IRP_MJ_SET_EA, "SetEA",
  25. IRP_MJ_FLUSH_BUFFERS, "FlushBuffers",
  26. IRP_MJ_QUERY_VOLUME_INFORMATION, "QueryVolInfo",
  27. IRP_MJ_SET_VOLUME_INFORMATION, "SetVolInfo",
  28. IRP_MJ_DIRECTORY_CONTROL, "DirectoryControl",
  29. IRP_MJ_FILE_SYSTEM_CONTROL, "FileSystemControl",
  30. IRP_MJ_DEVICE_CONTROL, "DeviceControl",
  31. IRP_MJ_INTERNAL_DEVICE_CONTROL, "InternalDevControl",
  32. IRP_MJ_SHUTDOWN, "Shutdown",
  33. IRP_MJ_LOCK_CONTROL, "LockControl",
  34. IRP_MJ_CLEANUP, "CleanUp",
  35. IRP_MJ_CREATE_MAILSLOT, "CreateMailSlot",
  36. IRP_MJ_QUERY_SECURITY, "QuerySecurity",
  37. IRP_MJ_SET_SECURITY, "SetSecurity",
  38. IRP_MJ_POWER, "Power",
  39. IRP_MJ_SYSTEM_CONTROL, "SystemControl",
  40. IRP_MJ_DEVICE_CHANGE, "DeviceChange",
  41. IRP_MJ_QUERY_QUOTA, "QueryQuota",
  42. IRP_MJ_SET_QUOTA, "SetQuota",
  43. IRP_MJ_PNP, "PnP",
  44. 0x00, NULL
  45. };
  46. NAMETABLE PnPMinorFnNames[] =
  47. {
  48. IRP_MN_START_DEVICE, "StartDevice",
  49. IRP_MN_QUERY_REMOVE_DEVICE, "QueryRemoveDevice",
  50. IRP_MN_REMOVE_DEVICE, "RemoveDevice",
  51. IRP_MN_CANCEL_REMOVE_DEVICE, "CancelRemoveDevice",
  52. IRP_MN_STOP_DEVICE, "StopDevice",
  53. IRP_MN_QUERY_STOP_DEVICE, "QueryStopDevice",
  54. IRP_MN_CANCEL_STOP_DEVICE, "CancelStopDevice",
  55. IRP_MN_QUERY_DEVICE_RELATIONS, "QueryDeviceRelations",
  56. IRP_MN_QUERY_INTERFACE, "QueryInterface",
  57. IRP_MN_QUERY_CAPABILITIES, "QueryCapabilities",
  58. IRP_MN_QUERY_RESOURCES, "QueryResources",
  59. IRP_MN_QUERY_RESOURCE_REQUIREMENTS, "QueryResRequirements",
  60. IRP_MN_QUERY_DEVICE_TEXT, "QueryDeviceText",
  61. IRP_MN_FILTER_RESOURCE_REQUIREMENTS,"FilterResRequirements",
  62. IRP_MN_READ_CONFIG, "ReadConfig",
  63. IRP_MN_WRITE_CONFIG, "WriteConfig",
  64. IRP_MN_EJECT, "Eject",
  65. IRP_MN_SET_LOCK, "SetLock",
  66. IRP_MN_QUERY_ID, "QueryID",
  67. IRP_MN_QUERY_PNP_DEVICE_STATE, "QueryPNPDeviceState",
  68. IRP_MN_QUERY_BUS_INFORMATION, "QueryBusInfo",
  69. IRP_MN_DEVICE_USAGE_NOTIFICATION, "DeviceUsageNotify",
  70. IRP_MN_SURPRISE_REMOVAL, "SurpriseRemoval",
  71. 0x18, "QueryLegacyBusInfo",
  72. 0x00, NULL
  73. };
  74. NAMETABLE PowerMinorFnNames[] =
  75. {
  76. IRP_MN_WAIT_WAKE, "WaitWake",
  77. IRP_MN_POWER_SEQUENCE, "PowerSequence",
  78. IRP_MN_SET_POWER, "SetPower",
  79. IRP_MN_QUERY_POWER, "QueryPower",
  80. 0x00, NULL
  81. };
  82. NAMETABLE PowerStateNames[] =
  83. {
  84. PowerDeviceUnspecified, "Unspecified",
  85. PowerDeviceD0, "D0",
  86. PowerDeviceD1, "D1",
  87. PowerDeviceD2, "D2",
  88. PowerDeviceD3, "D3",
  89. PowerDeviceMaximum, "Maximum",
  90. 0x00, NULL
  91. };
  92. NAMETABLE HidIoctlNames[] =
  93. {
  94. IOCTL_HID_GET_DEVICE_DESCRIPTOR, "GetDeviceDescriptor",
  95. IOCTL_HID_GET_REPORT_DESCRIPTOR, "GetReportDescriptor",
  96. IOCTL_HID_READ_REPORT, "ReadReport",
  97. IOCTL_HID_WRITE_REPORT, "WriteReport",
  98. IOCTL_HID_GET_STRING, "GetString",
  99. IOCTL_HID_ACTIVATE_DEVICE, "ActivateDevice",
  100. IOCTL_HID_DEACTIVATE_DEVICE, "DeactivateDevice",
  101. IOCTL_HID_GET_DEVICE_ATTRIBUTES, "GetDeviceAttributes",
  102. 0x00, NULL
  103. };
  104. NAMETABLE QueryIDTypeNames[] =
  105. {
  106. BusQueryDeviceID, "DeviceID",
  107. BusQueryHardwareIDs, "HardwareIDs",
  108. BusQueryCompatibleIDs, "CompatibleIDs",
  109. BusQueryDeviceSerialNumber, "DeviceSerialNumber",
  110. 0x00, NULL
  111. };
  112. FAST_MUTEX gmutexDevExtList = {0}; //synchronization for access to list
  113. LIST_ENTRY glistDevExtHead = {0}; //list of all the device instances
  114. int giVerboseLevel = 0;
  115. /*****************************************************************************
  116. *
  117. * @doc INTERNAL
  118. *
  119. * @func PSZ | LookupName |
  120. *
  121. * Look up name string of a code in the given name table.
  122. *
  123. * @parm IN ULONG | Code |
  124. *
  125. * The given code to lookup.
  126. *
  127. * @parm IN PNAMETABLE | NameTable |
  128. *
  129. * The name table to look into.
  130. *
  131. * @rvalue SUCCESS - Returns pointer to the minor function name string.
  132. * @rvalue FAILURE - Returns "unknown".
  133. *
  134. *****************************************************************************/
  135. PSZ INTERNAL
  136. LookupName(
  137. IN ULONG Code,
  138. IN PNAMETABLE NameTable
  139. )
  140. {
  141. PROCNAME("LookupName")
  142. PSZ pszName = "unknown";
  143. ENTER(5, ("(Code=%x,pNameTable=%p)\n", Code, NameTable));
  144. ASSERT(NameTable != NULL);
  145. while (NameTable->pszName != NULL)
  146. {
  147. if (Code == NameTable->Code)
  148. {
  149. pszName = NameTable->pszName;
  150. break;
  151. }
  152. NameTable++;
  153. }
  154. EXIT(5, ("=%s\n", pszName));
  155. return pszName;
  156. } //LookupName
  157. #endif //ifdef DEBUG