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.

348 lines
7.9 KiB

  1. /*++
  2. Copyright (c) 1997-2000 Microsoft Corporation All Rights Reserved
  3. Module Name:
  4. mintopo.cpp
  5. Abstract:
  6. Implementation of topology miniport.
  7. --*/
  8. #include <msvad.h>
  9. #include <common.h>
  10. #include "pcmex.h"
  11. #include "minwave.h"
  12. #include "mintopo.h"
  13. #include "toptable.h"
  14. /*********************************************************************
  15. * Topology/Wave bridge connection *
  16. * *
  17. * +------+ +------+ *
  18. * | Wave | | Topo | *
  19. * | | | | *
  20. * Capture <---|0 1|<===|4 1|<--- Synth *
  21. * | | | | *
  22. * Render --->|2 3|===>|0 | *
  23. * +------+ | | *
  24. * | 2|<--- Mic *
  25. * | | *
  26. * | 3|---> Line Out *
  27. * +------+ *
  28. *********************************************************************/
  29. PHYSICALCONNECTIONTABLE TopologyPhysicalConnections =
  30. {
  31. KSPIN_TOPO_WAVEOUT_SOURCE, // TopologyIn
  32. KSPIN_TOPO_WAVEIN_DEST, // TopologyOut
  33. KSPIN_WAVE_CAPTURE_SOURCE, // WaveIn
  34. KSPIN_WAVE_RENDER_SOURCE // WaveOut
  35. };
  36. #pragma code_seg("PAGE")
  37. //=============================================================================
  38. NTSTATUS
  39. CreateMiniportTopologyMSVAD
  40. (
  41. OUT PUNKNOWN * Unknown,
  42. IN REFCLSID,
  43. IN PUNKNOWN UnknownOuter OPTIONAL,
  44. IN POOL_TYPE PoolType
  45. )
  46. /*++
  47. Routine Description:
  48. Creates a new topology miniport.
  49. Arguments:
  50. Unknown -
  51. RefclsId -
  52. UnknownOuter -
  53. PoolType -
  54. Return Value:
  55. NT status code.
  56. --*/
  57. {
  58. PAGED_CODE();
  59. ASSERT(Unknown);
  60. STD_CREATE_BODY(CMiniportTopology, Unknown, UnknownOuter, PoolType);
  61. } // CreateMiniportTopologyMSVAD
  62. //=============================================================================
  63. CMiniportTopology::~CMiniportTopology
  64. (
  65. void
  66. )
  67. /*++
  68. Routine Description:
  69. Topology miniport destructor
  70. Arguments:
  71. Return Value:
  72. NT status code.
  73. --*/
  74. {
  75. PAGED_CODE();
  76. DPF_ENTER(("[CMiniportTopology::~CMiniportTopology]"));
  77. } // ~CMiniportTopology
  78. //=============================================================================
  79. NTSTATUS
  80. CMiniportTopology::DataRangeIntersection
  81. (
  82. IN ULONG PinId,
  83. IN PKSDATARANGE ClientDataRange,
  84. IN PKSDATARANGE MyDataRange,
  85. IN ULONG OutputBufferLength,
  86. OUT PVOID ResultantFormat OPTIONAL,
  87. OUT PULONG ResultantFormatLength
  88. )
  89. /*++
  90. Routine Description:
  91. The DataRangeIntersection function determines the highest quality
  92. intersection of two data ranges.
  93. Arguments:
  94. PinId - Pin for which data intersection is being determined.
  95. ClientDataRange - Pointer to KSDATARANGE structure which contains the data range
  96. submitted by client in the data range intersection property
  97. request.
  98. MyDataRange - Pin's data range to be compared with client's data range.
  99. OutputBufferLength - Size of the buffer pointed to by the resultant format
  100. parameter.
  101. ResultantFormat - Pointer to value where the resultant format should be
  102. returned.
  103. ResultantFormatLength - Actual length of the resultant format that is placed
  104. at ResultantFormat. This should be less than or equal
  105. to OutputBufferLength.
  106. Return Value:
  107. NT status code.
  108. --*/
  109. {
  110. PAGED_CODE();
  111. return
  112. CMiniportTopologyMSVAD::DataRangeIntersection
  113. (
  114. PinId,
  115. ClientDataRange,
  116. MyDataRange,
  117. OutputBufferLength,
  118. ResultantFormat,
  119. ResultantFormatLength
  120. );
  121. } // DataRangeIntersection
  122. //=============================================================================
  123. STDMETHODIMP
  124. CMiniportTopology::GetDescription
  125. (
  126. OUT PPCFILTER_DESCRIPTOR * OutFilterDescriptor
  127. )
  128. /*++
  129. Routine Description:
  130. The GetDescription function gets a pointer to a filter description.
  131. It provides a location to deposit a pointer in miniport's description
  132. structure. This is the placeholder for the FromNode or ToNode fields in
  133. connections which describe connections to the filter's pins.
  134. Arguments:
  135. OutFilterDescriptor - Pointer to the filter description.
  136. Return Value:
  137. NT status code.
  138. --*/
  139. {
  140. PAGED_CODE();
  141. return
  142. CMiniportTopologyMSVAD::GetDescription(OutFilterDescriptor);
  143. } // GetDescription
  144. //=============================================================================
  145. STDMETHODIMP
  146. CMiniportTopology::Init
  147. (
  148. IN PUNKNOWN UnknownAdapter,
  149. IN PRESOURCELIST ResourceList,
  150. IN PPORTTOPOLOGY Port_
  151. )
  152. /*++
  153. Routine Description:
  154. The Init function initializes the miniport. Callers of this function
  155. should run at IRQL PASSIVE_LEVEL
  156. Arguments:
  157. UnknownAdapter - A pointer to the Iuknown interface of the adapter object.
  158. ResourceList - Pointer to the resource list to be supplied to the miniport
  159. during initialization. The port driver is free to examine the
  160. contents of the ResourceList. The port driver will not be
  161. modify the ResourceList contents.
  162. Port - Pointer to the topology port object that is linked with this miniport.
  163. Return Value:
  164. NT status code.
  165. --*/
  166. {
  167. PAGED_CODE();
  168. ASSERT(UnknownAdapter);
  169. ASSERT(Port_);
  170. DPF_ENTER(("[CMiniportTopology::Init]"));
  171. NTSTATUS ntStatus;
  172. ntStatus =
  173. CMiniportTopologyMSVAD::Init
  174. (
  175. UnknownAdapter,
  176. Port_
  177. );
  178. if (NT_SUCCESS(ntStatus))
  179. {
  180. m_FilterDescriptor = &MiniportFilterDescriptor;
  181. m_AdapterCommon->MixerMuxWrite(KSPIN_TOPO_MIC_SOURCE);
  182. }
  183. return ntStatus;
  184. } // Init
  185. //=============================================================================
  186. STDMETHODIMP
  187. CMiniportTopology::NonDelegatingQueryInterface
  188. (
  189. IN REFIID Interface,
  190. OUT PVOID * Object
  191. )
  192. /*++
  193. Routine Description:
  194. QueryInterface for MiniportTopology
  195. Arguments:
  196. Interface - GUID of the interface
  197. Object - interface object to be returned.
  198. Return Value:
  199. NT status code.
  200. --*/
  201. {
  202. PAGED_CODE();
  203. ASSERT(Object);
  204. if (IsEqualGUIDAligned(Interface, IID_IUnknown))
  205. {
  206. *Object = PVOID(PUNKNOWN(this));
  207. }
  208. else if (IsEqualGUIDAligned(Interface, IID_IMiniport))
  209. {
  210. *Object = PVOID(PMINIPORT(this));
  211. }
  212. else if (IsEqualGUIDAligned(Interface, IID_IMiniportTopology))
  213. {
  214. *Object = PVOID(PMINIPORTTOPOLOGY(this));
  215. }
  216. else
  217. {
  218. *Object = NULL;
  219. }
  220. if (*Object)
  221. {
  222. // We reference the interface for the caller.
  223. PUNKNOWN(*Object)->AddRef();
  224. return(STATUS_SUCCESS);
  225. }
  226. return(STATUS_INVALID_PARAMETER);
  227. } // NonDelegatingQueryInterface
  228. //=============================================================================
  229. NTSTATUS
  230. PropertyHandler_Topology
  231. (
  232. IN PPCPROPERTY_REQUEST PropertyRequest
  233. )
  234. /*++
  235. Routine Description:
  236. Redirects property request to miniport object
  237. Arguments:
  238. PropertyRequest -
  239. Return Value:
  240. NT status code.
  241. --*/
  242. {
  243. PAGED_CODE();
  244. ASSERT(PropertyRequest);
  245. DPF_ENTER(("[PropertyHandler_Topology]"));
  246. return ((PCMiniportTopology)
  247. (PropertyRequest->MajorTarget))->PropertyHandlerGeneric
  248. (
  249. PropertyRequest
  250. );
  251. } // PropertyHandler_Topology
  252. #pragma code_seg()