xref: /reactos/drivers/wdm/audio/hdaudbus/hdaudbus.h (revision e8c7597b)
1 #pragma once
2 
3 #include <ntddk.h>
4 #include <initguid.h>
5 #include <hdaudio.h>
6 #include <stdio.h>
7 #include <ntstrsafe.h>
8 
9 // Include Haiku headers
10 #include "driver.h"
11 
12 #define NDEBUG
13 #include <debug.h>
14 
15 #define TAG_HDA 'bADH'
16 
17 #define MAKE_RATE(base, multiply, divide) \
18 	((base == 44100 ? FORMAT_44_1_BASE_RATE : 0) \
19 		| ((multiply - 1) << FORMAT_MULTIPLY_RATE_SHIFT) \
20 		| ((divide - 1) << FORMAT_DIVIDE_RATE_SHIFT))
21 
22 #define HDAC_INPUT_STREAM_OFFSET(index) \
23 	((index) * HDAC_STREAM_SIZE)
24 #define HDAC_OUTPUT_STREAM_OFFSET(num_input_streams, index) \
25 	((num_input_streams + (index)) * HDAC_STREAM_SIZE)
26 #define HDAC_BIDIR_STREAM_OFFSET(num_input_streams, num_output_streams, index) \
27 	((num_input_streams + num_output_streams \
28 		+ (index)) * HDAC_STREAM_SIZE)
29 
30 #define ALIGN(size, align)	(((size) + align - 1) & ~(align - 1))
31 
32 typedef struct {
33 	ULONG response;
34 	ULONG flags;
35 }RIRB_RESPONSE, *PRIRB_RESPONSE;
36 
37 typedef struct
38 {
39 	PDEVICE_OBJECT ChildPDO;
40 	ULONG FunctionGroup;
41 	ULONG NodeId;
42 }HDA_CODEC_AUDIO_GROUP, *PHDA_CODEC_AUDIO_GROUP;
43 
44 typedef struct
45 {
46 	USHORT		VendorId;
47 	USHORT		ProductId;
48 	UCHAR		Major;
49 	UCHAR		Minor;
50 	UCHAR		Revision;
51 	UCHAR		Stepping;
52 	UCHAR		Addr;
53 
54 	ULONG Responses[MAX_CODEC_RESPONSES];
55 	ULONG ResponseCount;
56 	KSEMAPHORE ResponseSemaphore;
57 
58 	PHDA_CODEC_AUDIO_GROUP AudioGroups[HDA_MAX_AUDIO_GROUPS];
59 	ULONG AudioGroupCount;
60 
61 }HDA_CODEC_ENTRY, *PHDA_CODEC_ENTRY;
62 
63 typedef struct
64 {
65 	BOOLEAN IsFDO;
66 	PDEVICE_OBJECT LowerDevice;
67 
68 	PUCHAR RegBase;
69 	SIZE_T RegLength;
70 	PKINTERRUPT Interrupt;
71 
72 	ULONG CorbLength;
73 	PULONG CorbBase;
74 	ULONG RirbLength;
75 	PRIRB_RESPONSE RirbBase;
76 	ULONG RirbReadPos;
77 	ULONG CorbWritePos;
78 	PVOID StreamPositions;
79 
80 	PHDA_CODEC_ENTRY Codecs[HDA_MAX_CODECS + 1];
81 
82 }HDA_FDO_DEVICE_EXTENSION, *PHDA_FDO_DEVICE_EXTENSION;
83 
84 typedef struct
85 {
86 	BOOLEAN IsFDO;
87 	BOOLEAN ReportedMissing;
88 	PHDA_CODEC_ENTRY Codec;
89 	PHDA_CODEC_AUDIO_GROUP AudioGroup;
90 	PDEVICE_OBJECT FDO;
91 }HDA_PDO_DEVICE_EXTENSION, *PHDA_PDO_DEVICE_EXTENSION;
92 
93 typedef struct {
94 	ULONG device : 16;
95 	ULONG vendor : 16;
96 	ULONG stepping : 8;
97 	ULONG revision : 8;
98 	ULONG minor : 4;
99 	ULONG major : 4;
100 	ULONG _reserved0 : 8;
101 	ULONG count : 8;
102 	ULONG _reserved1 : 8;
103 	ULONG start : 8;
104 	ULONG _reserved2 : 8;
105 }CODEC_RESPONSE, *PCODEC_RESPONSE;
106 
107 PVOID
108 AllocateItem(
109     IN POOL_TYPE PoolType,
110     IN SIZE_T NumberOfBytes);
111 
112 VOID
113 FreeItem(
114     IN PVOID Item);
115 
116 /* fdo.cpp */
117 
118 KSERVICE_ROUTINE HDA_InterruptService;
119 IO_DPC_ROUTINE HDA_DpcForIsr;
120 
121 NTSTATUS
122 NTAPI
123 HDA_FDOStartDevice(
124     IN PDEVICE_OBJECT DeviceObject,
125     IN PIRP Irp);
126 
127 NTSTATUS
128 NTAPI
129 HDA_FDORemoveDevice(
130     _In_ PDEVICE_OBJECT DeviceObject,
131     _Inout_ PIRP Irp);
132 
133 NTSTATUS
134 NTAPI
135 HDA_FDOQueryBusRelations(
136     IN PDEVICE_OBJECT DeviceObject,
137     IN PIRP Irp);
138 
139 NTSTATUS
140 HDA_SendVerbs(
141     IN PDEVICE_OBJECT DeviceObject,
142     IN PHDA_CODEC_ENTRY Codec,
143     IN PULONG Verbs,
144     OUT PULONG Responses,
145     IN ULONG Count);
146 
147 /* pdo.cpp*/
148 
149 NTSTATUS
150 HDA_PDORemoveDevice(
151     _In_ PDEVICE_OBJECT DeviceObject);
152 
153 NTSTATUS
154 HDA_PDOQueryBusInformation(
155     IN PIRP Irp);
156 
157 NTSTATUS
158 NTAPI
159 HDA_PDOQueryId(
160     IN PDEVICE_OBJECT DeviceObject,
161     IN PIRP Irp);
162 
163 NTSTATUS
164 HDA_PDOHandleQueryDeviceText(
165     IN PIRP Irp);
166 
167 NTSTATUS
168 HDA_PDOQueryBusDeviceCapabilities(
169     IN PIRP Irp);
170 
171 NTSTATUS
172 HDA_PDOQueryBusDevicePnpState(
173     IN PIRP Irp);
174 
175 /* businterface.cpp */
176 
177 NTSTATUS
178 HDA_PDOHandleQueryInterface(
179     IN PDEVICE_OBJECT DeviceObject,
180     IN PIRP Irp);
181