次の方法で共有


!acxkd

!acxkd 拡張機能は、オーディオ クラス拡張 (ACX) ドライバーに関する情報を表示します。 ACX の詳細については、「 ACX オーディオ クラス拡張機能の概要を参照してください。

構文

!acxkd.[Options]

DLL

Acxkd.dll

デバッガーのバージョン

!acxkd 拡張機能は、WinDbg バージョン 1.2402.24001.0 以降で使用できます。

ACX 1.0 のデバッグ

!acxkd デバッガー拡張機能は、ACX 1.0 で部分的な機能のみを提供します。 ACX 1.1 への更新をお勧めします。

パラメーター

オプション - 表示する情報の種類を指定します。

オプション 説明 パラメーター
!help 使用可能な拡張コマンドに関する情報を表示します。 [<command name>]
!acxcircuit ACXCIRCUIT オブジェクトをダンプします。 <circuit> - ACXCIRCUIT WDF ハンドル
!acxdataformat ACXDATAFORMAT オブジェクトをダンプします。 <dataformat> - ACXDATAFORMAT WDF ハンドル
!acxdataformatlist ACXDATAFORMATLIST オブジェクトをダンプします。 <dataformatlist> - ACXDATAFORMATLIST WDF ハンドル
!acxdevice ACXDEVICE オブジェクトをダンプします。 <device> - ACXDEVICE WDF ハンドル
!acxelement ACXELEMENT オブジェクトをダンプします。 <element> - ACXELEMENT WDF ハンドル
!acxevents ACXOBJECT オブジェクトのダンプ イベント。 <events> - ACXOBJECT WDF ハンドル
!acxfactory ACXFACTORYCIRCUT オブジェクトをダンプします。 <factory> - ACXFACTORYCIRCUIT WDF ハンドル
!acxmanager ACXMANAGER オブジェクトをダンプします。 なし
!acxmethods ACXOBJECT オブジェクトのダンプ メソッド。 <object> - ACXOBJECT WDF ハンドル
!acxobjbag ACXOBJECTBAG オブジェクトをダンプします。 <objbag> - ACXOBJECTBAG WDF ハンドル
!acxobject ACXOBJECT オブジェクトをダンプします。 <object> - ACXOBJECT WDF ハンドル
!acxpin ACXPIN オブジェクトをダンプします。 <pin> - ACXPIN WDF ハンドル
!acxproperties ACXOBJECT オブジェクトのダンプ プロパティ。 <properties> - ACXOBJECT WDF ハンドル
!acxstream ACXSTREAM オブジェクトをダンプします。 <stream> - ACXSTREAM ハンドル
!acxstreambridge ACXSTREAMBRIDGE オブジェクトをダンプします。 <bridge> - ACXSTREAMBRIDGE ハンドル
!acxtarget ACXTARGET オブジェクトをダンプします。 <target> - ACXTARGET WDF ハンドル
!acxtemplate ACXTEMPLATE オブジェクトをダンプします。 <tmpt> - ACXTEMPLATE ハンドル

解説

!acxkd.help

使用可能なすべてのコマンドを一覧表示するには、acxkd !help コマンドを使用します。

0: kd> !acxkd.help
Commands for C:\Debugger\acxkd.dll:
  !acxcircuit        - Dump a ACXCIRCUT object.
  !acxdataformat     - Dump a ACXDATAFORMAT object.
  !acxdataformatlist - Dump a ACXDATAFORMATLIST object.
  !acxdevice         - Dump a ACXDEVICE object.
  !acxelement        - Dump a ACXELEMENT object.
  !acxevents         - Dump events of a ACXOBJECT object.
  !acxfactory        - Dump a ACXFACTORYCIRCUT object.
  !acxmanager        - Dump a ACXMANAGER object.
  !acxmethods        - Dump methods of a ACXOBJECT object.
  !acxobjbag         - Dump a ACXOBJECTBAG object.
  !acxobject         - Dump a ACXOBJECT* object.
  !acxpin            - Dump a ACXPIN object.
  !acxproperties     - Dump properties of a ACXOBJECT object.
  !acxstream         - Dump a ACXSTREAM object.
  !acxstreambridge   - Dump a ACXSTREAMBRIDGE object.
  !acxtarget         - Dump a ACXTARGET* object.
  !acxtemplate       - Dump a ACX*TEMPLATE object.
  !help              - Displays information on available extension commands
!help <cmd> will give more information for a particular command

!acxdevice コマンドなど、コマンドの詳細については、acxkd !help コマンドを使用します。

0: kd> !acxkd.help acxdevice
!acxdevice <device>
  <device> - ACXDEVICE handle
Dump a ACXDEVICE object.

ACX ドライバーを調べる開始点として!acxdevice コマンドを使用します。

