windows蓝牙驱动开发-查询蓝牙接口

蓝牙驱动程序堆栈会公开以下接口,配置文件驱动程序可使用这些接口与蓝牙设备交互。

GUID_BTHDDI_SDP_NODE_INTERFACE: 配置文件驱动程序会查询 GUID_BTHDDI_SDP_NODE_INTERFACE 以获取指向允许其创建服务发现协议 (SDP) 记录的函数的指针。此接口对应于 BTHDDI_SDP_NODE_INTERFACE 结构。

GUID_BTHDDI_SDP_PARSE_INTERFACE: 配置文件驱动程序会查询 GUID_BTHDDI_SDP_PARSE_INTERFACE 以获取指向允许其分析 SDP 记录的函数的指针。此接口对应于 BTHDDI_SDP_PARSE_INTERFACE 结构。

GUID_BTHDDI_PROFILE_DRIVER_INTERFACE : 配置文件驱动程序会查询 BTHDDI_PROFILE_DRIVER_INTERFACE 以获取指向允许其创建、分配、重用和释放 BRB 的函数的指针。此接口对应于 BTH_PROFILE_DRIVER_INTERFACE 结构。

若要获取这些接口中的任何一个,配置文件驱动程序必须首先生成IRP_MN_QUERY_INTERFACE IRP 并将其发送到蓝牙驱动程序堆栈。

以下过程是获取其中一个接口的常规过程。

查询接口
  • 分配和初始化 IRP。
  • 分配和初始化接口的实例。
  • 指定要查询接口的主要和次要函数代码。
  • 指定要查询的接口。
  • 沿着要处理的驱动程序堆栈向下方向传递 IRP。

以下伪代码示例演示了如何设置 IRP_MN_QUERY_INTERFACE IRP 来查询蓝牙驱动程序堆栈,以获取 GUID_BTHDDI_PROFILE_DRIVER_INTERFACE。 为了提高可读性,该示例不演示错误处理。

复制代码
#include <bthddi.h>

...

// Define a custom pool tag to identify your profile driver's dynamic memory allocations. You should change this tag to easily identify your driver's allocations from other drivers.
#define PROFILE_DRIVER_POOL_TAG '_htB'

PIRP Irp;
Irp = IoAllocateIrp( DeviceExtension->ParentDeviceObject->StackSize, FALSE );

PBTH_PROFILE_DRIVER_INTERFACE BthInterface; // Define storage for an instance of the BTH_PROFILE_DRIVER_INTERFACE structure
BthInterface = ExAllocatePoolWithTag( NonPagedPool, sizeof( BTH_PROFILE_DRIVER_INTERFACE ), PROFILE_DRIVER_POOL_TAG );

// Zero the memory associated with the structure
RtlZeroMemory( BthInterface, sizeof( BTH_PROFILE_DRIVER_INTERFACE ) );

// Set up the next IRP stack location
PIO_STACK_LOCATION NextIrpStack;
NextIrpStack = IoGetNextIrpStackLocation( Irp );
NextIrpStack->MajorFunction = IRP_MJ_PNP;
NextIrpStack->MinorFunction = IRP_MN_QUERY_INTERFACE;
NextIrpStack->Parameters.QueryInterface.InterfaceType = (LPGUID) &GUID_BTHDDI_PROFILE_DRIVER_INTERFACE;
NextIrpStack->Parameters.QueryInterface.Size = sizeof( BTH_PROFILE_DRIVER_INTERFACE );
NextIrpStack->Parameters.QueryInterface.Version = BTHDDI_PROFILE_DRIVER_INTERFACE_VERSION_FOR_QI;
NextIrpStack->Parameters.QueryInterface.Interface = (PINTERFACE) BthInterface;
NextIrpStack->Parameters.QueryInterface.InterfaceSpecificData = NULL;

// Pass the IRP down the driver stack
NTSTATUS Status;
Status = IoCallDriver( DeviceExtension->NextLowerDriver, Irp );

如果 IRP 成功返回,则配置文件驱动程序可以访问和使用该接口中包含的函数指针。

相关推荐
senijusene19 小时前
基于 MX6UL 的 DHT11 温湿度传感器 驱动开发
驱动开发
charlie11451419121 小时前
嵌入式Linux驱动开发(8)——内存映射 I/O - 别拿物理地址当指针用
linux·开发语言·驱动开发·c·imx6ull
Wallace Zhang21 小时前
SimpleFOC源码学习09(v2.3.2) - 磁编码器MagneticSensorSPI.cpp与MagneticSensorSPI.h
驱动开发·stm32·simplefoc·foc电机控制
Freak嵌入式21 小时前
亲测可用!可本地部署的 MicroPython 开源仿真器
ide·驱动开发·嵌入式·仿真·micropython·upypi
进击的小头2 天前
20_第20篇:嵌入式外设驱动开发基础:寄存器级开发与库函数开发对比实战
arm开发·驱动开发·单片机
低调小一2 天前
BDD(行为驱动开发)入门:把“测试”写成“行为”,把“需求”写成“场景”
驱动开发·tdd·bdd
charlie1145141912 天前
嵌入式Linux驱动开发(7) 从虚拟设备到真实硬件 —— LED驱动硬件基础
linux·开发语言·驱动开发·内核·c
莎士比亚的文学花园2 天前
Linux驱动开发(2)——驱动编程
linux·运维·驱动开发
2601_949695592 天前
开源AI智能体OpenClaw接入DeepSeek V4全流程:从配置到成本
人工智能·驱动开发·ai·电脑
枳实-叶2 天前
【Linux驱动开发】第二天:内核模块生命周期+内存分配全解
linux·驱动开发