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.

476 lines
13 KiB

  1. //---------------------------------------------------------------------------
  2. //
  3. // Module: fn.h
  4. //
  5. // Description: filter node classes
  6. //
  7. // Filter nodes represent the physical ks filter and along with PinInfo,
  8. // PinNodes, TopologyNodes, TopologyPins, TopologyConnections objects
  9. // represent the whole filter. These objects are built when sysaudio
  10. // is notified via audio class device interfaces arrivals.
  11. //
  12. // There is some info read from the registry for each filter. Various
  13. // defaults can be overriden:
  14. //
  15. // Device Parameters/Sysaudio/Disabled DWORD
  16. //
  17. // If !0, the filter isn't profiled or used in any graph.
  18. //
  19. // Device Parameters/Sysaudio/Capture DWORD
  20. //
  21. // If !0, puts the filters in the capture side of the graph. See
  22. // the FILTER_TYPE_CAPTURE define for the particular default of
  23. // a filter type.
  24. //
  25. // Device Parameters/Sysaudio/Render DWORD
  26. //
  27. // If !0, puts the filters in the render side of the graph. See
  28. // the FILTER_TYPE_RENDER define for the particular default of
  29. // a filter type.
  30. //
  31. // Device Parameters/Sysaudio/Order DWORD
  32. //
  33. // Overrides the default order in the graph. See the ORDER_XXXX
  34. // defines below for the default.
  35. //
  36. // Device Parameters/Sysaudio/Device STRING
  37. //
  38. // The device interface (in the KSCATEGORY_AUDIO class) of the
  39. // renderer and/or capturer device graph to put this filter. The
  40. // default is to put the filter in all device graphs.
  41. //
  42. //@@BEGIN_MSINTERNAL
  43. // Development Team:
  44. // Mike McLaughlin
  45. //
  46. // History: Date Author Comment
  47. //
  48. //@@END_MSINTERNAL
  49. //---------------------------------------------------------------------------
  50. //
  51. // THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY
  52. // KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
  53. // IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A PARTICULAR
  54. // PURPOSE.
  55. //
  56. // Copyright (c) 1996-1999 Microsoft Corporation. All Rights Reserved.
  57. //
  58. //---------------------------------------------------------------------------
  59. //---------------------------------------------------------------------------
  60. // Constants and Macros
  61. //---------------------------------------------------------------------------
  62. #define OVERHEAD_NONE 0
  63. #define OVERHEAD_LOWEST 1
  64. #define OVERHEAD_LOW 0x00001000
  65. #define OVERHEAD_HARDWARE 0x00010000
  66. #define OVERHEAD_MEDIUM 0x00100000
  67. #define OVERHEAD_SOFTWARE 0x01000000
  68. #define OVERHEAD_HIGH 0x10000000
  69. #define OVERHEAD_HIGHEST MAXULONG
  70. //---------------------------------------------------------------------------
  71. //!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
  72. // MAKE SURE THAT NO FILTER ORDER IS ADDED BETWEEN GFX_FIRST & GFX_LAST
  73. //!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
  74. #define ORDER_NONE 0
  75. #define ORDER_LOWEST 1
  76. #define ORDER_ENDPOINT 1
  77. #define ORDER_VIRTUAL 0x10000000
  78. #define ORDER_MIC_ARRAY_PROCESSOR 0x15000000
  79. #define ORDER_AEC 0x40000000
  80. #define ORDER_GFX 0x50000000
  81. #define ORDER_SPLITTER 0x20000000
  82. #define ORDER_MIXER 0xA0000000
  83. #define ORDER_SYNTHESIZER 0xB0000000
  84. #define ORDER_DATA_TRANSFORM 0xB0000000
  85. #define ORDER_DRM_DESCRAMBLE 0xB0000000
  86. #define ORDER_INTERFACE_TRANSFORM 0xC0000000
  87. #define ORDER_HIGHEST MAXULONG
  88. #define ORDER_CAPTURE_GFX_LAST (ORDER_SPLITTER-1)
  89. #define ORDER_CAPTURE_GFX_FIRST 0x10000001
  90. #define ORDER_RENDER_GFX_LAST ORDER_GFX
  91. #define ORDER_RENDER_GFX_FIRST (ORDER_AEC+1)
  92. //---------------------------------------------------------------------------
  93. #define FILTER_TYPE_AUDIO 0x00000001
  94. #define FILTER_TYPE_TOPOLOGY 0x00000002
  95. #define FILTER_TYPE_BRIDGE 0x00000004
  96. #define FILTER_TYPE_RENDERER 0x00000008
  97. #define FILTER_TYPE_CAPTURER 0x00000010
  98. #define FILTER_TYPE_MIXER 0x00000020
  99. #define FILTER_TYPE_GFX 0x00000040
  100. #define FILTER_TYPE_AEC 0x00000080
  101. #define FILTER_TYPE_DATA_TRANSFORM 0x00000100
  102. #define FILTER_TYPE_COMMUNICATION_TRANSFORM 0x00000200
  103. #define FILTER_TYPE_INTERFACE_TRANSFORM 0x00000400
  104. #define FILTER_TYPE_MEDIUM_TRANSFORM 0x00000800
  105. #define FILTER_TYPE_SPLITTER 0x00001000
  106. #define FILTER_TYPE_SYNTHESIZER 0x00002000
  107. #define FILTER_TYPE_DRM_DESCRAMBLE 0x00004000
  108. #define FILTER_TYPE_MIC_ARRAY_PROCESSOR 0x00008000
  109. #define FILTER_TYPE_VIRTUAL 0x00010000
  110. #define FILTER_TYPE_ENDPOINT (FILTER_TYPE_BRIDGE | \
  111. FILTER_TYPE_RENDERER | \
  112. FILTER_TYPE_CAPTURER)
  113. #define FILTER_TYPE_LOGICAL_FILTER (FILTER_TYPE_MIXER | \
  114. FILTER_TYPE_GFX | \
  115. FILTER_TYPE_AEC | \
  116. FILTER_TYPE_DATA_TRANSFORM | \
  117. FILTER_TYPE_INTERFACE_TRANSFORM | \
  118. FILTER_TYPE_SPLITTER | \
  119. FILTER_TYPE_SYNTHESIZER | \
  120. FILTER_TYPE_DRM_DESCRAMBLE | \
  121. FILTER_TYPE_MIC_ARRAY_PROCESSOR | \
  122. FILTER_TYPE_VIRTUAL)
  123. #define FILTER_TYPE_RENDER (FILTER_TYPE_INTERFACE_TRANSFORM | \
  124. FILTER_TYPE_GFX | \
  125. FILTER_TYPE_AEC | \
  126. FILTER_TYPE_MIXER | \
  127. FILTER_TYPE_SYNTHESIZER | \
  128. FILTER_TYPE_DRM_DESCRAMBLE | \
  129. FILTER_TYPE_VIRTUAL)
  130. #define FILTER_TYPE_CAPTURE (FILTER_TYPE_AEC | \
  131. FILTER_TYPE_MIC_ARRAY_PROCESSOR | \
  132. FILTER_TYPE_MIXER | \
  133. FILTER_TYPE_SPLITTER)
  134. #define FILTER_TYPE_PRE_MIXER (FILTER_TYPE_SYNTHESIZER | \
  135. FILTER_TYPE_DRM_DESCRAMBLE | \
  136. FILTER_TYPE_INTERFACE_TRANSFORM )
  137. #define FILTER_TYPE_NORMAL_TOPOLOGY (FILTER_TYPE_INTERFACE_TRANSFORM | \
  138. FILTER_TYPE_GFX | \
  139. FILTER_TYPE_ENDPOINT | \
  140. FILTER_TYPE_AEC | \
  141. FILTER_TYPE_MIC_ARRAY_PROCESSOR | \
  142. FILTER_TYPE_SYNTHESIZER | \
  143. FILTER_TYPE_DRM_DESCRAMBLE | \
  144. FILTER_TYPE_MIXER | \
  145. FILTER_TYPE_SPLITTER)
  146. #define FILTER_TYPE_MIXER_TOPOLOGY (FILTER_TYPE_VIRTUAL)
  147. #define FILTER_TYPE_NO_BYPASS (FILTER_TYPE_GFX)
  148. #define FILTER_TYPE_NOT_SELECT (FILTER_TYPE_AEC | \
  149. FILTER_TYPE_MIC_ARRAY_PROCESSOR)
  150. #define FILTER_TYPE_GLOBAL_SELECT (FILTER_TYPE_AEC)
  151. #define FILTER_TYPE_DUP_FOR_CAPTURE (FILTER_TYPE_MIXER)
  152. //---------------------------------------------------------------------------
  153. #define FN_FLAGS_RENDER 0x00000001
  154. #define FN_FLAGS_NO_RENDER 0x00000002
  155. #define FN_FLAGS_CAPTURE 0x00000004
  156. #define FN_FLAGS_NO_CAPTURE 0x00000008
  157. //---------------------------------------------------------------------------
  158. // Class List Definitions
  159. //---------------------------------------------------------------------------
  160. typedef ListDoubleDestroy<CFilterNode> LIST_FILTER_NODE, *PLIST_FILTER_NODE;
  161. //---------------------------------------------------------------------------
  162. typedef ListData<CFilterNode> LIST_DATA_FILTER_NODE, *PLIST_DATA_FILTER_NODE;
  163. //---------------------------------------------------------------------------
  164. typedef ListDataAssertLess<WCHAR> LIST_WSTR;
  165. //---------------------------------------------------------------------------
  166. // Classes
  167. //---------------------------------------------------------------------------
  168. typedef class CFilterNode : public CListDoubleItem
  169. {
  170. public:
  171. CFilterNode(
  172. ULONG fulType
  173. );
  174. ~CFilterNode(
  175. );
  176. NTSTATUS
  177. Create(
  178. PWSTR pwstrDeviceInterface
  179. );
  180. NTSTATUS
  181. ProfileFilter(
  182. PFILE_OBJECT pFileObject
  183. );
  184. NTSTATUS
  185. DuplicateForCapture(
  186. );
  187. ENUMFUNC
  188. Destroy(
  189. )
  190. {
  191. Assert(this);
  192. delete this;
  193. return(STATUS_CONTINUE);
  194. };
  195. NTSTATUS
  196. OpenDevice(
  197. OUT PHANDLE pHandle
  198. )
  199. {
  200. ASSERT(pwstrDeviceInterface != NULL);
  201. return(::OpenDevice(pwstrDeviceInterface, pHandle));
  202. };
  203. BOOL
  204. IsDeviceInterfaceMatch(
  205. PDEVICE_NODE pDeviceNode
  206. );
  207. NTSTATUS
  208. AddDeviceInterfaceMatch(
  209. PWSTR pwstr
  210. )
  211. {
  212. return(lstwstrDeviceInterfaceMatch.AddList(pwstr));
  213. };
  214. ULONG
  215. GetFlags(
  216. )
  217. {
  218. return(ulFlags);
  219. };
  220. VOID
  221. SetRenderOnly(
  222. )
  223. {
  224. PLOGICAL_FILTER_NODE pLogicalFilterNode;
  225. FOR_EACH_LIST_ITEM(&lstLogicalFilterNode, pLogicalFilterNode) {
  226. pLogicalFilterNode->SetRenderOnly();
  227. } END_EACH_LIST_ITEM
  228. };
  229. VOID
  230. SetCaptureOnly(
  231. )
  232. {
  233. PLOGICAL_FILTER_NODE pLogicalFilterNode;
  234. FOR_EACH_LIST_ITEM(&lstLogicalFilterNode, pLogicalFilterNode) {
  235. pLogicalFilterNode->SetCaptureOnly();
  236. } END_EACH_LIST_ITEM
  237. };
  238. ULONG
  239. GetOrder(
  240. )
  241. {
  242. return(ulOrder);
  243. };
  244. VOID
  245. SetOrder(
  246. ULONG ulOrder
  247. )
  248. {
  249. PLOGICAL_FILTER_NODE pLogicalFilterNode;
  250. FOR_EACH_LIST_ITEM(&lstLogicalFilterNode, pLogicalFilterNode) {
  251. pLogicalFilterNode->SetOrder(ulOrder);
  252. } END_EACH_LIST_ITEM
  253. this->ulOrder = ulOrder;
  254. };
  255. ULONG
  256. GetType(
  257. )
  258. {
  259. return(fulType);
  260. };
  261. VOID
  262. SetType(
  263. ULONG fulType
  264. );
  265. VOID
  266. SetRenderCaptureFlags(
  267. ULONG fulFlags
  268. )
  269. {
  270. //
  271. // 1 & 2 should be changed to use public header files
  272. //
  273. if (fulFlags == 1) {
  274. ulFlags |= FN_FLAGS_RENDER | FN_FLAGS_NO_CAPTURE;
  275. } else if (fulFlags == 2) {
  276. ulFlags |= FN_FLAGS_CAPTURE | FN_FLAGS_NO_RENDER;
  277. }
  278. else {
  279. Trap();
  280. }
  281. }
  282. PFILE_OBJECT
  283. GetFileObject(
  284. )
  285. {
  286. return(pFileObject);
  287. }
  288. VOID
  289. SetFileDetails(
  290. HANDLE Handle,
  291. PFILE_OBJECT pFileObject,
  292. PEPROCESS pProcess
  293. )
  294. {
  295. this->hFileHandle = Handle;
  296. this->pFileObject = pFileObject;
  297. this->pProcess = pProcess;
  298. }
  299. NTSTATUS
  300. ClearFileDetails(
  301. )
  302. {
  303. NTSTATUS Status;
  304. ::ObDereferenceObject(this->pFileObject);
  305. this->pFileObject = NULL;
  306. this->hFileHandle = 0;
  307. this->pProcess = NULL;
  308. return(STATUS_SUCCESS);
  309. }
  310. BOOL
  311. CFilterNode::DoesGfxMatch(
  312. HANDLE hGfx,
  313. PWSTR pwstrDeviceName,
  314. ULONG GfxOrder
  315. );
  316. NTSTATUS
  317. CreatePin(
  318. PKSPIN_CONNECT pPinConnect,
  319. ACCESS_MASK Access,
  320. PHANDLE pHandle
  321. );
  322. PKSCOMPONENTID
  323. GetComponentId(
  324. )
  325. {
  326. return(ComponentId);
  327. };
  328. PWSTR
  329. GetFriendlyName(
  330. )
  331. {
  332. return(pwstrFriendlyName);
  333. };
  334. VOID
  335. SetFriendlyName(
  336. PWSTR pwstr
  337. )
  338. {
  339. pwstrFriendlyName = pwstr;
  340. };
  341. PWSTR
  342. GetDeviceInterface(
  343. )
  344. {
  345. return(pwstrDeviceInterface);
  346. };
  347. #ifdef DEBUG
  348. ENUMFUNC Dump();
  349. PSZ DumpName()
  350. {
  351. return(DbgUnicode2Sz(pwstrFriendlyName));
  352. };
  353. PSZ DumpDeviceInterface()
  354. {
  355. return(DbgUnicode2Sz(pwstrDeviceInterface));
  356. };
  357. #endif
  358. PDEVICE_NODE pDeviceNode;
  359. LIST_PIN_INFO lstPinInfo;
  360. LIST_TOPOLOGY_NODE lstTopologyNode;
  361. LIST_DESTROY_TOPOLOGY_CONNECTION lstTopologyConnection;
  362. LIST_DESTROY_LOGICAL_FILTER_NODE lstLogicalFilterNode;
  363. LIST_DATA_FILTER_NODE lstConnectedFilterNode;
  364. CLIST_DATA lstFreeMem; // list of blocks to free
  365. private:
  366. LIST_WSTR lstwstrDeviceInterfaceMatch;
  367. PWSTR pwstrDeviceInterface;
  368. PWSTR pwstrFriendlyName;
  369. ULONG ulFlags;
  370. ULONG fulType;
  371. ULONG ulOrder;
  372. PKSCOMPONENTID ComponentId;
  373. PFILE_OBJECT pFileObject;
  374. HANDLE hFileHandle;
  375. PEPROCESS pProcess;
  376. public:
  377. ULONG cPins;
  378. DefineSignature(0x20204E46); // FN
  379. } FILTER_NODE, *PFILTER_NODE;
  380. //---------------------------------------------------------------------------
  381. // Inline functions
  382. //---------------------------------------------------------------------------
  383. inline ULONG
  384. CLogicalFilterNode::GetType(
  385. )
  386. {
  387. return(pFilterNode->GetType());
  388. }
  389. //---------------------------------------------------------------------------
  390. // Globals
  391. //---------------------------------------------------------------------------
  392. extern PLIST_FILTER_NODE gplstFilterNode;
  393. //---------------------------------------------------------------------------
  394. // Local prototypes
  395. //---------------------------------------------------------------------------
  396. NTSTATUS
  397. InitializeFilterNode(
  398. );
  399. VOID
  400. UninitializeFilterNode(
  401. );
  402. #ifdef DEBUG
  403. VOID
  404. DumpSysAudio(
  405. );
  406. #endif
  407. //---------------------------------------------------------------------------