3: kd> !acxdevice 0x00007dfadb0a5358
Dumping info for ACXDEVICE 0x00007dfadb0a5358

    In connected standby: FALSE

    State: AfxDeviceStateInitialized
    State history:
        0 : AfxDeviceStateInvalid
        1 : AfxDeviceStateInvalid
        2 : AfxDeviceStateInvalid
        3 : AfxDeviceStateInvalid
        4 : AfxDeviceStateInvalid
        5 : AfxDeviceStateCreated
        6 : AfxDeviceStateInitializing
        7 : AfxDeviceStateInitialized

    Create dispatch list:
        Create name: eHDMIOutTopo
        Dispatch routine: fffff80393179918
        Dispatch context: ffff82052513b960

    Circuits:
        ----------------------------------

        [Circuit 0]

        Name: eHDMIOutTopo
        Type: AcxCircuitTypeRender
        ComponentId: {BFCA9AD9-4EED-46C2-9323-B5D4400761A5}

        State: AfxCircuitStatePoweredUp

        Interface is enabled
        SymolicLinkName: \??\HDAUDIO#SUBFUNC_01&VEN_8086&DEV_281F&NID_0001&SUBSYS_00000000&REV_1000#6&4948348&0&0002&00000025#{2c6bb644-e1ae-47f8-9a2b-1d1fa750f2fa}\eHDMIOutTopo

        !acxproperties 00007dfad9ccccb8
        !acxmethods 00007dfad9ccccb8
        !acxevents 00007dfad9ccccb8

        # Pins: 2
            !acxpin 00007dfadf996dd8
            !acxpin 00007dfad4697238

        # Elements: 1
            !acxelement 00007dfadf997a18

        # Streams: 0

        !acxcircuit 00007dfad9ccccb8

    !wdfqueue 00007dfade9beaf8
    !wdfdevice 00007dfadb0a5358

    !wdfhandle 00007dfadb0a5358
    dt Acx01000!Acx::AfxDevice ffff8205256ab420

!acxproperties、!acxmethods、!acxevents コマンドを使用して情報を表示するには、出力内のリンクをクリックします。

ACXDEVICE オブジェクトの wdfhandle の検索については、この記事の「 Example ACX ドライバーのチュートリアル を参照してください。

WDF コマンド - !wdfkd.wdfldr

ACX ドライバーは WDF ドライバーであり、任意の WDF カーネル デバッガー コマンドを使用します。 たとえば、 !wdfkd.wdfldr を使用して、バージョン情報と WDF を使用した ACX バインディングを表示します。

0: kd> !wdfldr acx01000
WDF Driver: Acx01000
----------------------------------
CLIENT_MODULE   0xffff82052abdcbc0
  WDF Version   v1.31
  ImageName     Acx01000.sys
  ImageAddress  0xfffff80393150000
  ImageSize     0xb3000
  BindingList   0xffff82052abdcc08

  ImageName        WdfVer Ver   WdfGlobals         BindInfo           ImageAddress       ImageSize
  Wdf01000.sys     v1.33  v1.33 0xffff8205218d8fb0 0xffff8205218d8df0 0xfffff80356a00000 0x000c7000
----------------------------------
CLASS_MODULE    0xffff820525b3dc90
  WDF Version   v1.31
  Version       v1.1
  Service       \Registry\Machine\System\CurrentControlSet\Services\acx01000
  ImageName     Acx01000.sys
  ImageAddress  0xfffff80393150000
  ImageSize     0xb3000
  ClientsList   0xffff820525b3dcf8
  Associated Clients: 1

  ImageName        WdfVer Ver   WdfGlobals         BindInfo           ImageAddress       ImageSize
  AcxHdAudio.sys   v1.25  v1.0  0xffff820527f70ae0 0xfffff803930df3e8 0xfffff803930c0000 0x0008a000
----------------------------------

!acxkd.acxmanager

!acxmanager コマンドを使用して、ACXMANAGER オブジェクトに関する情報を表示します。 これにより、ACX ドライバーを調査するための適切な開始点が提供されます。

この例は、mulitcircuit ACX 構成に提供される広範な !acxmanager 出力の最初の部分を示しています。

10: kd> !acxmanager
Dumping info for ACXMANAGER 0x000054f94d1d4378

    Delete pending: No

    # singleton composites: 8
        ----------------------------------

        [Composite 0]

        State: AfxCompositeStateActive
        !acxobjbag 000054f94c8e61c8
        !acxtemplate 000054f94c014d28
        !acxobject 000054f94c0141c8

        # circuits: 3
            ----------------------------------
            [Circuit 0 CORE]
…

この出力例は、1 つの ACX 回線を示しています。

0: kd> !acxmanager
Dumping info for ACXMANAGER 0x000049f6c3c769f8

    Delete pending: No

    # singleton composites: 0
    # Composite factories: 0
    !wdfhandle 000049f6c3c769f8
    dt Acx01000!Acx::AfxManager ffffb6093c3896b0

!acxkd.acxobject

!acxmanager の出力では、wdfhandle のアドレスが提供されます。 !acxobject コマンドで wdfhandle アドレスを使用して、ACXMANAGER またはその他の ACX オブジェクトに関する情報を表示します。

0: kd> !acxobject 000049f6c3c769f8
Dumping info for ACXMANAGER 0x000049f6c3c769f8

    Delete pending: No

    # singleton composites: 0
    # Composite factories: 0
    !wdfhandle 000049f6c3c769f8
    dt Acx01000!Acx::AfxManager ffffb6093c3896b0

上記の出力の dt リンクをクリックすると、内部 ACX オブジェクト構造の詳細が表示されます。

