windows驱动开发第13课(R3与R0通信之读取数据)

在上一节课(R3与R0通信之写入数据)里,我们知道和IRP有关的系统缓冲区(pirp->Associatedlrp.SystemBuffer)是一个读写共享的缓冲区。这节课我们通过这个缓冲区来从驱动层读取数据。

知识点:和IRP有关的系统缓冲区
pirp->AssociatedIrp.SystemBuffer; //和IRP有关的系统缓冲区

要点:这个缓冲区读和写是共享的。

具体实现步骤如下:

第一步:在用户层(MFC工程项目里)选“资源视图”,在对话框里双击“读数据”按钮,在里面添加如下代码:

	DWORD dwRetSize = 0;//返回字节数
	char ReData[512] = {0};//返回数据
	//数组示例
	DWORD WriteInBuffer;
	//DWORD OutBuf[512] = { 0 };//输出缓冲区
	DeviceIoControl(
		DeviceHandle,//CreateFile打开驱动设备 返回的句柄
		ReadTest,//控制码 CTL_CODE
		&WriteInBuffer,//输入缓冲区指针
		4,//输入缓冲区大小
		ReData,//返回缓冲区
		sizeof(ReData),//返回缓冲区大小
		&dwRetSize, //返回字节数
		NULL);
	OutputDebugStringA(ReData);

第二步:在驱动层写相应的操作代码,这里我们可以把读取数据的代码单独写到一个函数里,代码如下:

void IRP_IO_READ_TEST(PIRP pirp)
{
	//读数据
	KdPrint(("zdsoft:IRP_IO_READ_TEST Line=%d", __LINE__));
	char* IrpSysBuffer = (char*)pirp->AssociatedIrp.SystemBuffer; //和IRP有关的系统缓冲区
	PIO_STACK_LOCATION irpStack = IoGetCurrentIrpStackLocation(pirp);//获取应用层传来的参数
	//向缓冲区写入
	char DataFromR0[] = "zdsoft:sys来自驱动层R0的数据";
	memcpy_s(IrpSysBuffer, sizeof(DataFromR0), DataFromR0, sizeof(DataFromR0));

	pirp->IoStatus.Status = STATUS_SUCCESS;
	pirp->IoStatus.Information = sizeof(DataFromR0);//返回给DeviceIoControl中的倒数第二个参数

lpBytesReturned
	IoCompleteRequest(pirp, IO_NO_INCREMENT);//调用方已完成所有I/O请求处理操作,并且不增加优先

级
	KdPrint(("zdsoft:离开派遣函数"));
}

 然后在 IRP_CALL函数里直接调用,这里为了不影响上一节课的写入功能,使用了一个开关,可以根据控制码分别处理读数据和写数据功能。代码如下:

	switch (irpStackL->MajorFunction)
	{
	case IRP_MJ_DEVICE_CONTROL://DeviceIoControl
	{
		UINT32 CtlCode = irpStackL->Parameters.DeviceIoControl.IoControlCode;
		if (CtlCode==ReadTest)
		{
			IRP_IO_READ_TEST(pirp);
			return STATUS_SUCCESS;
		}
		else if (CtlCode==WriteTest)
		{
			char* IrpSysBuffer = (char*)pirp->AssociatedIrp.SystemBuffer; //和IRP有关的

系统缓冲区
			KdPrint(("zdsoft:用户层调用了DeviceIoControl R0控制码=%X", CtlCode));
			KdPrint(("zdsoft:和IRP有关的系统缓冲区=%s", IrpSysBuffer));
		}
		else if (CtlCode==ReadWriteTest)
		{
		
		
		}
		break;
	}

 重点:一定要注意 pirp->IoStatus.Information = sizeof(DataFromR0);这个是返回的长度,一定要大于等于IRP系统缓冲区数据的长度。

最后编译生成(驱动层生成Debug版,用户层生成Release版),再把生成后的文件复制到虚拟机里,打开相应的调试工具,测试效果如下图(图1):

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 这里有一个示例代码可以参考: import serial import MySQLdb # 打开串口 ser = serial.Serial("/dev/ttyUSB0", 9600) # 连接MySQL数据库 db = MySQLdb.connect("localhost", "username", "password", "database") cursor = db.cursor() while True: # 读取串口数据 data = ser.readline() # 将数据写入MySQL cursor.execute("INSERT INTO table_name (data) VALUES (%s)", (data)) # 提交数据 db.commit() ### 回答2: 要用Python代码连接Arduino UNO R3并将数据写入MySQL数据库,你需要进行以下步骤: 1. 首先,你需要确保已经连接好了Arduino UNO R3到计算机上,并且已安装好了Arduino IDE。 2. 在Arduino IDE中,编写一个简单的程序来读取传感器数据(假设我们使用的是温度传感器)。该程序将数据通过串口发送给计算机。 3. 在Python中,你需要安装pyserial库来与Arduino进行串口通信。你可以在终端中运行以下命令来安装pyserial: ```python pip install pyserial ``` 4. 在Python代码中,导入pyserial库并连接到Arduino的串口。你需要确定Arduino连接到计算机的串口号,并将其作为参数传递给Serial函数。例如,如果串口号为COM3,代码如下所示: ```python import serial arduino = serial.Serial('COM3', 9600) ``` 5. 接下来,你可以使用arduino.readline()函数来读取来自Arduino的数据,并将其存储在变量中。例如,将温度数据存储在变量temperature中: ```python temperature = arduino.readline().decode('utf-8').rstrip() ``` 6. 确保你已经安装了MySQL Connector库,你可以在终端中运行以下命令来安装MySQL Connector: ```python pip install mysql-connector-python ``` 7. 在Python代码中,导入MySQL Connector库并连接到你的MySQL数据库。你需要提供数据库的主机地址、用户名、密码和数据库名称。例如: ```python import mysql.connector mydb = mysql.connector.connect( host="localhost", user="yourusername", password="yourpassword", database="yourdatabase" ) ``` 8. 创建一个游标对象,并使用execute()方法执行插入语句,将读取到的温度数据写入数据库中。例如: ```python mycursor = mydb.cursor() sql = "INSERT INTO temperature (value) VALUES (%s)" val = (temperature,) mycursor.execute(sql, val) mydb.commit() ``` 9. 最后,关闭数据库连接和串口连接。代码如下所示: ```python mycursor.close() mydb.close() arduino.close() ``` 以上是一个简单的Python代码示例,连接到Arduino UNO R3并将数据写入MySQL数据库。当你运行该代码时,你将能够读取到Arduino传感器的数据并将其存储在数据库中。请确保在代码中使用正确的串口号、主机地址、用户名、密码和数据库名称。 ### 回答3: 要使用Python代码连接Arduino UNO R3读取数据并将其写入MySQL数据库,您可以遵循以下步骤: 1. 确保您的Arduino UNO R3正确连接到计算机上,并且您已经安装了Arduino IDE来编程控制它。 2. 在Arduino IDE中,编写一个简单的程序来读取传感器数据并将其发送给计算机。例如,您可以使用Serial.println()函数将数据发送到串行端口。确保程序正常运行,并记下Arduino连接的串行端口号。 3. 在计算机上,确保您已经安装了Python和适当的MySQL连接库,比如mysql-connector-python(使用pip install mysql-connector-python命令安装)。 4. 在Python代码中,导入所需的库和模块。例如:import serial(用于与Arduino通信)和import mysql.connector(用于与MySQL数据库通信)。 5. 建立与数据库的连接。使用mysql.connector.connect()函数,并提供数据库的用户名、密码、主机和数据库名称等详细信息。 6. 使用serial.Serial()函数在Python中创建一个串行对象,并传入串行端口号、波特率等参数来与Arduino通信。 7. 在一个无限循环中,使用serial.readline()函数从串行端口读取Arduino发送的数据。将数据转换为适当的格式(例如字符串或数字)。 8. 将读取的数据插入到MySQL数据库中。使用mysql.connector的insert语句,将数据插入到数据库中的适当表中。 9. 如果需要,确保及时地提交数据库更改。使用connection.commit()函数提交更改。 10. 关闭与串行端口和数据库的连接。使用serial.close()函数关闭与Arduino的连接,并使用connection.close()函数关闭与MySQL数据库的连接。 这些步骤是一个基本的指导,您可以根据您的需求进一步自定义和优化代码。也可以使用其他Python库和模块来实现此功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值