Leaked source code of windows server 2003
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.

198 lines
5.2 KiB

  1. /*++
  2. Copyright (c) Microsoft Corporation. All rights reserved.
  3. THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY
  4. KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
  5. IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A PARTICULAR
  6. PURPOSE.
  7. Module Name:
  8. ExCallbk.c
  9. Abstract: The routines in this module helps to solve driver load order
  10. dependency between this sample and NDISWDM sample. These
  11. routines are not required in a typical protocol driver. By default
  12. this module is not included in the sample. You include these routines
  13. by adding EX_CALLBACK defines to the 'sources' file. Read the
  14. NDISWDM samples readme file for more information on how ExCallback
  15. kernel interfaces are used to solve driver load order issue.
  16. Author: Eliyas Yakub (Jan 12, 2003)
  17. Environment:
  18. Kernel mode
  19. Revision History:
  20. --*/
  21. #include "precomp.h"
  22. #ifdef EX_CALLBACK
  23. #define __FILENUMBER 'LCxE'
  24. #define NDISPROT_CALLBACK_NAME L"\\Callback\\NdisProtCallbackObject"
  25. #define CALLBACK_SOURCE_NDISPROT 0
  26. #define CALLBACK_SOURCE_NDISWDM 1
  27. PCALLBACK_OBJECT CallbackObject = NULL;
  28. PVOID CallbackRegisterationHandle = NULL;
  29. typedef VOID (* NOTIFY_PRESENCE_CALLBACK)(OUT PVOID Source);
  30. #ifdef ALLOC_PRAGMA
  31. #pragma alloc_text(PAGE, ndisprotRegisterExCallBack)
  32. #pragma alloc_text(PAGE, ndisprotUnregisterExCallBack)
  33. #endif // ALLOC_PRAGMA
  34. BOOLEAN
  35. ndisprotRegisterExCallBack()
  36. {
  37. OBJECT_ATTRIBUTES ObjectAttr;
  38. UNICODE_STRING CallBackObjectName;
  39. NTSTATUS Status;
  40. BOOLEAN bResult = TRUE;
  41. DEBUGP(DL_LOUD, ("--> ndisprotRegisterExCallBack\n"));
  42. PAGED_CODE();
  43. do {
  44. RtlInitUnicodeString(&CallBackObjectName, NDISPROT_CALLBACK_NAME);
  45. InitializeObjectAttributes(&ObjectAttr,
  46. &CallBackObjectName,
  47. OBJ_CASE_INSENSITIVE | OBJ_PERMANENT,
  48. NULL,
  49. NULL);
  50. Status = ExCreateCallback(&CallbackObject,
  51. &ObjectAttr,
  52. TRUE,
  53. TRUE);
  54. if (!NT_SUCCESS(Status))
  55. {
  56. DEBUGP(DL_ERROR, ("RegisterExCallBack: failed to create callback %lx\n", Status));
  57. bResult = FALSE;
  58. break;
  59. }
  60. CallbackRegisterationHandle = ExRegisterCallback(CallbackObject,
  61. ndisprotCallback,
  62. (PVOID)NULL);
  63. if (CallbackRegisterationHandle == NULL)
  64. {
  65. DEBUGP(DL_ERROR,("RegisterExCallBack: failed to register a Callback routine%lx\n", Status));
  66. bResult = FALSE;
  67. break;
  68. }
  69. ExNotifyCallback(CallbackObject,
  70. (PVOID)CALLBACK_SOURCE_NDISPROT,
  71. (PVOID)NULL);
  72. }while(FALSE);
  73. if(!bResult) {
  74. if (CallbackRegisterationHandle)
  75. {
  76. ExUnregisterCallback(CallbackRegisterationHandle);
  77. CallbackRegisterationHandle = NULL;
  78. }
  79. if (CallbackObject)
  80. {
  81. ObDereferenceObject(CallbackObject);
  82. CallbackObject = NULL;
  83. }
  84. }
  85. DEBUGP(DL_LOUD, ("<-- ndisprotRegisterExCallBack\n"));
  86. return bResult;
  87. }
  88. VOID
  89. ndisprotUnregisterExCallBack()
  90. {
  91. DEBUGP(DL_LOUD, ("--> ndisprotUnregisterExCallBack\n"));
  92. PAGED_CODE();
  93. if (CallbackRegisterationHandle)
  94. {
  95. ExUnregisterCallback(CallbackRegisterationHandle);
  96. CallbackRegisterationHandle = NULL;
  97. }
  98. if (CallbackObject)
  99. {
  100. ObDereferenceObject(CallbackObject);
  101. CallbackObject = NULL;
  102. }
  103. DEBUGP(DL_LOUD, ("<-- ndisprotUnregisterExCallBack\n"));
  104. }
  105. VOID
  106. ndisprotCallback(
  107. PVOID CallBackContext,
  108. PVOID Source,
  109. PVOID CallbackAddr
  110. )
  111. {
  112. NOTIFY_PRESENCE_CALLBACK func;
  113. DEBUGP(DL_LOUD, ("==>ndisprotoCallback: Source %lx, CallbackAddr %p\n",
  114. Source, CallbackAddr));
  115. //
  116. // if we are the one issuing this notification, just return
  117. //
  118. if (Source == CALLBACK_SOURCE_NDISPROT) {
  119. return;
  120. }
  121. //
  122. // Notification is coming from NDISWDM
  123. // let it know that you are here
  124. //
  125. ASSERT(Source == (PVOID)CALLBACK_SOURCE_NDISWDM);
  126. if(Source == (PVOID)CALLBACK_SOURCE_NDISWDM) {
  127. ASSERT(CallbackAddr);
  128. if (CallbackAddr == NULL)
  129. {
  130. DEBUGP(DL_ERROR, ("Callback called with invalid address %p\n", CallbackAddr));
  131. return;
  132. }
  133. func = CallbackAddr;
  134. func(CALLBACK_SOURCE_NDISPROT);
  135. }
  136. DEBUGP(DL_LOUD, ("<==ndisprotoCallback: Source, %lx\n", Source));
  137. }
  138. #endif