0: kd> dt Acx01000!Acx::AfxManager ffffb6093c3896b0
   +0x000 m_Object         : 0x000049f6`c3c769f8 ACXMANAGER__
   =fffff803`8a478ad8 s_AfxManager     : 0xffffb609`3c3896b0 Acx::AfxManager
   +0x008 m_AcxGlobals     : 0xffffb609`403cae24 _ACX_DRIVER_GLOBALS
   +0x010 m_Flags          : 0
   +0x010 m_Unloading      : 0y0
   +0x018 m_CompositesMutex : _FAST_MUTEX
   +0x050 m_CompositeFactoriesList : _LIST_ENTRY [ 0xffffb609`3c389700 - 0xffffb609`3c389700 ]
   +0x060 m_CompositeFactoriesCount : 0n0
   +0x068 m_CompositesList : _LIST_ENTRY [ 0xffffb609`3c389718 - 0xffffb609`3c389718 ]
   +0x078 m_CompositesCount : 0n0
   +0x080 m_FactoriesList  : _LIST_ENTRY [ 0xffffb609`3c389730 - 0xffffb609`3c389730 ]
   +0x090 m_CircuitsList   : _LIST_ENTRY [ 0xffffb609`40a27068 - 0xffffb609`40a27068 ]
   +0x0a0 m_FiltersMutex   : _FAST_MUTEX
   +0x0d8 m_FactoryFiltersList : _LIST_ENTRY [ 0xffffb609`3c389788 - 0xffffb609`3c389788 ]
   +0x0e8 m_CircuitFiltersList : _LIST_ENTRY [ 0xffffb609`3c389798 - 0xffffb609`3c389798 ]
   +0x0f8 m_FactoriesNotificationHandle : 0xffffc70c`b2356790 Void
   +0x100 m_CircuitsNotificationHandle : 0xffffc70c`b2357ec0 Void
   +0x108 m_CommandQueue   : 0xffffb609`3ffc5400 Acx::AfxWorkQueue

デバッガーの出力には、ACXMANAGER、ACXCIRCUITFACTORY、ACXCIRCUITFACTORY などのパブリック ACX オブジェクトと、不透明として定義されている内部構造体が混在している場合があることに注意してください。 内部型は、同じままであること、または ACX の異なるリリースで利用できることは保証されておらず、直接呼び出したり使用したりしてはなりません。

ACX オブジェクトは WDF オブジェクトであるため、 !wdfkd.wdfhandle コマンドを使用して、ACXMANAGER オブジェクトに関する追加情報を表示できます。

0: kd> !wdfhandle 000049f6c3c769f8
Treating handle as a KMDF handle!

Dumping WDFHANDLE 0x000049f6c3c769f8
=============================
Handle type is WDFOBJECT [ACXMANAGER]
Refcount: 2
Contexts:
    context:  dt 0xffffb6093c3896b0 Acx01000!AfxManager (size is 0x110 bytes)
    EvtCleanupCallback fffff8038a453070 Acx01000!Acx::WdfCpp::ObjectContext<ACXMANAGER__ *,Acx::AfxManager>::EvtObjectContextCleanupThunk
    EvtDestroyCallback fffff8038a453000 Acx01000!Acx::WdfCpp::ObjectContext<ACXMANAGER__ *,Acx::AfxManager>::EvtObjectContextDestroyThunk

    context:  dt 0xffffb609404c2280 Acx01000!WdfCustomType_ACXMANAGER (size is 0x10 bytes)
    <no associated attribute callbacks>

Parent: !wdfhandle 0x000049f6d4e2d5c8, type is WDFDEVICE
Owning device: !wdfdevice 0x000049f6d4e2d5c8

!wdfobject 0xffffb6093c389600

!acxkd.acxpin

!acxpinなど、他の ACX 情報を表示するコマンドには、オブジェクトへの WDF ハンドルが必要です。 ACX オブジェクトの WDF ハンドルの検索については、この記事の「 Example ACX ドライバーのチュートリアル を参照してください。

0: kd> !acxpin 0x000049f6befeee38
Dumping info for ACXPIN 0x000049f6befeee38

    ID: 0
    Type: AcxPinTypeSink
    Type: AcxPinCommunicationSink

    Category: KSCATEGORY_AUDIO
    Name: {00000000-0000-0000-0000-000000000000}

ACX オブジェクトの状態によっては、すべての情報を表示できるわけではありません。

!acxkd.acxdataformatlist

!acxpin と同様に、 !acxdataformatlist は ACX データフォーマット リストに関する情報を表示します。

0: kd> !acxdataformatlist 0x000049f6bf8be668
Dumping info for ACXDATAFORMATLIST 0x000049f6bf8be668

    # Scan count: 0
    # Data formats: 6
    Data formats:
        Sample Rate: 48000, #Channels: 2, #Bits: 16, ValidBits: 16, Mask: 0x3 (default)
        Sample Rate: 48000, #Channels: 2, #Bits: 32, ValidBits: 24, Mask: 0x3
        Sample Rate: 44100, #Channels: 2, #Bits: 16, ValidBits: 16, Mask: 0x3
        Sample Rate: 44100, #Channels: 2, #Bits: 32, ValidBits: 24, Mask: 0x3
        Sample Rate: 32000, #Channels: 2, #Bits: 16, ValidBits: 16, Mask: 0x3
        Sample Rate: 32000, #Channels: 2, #Bits: 32, ValidBits: 24, Mask: 0x3

    !wdfhandle 000049f6bf8be668
    dt Acx01000!Acx::AfxDataFormatList ffffb60940444530

ACX ドライバーのチュートリアルの例

このセクションでは、ACX ドライバーのデバッグのチュートリアルを提供します。

シンボル パス

シンボル パスを変更するには.symfix コマンドと .sympath (シンボル パスの設定) コマンドを使用します。 ドライバーでローカル コードを使用している場合は、そのコードへのパスも追加します。 .reload (モジュールの再読み込み) コマンドを使用して現在のパスからシンボルを再度読み込みます。

.symfix
.sympath+ C:\Windows-driver-samples-develop\audio\Acx\Samples\AudioCodec\Driver
.reload /f

ドライバーのデバッガー コンテキスト

アクティブな ACX ドライバーをデバッグする場合は、ブレークポイントを設定します。 これにより、情報を収集して表示できるように、デバッガーが ACX オブジェクトのコンテキストに配置されます。

これらのブレークポイントの例は、サンプルの AudioCodec ドライバーの起動時に起動するように設計されています。

bm AudioCodec!DriverEntry
bm AudioCodec!AcxDriverInitialize

これらのブレークポイントの例は、ピンや回線の作成など、特定のアクションが発生したときに発生するように設計されています。

bm AudioCodec!AcxPinCreate
bm AudioCodec!AcxCircuitCreate
bm AudioCodec!Codec_EvtBusDeviceAdd

ドライバーが読み込まれ、適切なブレークポイントが起動し、有効な実行コンテキストが使用可能になったら、!acxkd コマンドを使用して、ACX オブジェクトに関する情報を表示します。 一般的な情報には !acxobject コマンドを使用し、詳細な情報については !acxcircuit や !acxpin などの特定のコマンドを使用します。

acxkd dll を読み込む

acxkd.dll拡張機能を読み込むには、 .load (Load Extension DLL) コマンドを使用します。

.load acxkd.dll

ACX ドライバーに関する情報を表示する

ターゲット ドライバーに関する情報を収集するには、 lm (List Loaded Modules) コマンドを使用して、読み込まれたすべてのドライバーを表示します。 次に、Dvm オプションを使用して、次に示すように目的の ACX ドライバーに関する情報を表示します。

0: kd> lm Dvm AcxHdAudio
Browse full module list
start             end                 module name
fffff803`8a3c0000 fffff803`8a448000   AcxHdAudio   (private pdb symbols)  C:\ProgramData\Dbg\sym\AcxHdAudio.pdb\6AEA2622909B20C1AD149C57ACBB4A6F1\AcxHdAudio.pdb
    Loaded symbol image file: AcxHdAudio.sys
    Mapped memory image file: C:\ProgramData\Dbg\sym\AcxHdAudio.sys\0829423388000\AcxHdAudio.sys
    Image path: \SystemRoot\System32\drivers\AcxHdAudio.sys
    Image name: AcxHdAudio.sys
    Browse all global symbols  functions  data  Symbol Reload
    Image was built with /Brepro flag.
    Timestamp:        08294233 (This is a reproducible build file hash, not a timestamp)
    CheckSum:         00087DD6
    ImageSize:        00088000
    Translations:     0000.04b0 0000.04e4 0409.04b0 0409.04e4
    Information from resource tables:

x (シンボルの検査)コマンドとワイルドカード マスクを使用して、ACXPIN などの特定の ACX 構造体を表示します。

0: kd> x /D AcxHdAudio!acxpin*
 A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

fffff803`8a3e3216 AcxHdAudio!AcxPinGetRawDataFormatList =  (inline caller) AcxHdAudio!HDACodec_EvtFormatChange+66
fffff803`8a3e31e0 AcxHdAudio!AcxPinGetCircuit =  (inline caller) AcxHdAudio!HDACodec_EvtFormatChange+30
fffff803`8a3e361f AcxHdAudio!AcxPinNotifyDataFormatChange =  (inline caller) AcxHdAudio!HDACodec_EvtFormatChange+46f
fffff803`8a3e7396 AcxHdAudio!AcxPinCreate =  (inline caller) AcxHdAudio!HDACodecR_CreateRenderCircuit+962
fffff803`8a3e74a2 AcxHdAudio!AcxPinGetRawDataFormatList =  (inline caller) AcxHdAudio!HDACodecR_CreateRenderCircuit+a6e
fffff803`8a3e75f8 AcxHdAudio!AcxPinCreate =  (inline caller) AcxHdAudio!HDACodecR_CreateRenderCircuit+bc4
fffff803`8a3e789a AcxHdAudio!AcxPinAddJacks =  (inline caller) AcxHdAudio!HDACodecR_CreateRenderCircuit+e66
fffff803`8a3e5ae5 AcxHdAudio!AcxPinGetCircuit =  (inline caller) AcxHdAudio!HDACodecR_EvtAcxPinRetrieveJackSinkInfo+25
fffff803`8a3e5913 AcxHdAudio!AcxPinGetCircuit =  (inline caller) AcxHdAudio!HDACodecR_EvtAcxPinRetrieveName+73
fffff803`8a3ea277 AcxHdAudio!AcxPinCreate =  (inline caller) AcxHdAudio!HDACodecC_CreateCaptureCircuit+b27
fffff803`8a3ea39c AcxHdAudio!AcxPinGetRawDataFormatList =  (inline caller) AcxHdAudio!HDACodecC_CreateCaptureCircuit+c4c
fffff803`8a3ea4bc AcxHdAudio!AcxPinCreate =  (inline caller) AcxHdAudio!HDACodecC_CreateCaptureCircuit+d6c
fffff803`8a3ea7b2 AcxHdAudio!AcxPinAddJacks =  (inline caller) AcxHdAudio!HDACodecC_CreateCaptureCircuit+1062

