2015-06-29 17:03:33 +00:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#define YDEBUG
|
|
|
|
#include <ntddk.h>
|
|
|
|
#include <debug.h>
|
|
|
|
#include <initguid.h>
|
|
|
|
#include <hdaudio.h>
|
|
|
|
#include <stdio.h>
|
2019-09-27 11:13:49 +00:00
|
|
|
#include <ntstrsafe.h>
|
2015-06-29 17:03:33 +00:00
|
|
|
|
|
|
|
#define TAG_HDA 'bADH'
|
|
|
|
|
|
|
|
|
|
|
|
// include Haiku headers
|
|
|
|
#include "driver.h"
|
|
|
|
|
|
|
|
#define MAKE_RATE(base, multiply, divide) \
|
|
|
|
((base == 44100 ? FORMAT_44_1_BASE_RATE : 0) \
|
|
|
|
| ((multiply - 1) << FORMAT_MULTIPLY_RATE_SHIFT) \
|
|
|
|
| ((divide - 1) << FORMAT_DIVIDE_RATE_SHIFT))
|
|
|
|
|
|
|
|
#define HDAC_INPUT_STREAM_OFFSET(index) \
|
|
|
|
((index) * HDAC_STREAM_SIZE)
|
|
|
|
#define HDAC_OUTPUT_STREAM_OFFSET(num_input_streams, index) \
|
|
|
|
((num_input_streams + (index)) * HDAC_STREAM_SIZE)
|
|
|
|
#define HDAC_BIDIR_STREAM_OFFSET(num_input_streams, num_output_streams, index) \
|
|
|
|
((num_input_streams + num_output_streams \
|
|
|
|
+ (index)) * HDAC_STREAM_SIZE)
|
|
|
|
|
|
|
|
#define ALIGN(size, align) (((size) + align - 1) & ~(align - 1))
|
|
|
|
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
ULONG response;
|
|
|
|
ULONG flags;
|
|
|
|
}RIRB_RESPONSE, *PRIRB_RESPONSE;
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
PDEVICE_OBJECT ChildPDO;
|
|
|
|
ULONG FunctionGroup;
|
|
|
|
ULONG NodeId;
|
|
|
|
}HDA_CODEC_AUDIO_GROUP, *PHDA_CODEC_AUDIO_GROUP;
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
USHORT VendorId;
|
|
|
|
USHORT ProductId;
|
|
|
|
UCHAR Major;
|
|
|
|
UCHAR Minor;
|
|
|
|
UCHAR Revision;
|
|
|
|
UCHAR Stepping;
|
|
|
|
UCHAR Addr;
|
|
|
|
|
|
|
|
ULONG Responses[MAX_CODEC_RESPONSES];
|
|
|
|
ULONG ResponseCount;
|
2019-02-27 14:02:38 +00:00
|
|
|
KSEMAPHORE ResponseSemaphore;
|
2015-06-29 17:03:33 +00:00
|
|
|
|
|
|
|
PHDA_CODEC_AUDIO_GROUP AudioGroups[HDA_MAX_AUDIO_GROUPS];
|
|
|
|
ULONG AudioGroupCount;
|
|
|
|
|
|
|
|
}HDA_CODEC_ENTRY, *PHDA_CODEC_ENTRY;
|
|
|
|
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
BOOLEAN IsFDO;
|
|
|
|
PDEVICE_OBJECT LowerDevice;
|
2019-02-24 13:33:41 +00:00
|
|
|
|
2015-06-29 17:03:33 +00:00
|
|
|
PUCHAR RegBase;
|
2019-02-24 13:33:41 +00:00
|
|
|
SIZE_T RegLength;
|
2015-06-29 17:03:33 +00:00
|
|
|
PKINTERRUPT Interrupt;
|
|
|
|
|
|
|
|
ULONG CorbLength;
|
|
|
|
PULONG CorbBase;
|
|
|
|
ULONG RirbLength;
|
|
|
|
PRIRB_RESPONSE RirbBase;
|
|
|
|
ULONG RirbReadPos;
|
|
|
|
ULONG CorbWritePos;
|
|
|
|
PVOID StreamPositions;
|
|
|
|
|
|
|
|
PHDA_CODEC_ENTRY Codecs[HDA_MAX_CODECS + 1];
|
|
|
|
|
|
|
|
}HDA_FDO_DEVICE_EXTENSION, *PHDA_FDO_DEVICE_EXTENSION;
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
BOOLEAN IsFDO;
|
2019-02-25 12:47:14 +00:00
|
|
|
BOOLEAN ReportedMissing;
|
2015-06-29 17:03:33 +00:00
|
|
|
PHDA_CODEC_ENTRY Codec;
|
|
|
|
PHDA_CODEC_AUDIO_GROUP AudioGroup;
|
2015-07-02 11:07:39 +00:00
|
|
|
PDEVICE_OBJECT FDO;
|
2015-06-29 17:03:33 +00:00
|
|
|
}HDA_PDO_DEVICE_EXTENSION, *PHDA_PDO_DEVICE_EXTENSION;
|
|
|
|
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
ULONG device : 16;
|
|
|
|
ULONG vendor : 16;
|
|
|
|
ULONG stepping : 8;
|
|
|
|
ULONG revision : 8;
|
|
|
|
ULONG minor : 4;
|
|
|
|
ULONG major : 4;
|
|
|
|
ULONG _reserved0 : 8;
|
|
|
|
ULONG count : 8;
|
|
|
|
ULONG _reserved1 : 8;
|
|
|
|
ULONG start : 8;
|
|
|
|
ULONG _reserved2 : 8;
|
|
|
|
}CODEC_RESPONSE, *PCODEC_RESPONSE;
|
2015-06-30 11:36:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
PVOID
|
|
|
|
AllocateItem(
|
|
|
|
IN POOL_TYPE PoolType,
|
|
|
|
IN SIZE_T NumberOfBytes);
|
|
|
|
|
|
|
|
VOID
|
|
|
|
FreeItem(
|
|
|
|
IN PVOID Item);
|
|
|
|
|
|
|
|
/* fdo.cpp */
|
2019-02-27 13:34:23 +00:00
|
|
|
KSERVICE_ROUTINE HDA_InterruptService;
|
|
|
|
IO_DPC_ROUTINE HDA_DpcForIsr;
|
2015-06-30 11:36:52 +00:00
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
HDA_FDOStartDevice(
|
|
|
|
IN PDEVICE_OBJECT DeviceObject,
|
|
|
|
IN PIRP Irp);
|
|
|
|
|
2019-02-24 13:33:41 +00:00
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
HDA_FDORemoveDevice(
|
|
|
|
_In_ PDEVICE_OBJECT DeviceObject,
|
|
|
|
_Inout_ PIRP Irp);
|
|
|
|
|
2015-06-30 11:36:52 +00:00
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
HDA_FDOQueryBusRelations(
|
|
|
|
IN PDEVICE_OBJECT DeviceObject,
|
|
|
|
IN PIRP Irp);
|
|
|
|
|
2015-07-02 11:07:39 +00:00
|
|
|
VOID
|
|
|
|
HDA_SendVerbs(
|
|
|
|
IN PDEVICE_OBJECT DeviceObject,
|
|
|
|
IN PHDA_CODEC_ENTRY Codec,
|
|
|
|
IN PULONG Verbs,
|
|
|
|
OUT PULONG Responses,
|
|
|
|
IN ULONG Count);
|
|
|
|
|
2015-06-30 11:36:52 +00:00
|
|
|
/* pdo.cpp*/
|
|
|
|
|
2019-02-25 12:47:14 +00:00
|
|
|
NTSTATUS
|
|
|
|
HDA_PDORemoveDevice(
|
|
|
|
_In_ PDEVICE_OBJECT DeviceObject);
|
|
|
|
|
2015-06-30 11:36:52 +00:00
|
|
|
NTSTATUS
|
|
|
|
HDA_PDOQueryBusInformation(
|
|
|
|
IN PIRP Irp);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
HDA_PDOQueryId(
|
|
|
|
IN PDEVICE_OBJECT DeviceObject,
|
|
|
|
IN PIRP Irp);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
HDA_PDOHandleQueryDeviceText(
|
|
|
|
IN PIRP Irp);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
HDA_PDOQueryBusDeviceCapabilities(
|
|
|
|
IN PIRP Irp);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
HDA_PDOQueryBusDevicePnpState(
|
|
|
|
IN PIRP Irp);
|
|
|
|
|
|
|
|
/* businterface.cpp */
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
HDA_PDOHandleQueryInterface(
|
|
|
|
IN PDEVICE_OBJECT DeviceObject,
|
|
|
|
IN PIRP Irp);
|