デバッガーの現在の実行コンテキストによっては、 dx (Display Debugger Object Model Expression) を使用して特定の ACX 構造体にドリルダウンできる場合があります。

0: kd> dx -r2 AudioCodec!AcxDeviceAddCircuit
AudioCodec!AcxDeviceAddCircuit                 : AudioCodec!AcxDeviceAddCircuit+0x0 [Type: long __cdecl(WDFDEVICE__ *,ACXCIRCUIT__ *)]
0: kd> u fffff8007ead1120
AudioCodec!AcxDeviceAddCircuit [C:\Program Files (x86)\Windows Kits\10\Include\10.0.26016.0\km\acx\km\1.1\AcxDevice.h @ 206]:
fffff800`7ead1120 4889542410      mov     qword ptr [rsp+10h],rdx
fffff800`7ead1125 48894c2408      mov     qword ptr [rsp+8],rcx
fffff800`7ead112a 4883ec38        sub     rsp,38h
fffff800`7ead112e b808000000      mov     eax,8
fffff800`7ead1133 486bc046        imul    rax,rax,46h
fffff800`7ead1137 488d0dc2ab0000  lea     rcx,[AudioCodec!AcxFunctions (fffff800`7eadbd00)]
fffff800`7ead113e 488b0401        mov     rax,qword ptr [rcx+rax]
fffff800`7ead1142 4889442420      mov     qword ptr [rsp+20h],rax

!wdfkd.wdfdriverinfo

!wdfdriverinfo 関連付けられた ACX オブジェクトや ACXDEVICE wdfhandle などの WDF 情報を収集するには、ドライバーの名前を指定してコマンドを使用します。

0: kd> !wdfdriverinfo AcxHdAudio.sys 1 -v 
----------------------------------
Default driver image name: AcxHdAudio
WDF library image name: Wdf01000
 FxDriverGlobals  0xffffb609403e3de0
 WdfBindInfo      0xfffff8038a3dd1b0
   Version        v1.25
 Library module   0xffffb60929cc6050
   ServiceName    \Registry\Machine\System\CurrentControlSet\Services\Wdf01000
   ImageName      Wdf01000
----------------------------------
WDFDRIVER: 0x000049f6bfe9d5d8
    context:  dt 0xffffb60940162bc0 AcxHdAudio!CODEC_DRIVER_CONTEXT (size is 0x1 bytes)
    <no associated attribute callbacks>

    context:  dt 0xffffb6093ccead20 Acx01000!AfxDriver (size is 0x20 bytes)
    EvtCleanupCallback fffff8038a455780 Acx01000!Acx::WdfCpp::ObjectContext<WDFDRIVER__ *,Acx::AfxDriver>::EvtObjectContextCleanupThunk
    EvtDestroyCallback fffff8038a455740 Acx01000!Acx::WdfCpp::ObjectContext<WDFDRIVER__ *,Acx::AfxDriver>::EvtObjectContextDestroyThunk
Object Hierarchy: !wdfhandle 0x000049f6bfe9d5d8 0xff
Driver logs: !wdflogdump AcxHdAudio.sys -d
Framework logs: !wdflogdump AcxHdAudio.sys -f

    !wdfdevice 0x000049f6bffba488 ff (FDO)
        Pnp/Power State: WdfDevStatePnpStarted, WdfDevStatePowerD0, WdfDevStatePwrPolStartedWakeCapable
        context:  dt 0xffffb60940045e60 AcxHdAudio!CODEC_DEVICE_CONTEXT (size is 0x110 bytes)
        EvtCleanupCallback fffff8038a3e3c90 AcxHdAudio!HDACodec_EvtDeviceContextCleanup

        context:  dt 0xffffb60933f030f0 Acx01000!AfxDevice (size is 0x150 bytes)
        EvtCleanupCallback fffff8038a451910 Acx01000!Acx::WdfCpp::ObjectContext<WDFDEVICE__ *,Acx::AfxDevice>::EvtObjectContextCleanupThunk
        EvtDestroyCallback fffff8038a451740 Acx01000!Acx::WdfCpp::ObjectContext<WDFDEVICE__ *,Acx::AfxDevice>::EvtObjectContextDestroyThunk

        context:  dt 0xffffb60940a26b90 AcxHdAudio!CODEC_RENDER_DEVICE_CONTEXT (size is 0x38 bytes)
        <no associated attribute callbacks>

        context:  dt 0xffffb609409f2e00 AcxHdAudio!CODEC_CAPTURE_DEVICE_CONTEXT (size is 0x8 bytes)
        <no associated attribute callbacks>
        !wdfdevicequeues 0x000049f6bffba488

        !wdfdevice 0x000049f6bef1a848 ff (PDO)
            Pnp/Power State: WdfDevStatePnpStarted, WdfDevStatePowerD0BusWakeOwner, WdfDevStatePwrPolStartedWakeCapable
            context:  dt 0xffffb609410e5aa0 AcxHdAudio!CODEC_RENDER_DEVICE_CONTEXT (size is 0x38 bytes)
            EvtCleanupCallback fffff8038a3e6400 AcxHdAudio!HDACodecR_EvtDeviceContextCleanup

            context:  dt 0xffffb60933f090d0 Acx01000!AfxDevice (size is 0x150 bytes)
            EvtCleanupCallback fffff8038a451910 Acx01000!Acx::WdfCpp::ObjectContext<WDFDEVICE__ *,Acx::AfxDevice>::EvtObjectContextCleanupThunk
            EvtDestroyCallback fffff8038a451740 Acx01000!Acx::WdfCpp::ObjectContext<WDFDEVICE__ *,Acx::AfxDevice>::EvtObjectContextDestroyThunk
            !wdfdevicequeues 0x000049f6bef1a848

----------------------------------

WDF Verifier settings for AcxHdAudio.sys is OFF
----------------------------------

上記の出力では、関連付けられている wdfdevice へのリンクを使用できます。 そのリンクをクリックすると、関連付けられている WDF デバイス オブジェクトに関する情報が表示されます。

0: kd> !wdfdevice 0x000049f6bef1a848 ff
Treating handle as a KMDF handle!

Dumping WDFDEVICE 0x000049f6bef1a848
=================================

WDM PDEVICE_OBJECTs:  self ffffb60940ddbdd0

Pnp state:  119 ( WdfDevStatePnpStarted )
Power state:  309 ( WdfDevStatePowerD0BusWakeOwner )
Power Pol state:  531 ( WdfDevStatePwrPolStartedWakeCapable )

!acxkd.acxdevice

!acxdeviceで同じ wdfhandle を使用すると、ACX 中心の情報が提供されます。

3: kd> !acxdevice 0x00007dfadb0a5358
Dumping info for ACXDEVICE 0x00007dfadb0a5358

    In connected standby: FALSE

    State: AfxDeviceStateInitialized
    State history:
        0 : AfxDeviceStateInvalid
        1 : AfxDeviceStateInvalid
        2 : AfxDeviceStateInvalid
        3 : AfxDeviceStateInvalid
        4 : AfxDeviceStateInvalid
        5 : AfxDeviceStateCreated
        6 : AfxDeviceStateInitializing
        7 : AfxDeviceStateInitialized

    Create dispatch list:
        Create name: eHDMIOutTopo
        Dispatch routine: fffff80393179918
        Dispatch context: ffff82052513b960

    Circuits:
        ----------------------------------

        [Circuit 0]

        Name: eHDMIOutTopo
        Type: AcxCircuitTypeRender
        ComponentId: {BFCA9AD9-4EED-46C2-9323-B5D4400761A5}

        State: AfxCircuitStatePoweredUp

        Interface is enabled
        SymolicLinkName: \??\HDAUDIO#SUBFUNC_01&VEN_8086&DEV_281F&NID_0001&SUBSYS_00000000&REV_1000#6&4948348&0&0002&00000025#{2c6bb644-e1ae-47f8-9a2b-1d1fa750f2fa}\eHDMIOutTopo

        !acxproperties 00007dfad9ccccb8
        !acxmethods 00007dfad9ccccb8
        !acxevents 00007dfad9ccccb8

        # Pins: 2
            !acxpin 00007dfadf996dd8
            !acxpin 00007dfad4697238

        # Elements: 1
            !acxelement 00007dfadf997a18

        # Streams: 0

        !acxcircuit 00007dfad9ccccb8

    !wdfqueue 00007dfade9beaf8
    !wdfdevice 00007dfadb0a5358

    !wdfhandle 00007dfadb0a5358
    dt Acx01000!Acx::AfxDevice ffff8205256ab420

ACXCIRCUIT などの他の ACX オブジェクトに関する情報を表示するには、上記の出力のリンクを使用して、適切な wdfhandle で !acxcircuit を呼び出します。

3: kd> !acxcircuit 00007dfad9ccccb8
Dumping info for ACXCIRCUIT 0x00007dfad9ccccb8

    Name: eHDMIOutTopo
    Type: AcxCircuitTypeRender
    ComponentId: {BFCA9AD9-4EED-46C2-9323-B5D4400761A5}

    State: AfxCircuitStatePoweredUp
    State history:
        0 : AfxCircuitStateInvalid
        1 : AfxCircuitStateInvalid
        2 : AfxCircuitStateInvalid
        3 : AfxCircuitStateCreated
        4 : AfxCircuitStateInitializing
        5 : AfxCircuitStateInitialized
        6 : AfxCircuitStatePoweredDown
        7 : AfxCircuitStatePoweredUp

    Interface is enabled
    SymolicLinkName: \??\HDAUDIO#SUBFUNC_01&VEN_8086&DEV_281F&NID_0001&SUBSYS_00000000&REV_1000#6&4948348&0&0002&00000025#{2c6bb644-e1ae-47f8-9a2b-1d1fa750f2fa}\eHDMIOutTopo

    # Power references: 0
    # Open handles: 18

    !acxproperties 00007dfad9ccccb8
    !acxmethods 00007dfad9ccccb8
    !acxevents 00007dfad9ccccb8

    # Pins: 2
        !acxpin 00007dfadf996dd8
        !acxpin 00007dfad4697238

    # Elements: 1
        !acxelement 00007dfadf997a18

!acxkd.acxproperties

出力コマンドでは、表示可能な ACX プロパティなどの他のオブジェクトに対して wdfhandle とのリンクが提供されます。

0: kd> !acxproperties 000049f6bf436b88
Dumping properties info for ACXOBJECT 0x000049f6bf436b88

    # sets: 4

        Set: {8C134960-51AD-11CF-878A-94F801C10000}
            Id: 0, Flags: 0x1
            Id: 1, Flags: 0x1

        Set: {720D4AC0-7533-11D0-A5D6-28DB04C10000}
            Id: 0, Flags: 0x1
            Id: 1, Flags: 0x1
            Id: 2, Flags: 0x1
            Id: 3, Flags: 0x1

        Set: {C034FDB0-FF75-47C8-AA3C-EE46716B50C6}
            Id: 1, Flags: 0x1
            Id: 2, Flags: 0x1
            Id: 3, Flags: 0x1

        Set: {4D12807E-55DB-48B8-A466-F15A510F5817}
            Id: 1, Flags: 0x1

!wdfhandle

!wdfdriverinfo出力でも使用できます。これは、ACX に関連付けられている WDF オブジェクト階層の wdfhandle へのリンクです。

Object Hierarchy: !wdfhandle 0x000049f6bfe9d5d8 0xff

そのリンクをクリックすると、ACX ドライバーの WDF オブジェクト階層が表示されます。 この出力を使用して、他の ACX および WDF オブジェクトの WDF ハンドルを見つけることができます。

0: kd> !wdfhandle 0x000049f6bfe9d5d8 0xff
Treating handle as a KMDF handle!

Dumping WDFHANDLE 0x000049f6bfe9d5d8
=============================
Handle type is WDFDRIVER
Refcount: 1
Contexts:
    context:  dt 0xffffb60940162bc0 AcxHdAudio!CODEC_DRIVER_CONTEXT (size is 0x1 bytes)
    <no associated attribute callbacks>

    context:  dt 0xffffb6093ccead20 Acx01000!AfxDriver (size is 0x20 bytes)
    EvtCleanupCallback fffff8038a455780 Acx01000!Acx::WdfCpp::ObjectContext<WDFDRIVER__ *,Acx::AfxDriver>::EvtObjectContextCleanupThunk
    EvtDestroyCallback fffff8038a455740 Acx01000!Acx::WdfCpp::ObjectContext<WDFDRIVER__ *,Acx::AfxDriver>::EvtObjectContextDestroyThunk

Child WDFHANDLEs of 0x000049f6bfe9d5d8:
    !wdfhandle 0x000049f6bfe9d5d8  dt FxDriver 0xffffb60940162a20 Context ffffb60940162bc0, Context ffffb6093ccead20 Cleanup fffff8038a455780 Destroy fffff8038a455740
        !wdfdevice 0x000049f6bffba488  dt FxDevice 0xffffb60940045b70 Context ffffb60940045e60 Cleanup fffff8038a3e3c90, Context ffffb60933f030f0 Cleanup fffff8038a451910 Destroy fffff8038a451740, Context ffffb60940a26b90, Context ffffb609409f2e00
            WDF INTERNAL   dt FxDefaultIrpHandler 0xffffb6093fa54130
            WDF INTERNAL   dt FxPkgGeneral 0xffffb609401f5610
            WDF INTERNAL   dt FxWmiIrpHandler 0xffffb609401f6510
            WDF INTERNAL   dt FxPkgIo 0xffffb6093f6d2400
                !wdfqueue 0x000049f6c00114b8  dt FxIoQueue 0xffffb6093ffeeb40
            WDF INTERNAL   dt FxPkgFdo 0xffffb6093f2ae020
            !wdfhandle 0x000049f6bfe099f8  dt FxCmResList 0xffffb609401f6600
            !wdfhandle 0x000049f6bfe0a358  dt FxCmResList 0xffffb609401f5ca0
            !wdfchildlist 0x000049f6c09adb98  dt FxChildList 0xffffb6093f652460
            !wdfiotarget 0x000049f6c092d1d8  dt FxIoTarget 0xffffb6093f6d2e20
            !wdfqueue 0x000049f6c04904c8  dt FxIoQueue 0xffffb6093fb6fb30 Context ffffb6093fa8dcd0 Cleanup fffff8038a45a350 Destroy fffff8038a45a310
            !wdfhandle 0x000049f6c09e7ed8  dt FxWorkItem 0xffffb6093f618120 Context ffffb6093f618220
            WDF INTERNAL   dt FxWmiProvider 0xffffb609403d9b50
                WDF INTERNAL   dt FxWmiInstanceExternal 0xffffb60940a11320
            WDF INTERNAL   dt FxWmiProvider 0xffffb609403d9300
                WDF INTERNAL   dt FxWmiInstanceExternal 0xffffb60940a11720
        !wdfdevice 0x000049f6bef1a848  dt FxDevice 0xffffb609410e57b0 Context ffffb609410e5aa0 Cleanup fffff8038a3e6400, Context ffffb60933f090d0 Cleanup fffff8038a451910 Destroy fffff8038a451740
            WDF INTERNAL   dt FxDefaultIrpHandler 0xffffb60940c16450
            WDF INTERNAL   dt FxPkgGeneral 0xffffb60940bc9a10
            WDF INTERNAL   dt FxWmiIrpHandler 0xffffb60940bc9380
            WDF INTERNAL   dt FxPkgIo 0xffffb609400ab5c0
                !wdfqueue 0x000049f6beefd588  dt FxIoQueue 0xffffb60941102a70
            WDF INTERNAL   dt FxPkgPdo 0xffffb609410e6020
            !wdfhandle 0x000049f6bf436e58  dt FxCmResList 0xffffb60940bc91a0
            !wdfhandle 0x000049f6bf436d68  dt FxCmResList 0xffffb60940bc9290
            !wdfqueue 0x000049f6bef185c8  dt FxIoQueue 0xffffb609410e7a30 Context ffffb60940e72ed0 Cleanup fffff8038a45a350 Destroy fffff8038a45a310
            !wdfhandle 0x000049f6bf436b88 [ACXCIRCUIT]  dt FxUserObject 0xffffb60940bc9470 Context ffffb60940bc9520, Context 
...

WDF ログ コマンド

!wdflogdump は、WDF ログ情報を表示することで、ACX ドライバーのトラブルシューティングに役立ちます。

-d ドライバー オプションを使用して ACX のログを表示します。

0: kd> !wdflogdump acx01000 -d 
Log dump command                           Log ID                   Size
================                           ======                   ====
 !wdflogdump  Acx01000 -a 0xFFFF820527861000  AFX_Client1              4096
 !wdflogdump  Acx01000 -a 0xFFFF8205215C0000  AFX_Log                  4096
Trace searchpath is: 

Trace format prefix is: %7!u!: %!FUNC! - 
Trying to extract TMF information from - C:\ProgramData\Dbg\sym\Acx01000.pdb\B13D39B43205B60C07935803D7CB96981\Acx01000.pdb
--- start of log ---
AFX_Client1 1: Acx::AfxCircuit::Register - INFO:ACXCIRCUIT 00007DFAD9CCCCB8 Registered
AFX_Client1 2: Acx::AfxCircuit::PowerUpNotification - INFO:ACXCIRCUIT 00007DFAD9CCCCB8, EvtAcxCircuitPowerUp callback, STATUS_SUCCESS
AFX_Client1 5: Acx::AfxPin::GetModesCount - WARN:ACXPIN 00007DFAD4697238, failed to get default format for processing mode 9e90ea20-b493-4fd1-a1a8-7e1361a956cf, 0xc0000225(STATUS_NOT_FOUND)
AFX_Client1 7: Acx::AfxPin::GetModesCount - WARN:ACXPIN 00007DFAD4697238, failed to get default format for processing mode 9e90ea20-b493-4fd1-a1a8-7e1361a956cf, 0xc0000225(STATUS_NOT_FOUND)
AFX_Client1 8: Acx::AfxMute::EvtMuteEventEnableCallback - INFO:ACXMUTE 00007DFADF997A18, enabled ACXEVENT 00007DFADF996F98
AFX_Client1 10: Acx::AfxPin::GetModesCount - WARN:ACXPIN 00007DFAD4697238, failed to get default format for processing mode 9e90ea20-b493-4fd1-a1a8-7e1361a956cf, 0xc0000225(STATUS_NOT_FOUND)
AFX_Client1 12: Acx::AfxPin::GetModesCount - WARN:ACXPIN 00007DFAD4697238, failed to get default format for processing mode 9e90ea20-b493-4fd1-a1a8-7e1361a956cf, 0xc0000225(STATUS_NOT_FOUND)
AFX_Client1 13: Acx::AfxPin::EvtJackEventEnableCallback - INFO:ACXPIN 00007DFAD4697238, enabled ACXEVENT 00007DFADF9973F8
AFX_Client1 15: Acx::AfxPin::GetModesCount - WARN:ACXPIN 00007DFAD4697238, failed to get default format for processing mode 9e90ea20-b493-4fd1-a1a8-7e1361a956cf, 0xc0000225(STATUS_NOT_FOUND)
AFX_Client1 17: Acx::AfxPin::GetModesCount - WARN:ACXPIN 00007DFAD4697238, failed to get default format for processing mode 9e90ea20-b493-4fd1-a1a8-7e1361a956cf, 0xc0000225(STATUS_NOT_FOUND)

!wdflogdump を使用して、-f オプションを使用して特定の ACX ドライバーのフレームワーク ログを表示します。

0: kd> !wdflogdump AcxHdAudio -f
Trace searchpath is: 

Trace format prefix is: %7!u!: %4!s! %!FUNC! - 
Trying to extract TMF information from - C:\ProgramData\Dbg\sym\Wdf01000.pdb\CBDEA3A4F64C17C1752E652A91DD14761\Wdf01000.pdb
Gather log: Please wait, this may take a moment (reading 4024 bytes).
% read so far ... 10, 20, 30, 40, 50, 60, 70, 80, 90, 100
There are 65 log entries
--- start of log ---
16131: 09/03/2023-23:43:07.3233594 imp_WdfRegistryOpenKey - new WDFKEY object open failed, 0xc0000034(STATUS_OBJECT_NAME_NOT_FOUND)
16132: 09/03/2023-23:43:07.3233594 FxPowerIdleMachine::ProcessEventLocked - WDFDEVICE 0x00007DFADB0A5358 !devobj 0xFFFF820521608AF0 entering power idle state FxIdleDecrementIo from FxIdleBusy
16133: 09/03/2023-23:43:07.3233594 FxPowerIdleMachine::ProcessEventLocked - WDFDEVICE 0x00007DFADB0A5358 !devobj 0xFFFF820521608AF0 entering power idle state FxIdleStartTimer from FxIdleDecrementIo
16134: 09/03/2023-23:43:07.3233594 FxPowerIdleMachine::ProcessEventLocked - WDFDEVICE 0x00007DFADB0A5358 !devobj 0xFFFF820521608AF0 entering power idle state FxIdleTimerRunning from FxIdleStartTimer
16135: 09/03/2023-23:43:07.3233594 FxPowerIdleMachine::ProcessEventLocked - WDFDEVICE 0x00007DFADB0A5358 !devobj 0xFFFF820521608AF0 entering power idle state FxIdleCancelTimer from FxIdleTimerRunning
16136: 09/03/2023-23:43:07.3233594 FxPowerIdleMachine::ProcessEventLocked - WDFDEVICE 0x00007DFADB0A5358 !devobj 0xFFFF820521608AF0 entering power idle state FxIdleCheckIoCount from FxIdleCancelTimer
16137: 
...

関連項目

詳細については、 「カーネル ストリーミングのデバッグ」を参照してください。 WDM オーディオ ドライバーを使用したデバッグのチュートリアルについては、「 Debug ドライバー - ステップ バイ ステップ ラボ (Sysvad カーネル モード)」を参照してください。 ACX の詳細については、「 ACX オーディオ クラス拡張機能の概要を参照してください。