3962|4

74

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

应用层发送数据到驱动程序的问题 [复制链接]

IIC驱动中的结构如下:
typedef struct _I2C_IO_DESC {
    DWORD   SlaveAddr;      // Target Slave Address
    UCHAR   WordAddr;       // Starting Slave Word Address
    PUCHAR  Data;           // pBuffer
    DWORD   Count;          // nBytes to read/write
} I2C_IO_DESC, *PI2C_IO_DESC;
---
这个是接口原型:
BOOL
I2C_IOControl(
    PI2C_CONTEXT pI2C,
    DWORD dwCode,  
    PBYTE pBufIn,
    DWORD dwLenIn,
    PBYTE pBufOut,
    DWORD dwLenOut,
    PDWORD pdwActualOut
   )
---
这是实际的写操作:(是在I2C_IOControl函数里面的)
dwErr = HW_Write(pI2C,
                 ((PI2C_IO_DESC)pBufIn)->SlaveAddr,
                 ((PI2C_IO_DESC)pBufIn)->WordAddr,
                   puc,
                 ((PI2C_IO_DESC)pBufIn)->Count);
---
(PI2C_IO_DESC)pBufIn) 转换后,调用数据包中的各种数据
--------

问题:
在应用层用怎么通过DeviceIoControl来传递数据
        DeviceIoControl(hFile,
                        IOCTL_I2C_WRITE,
                        xxx,
                        xxx,
                        0,
                        0,
                        0,
                        0);
我要将slaveraddr、WordAddr、写入数据的地址、写入数据的数量 通过结构体送入驱动

最新回复

个人觉得IIC驱动程序应该采用的是Windows CE流驱动的标准形式编写,在IIC_Init的函数中,通过函数VirtualAlloc()和VirtualCopy(),把芯片中针对IIC的物理地址和操作系统的虚存空间联系起来,对虚拟地址空间的操作就相当于对芯片的物理地址进行超作。 在CE中,设备被当做一种特殊的文件,应用程序对设备文件的操作都转换为对驱动程序的请求。我觉得主要是对比文件操作和设备错做函数参数间的对应关系: 与DeviceIoControl对应的文件操作函数原型为: BOOL XXX_IOControl( DWORD hOpenContext,                     DWORD dwCode,                     PBYTE pBufIn,                     DWORD dwLenIn,                     PBYTE pBufOut,                     DWORD dwLenOut,                     PDWORD pdwActualOut); 从上面函数得参数中可以看见,和DeviceIoControl函数的参数是一一对应的。应用程序通过调用IOControl函数来指定一个参数,接着操作系统对应地调用XXX_IOControl函数来完成这个任务。不过dwCode参数包含要执行的输入和输出操作,这些编码通常由每个设备驱动程序来指定,并且通过头文件提供给编程人员。  详情 回复 发表于 2009-9-25 14:45
点赞 关注

回复
举报

72

帖子

0

TA的资源

一粒金砂(初级)

沙发
 
定义个结构变量I2C_IO_DESC sendParam;
DeviceIoControl(hFile,
        IOCTL_I2C_WRITE,
        &sendParam,
        sizeof(I2C_Param),
        0,
        0,
        0,
        0);
你也看到了有类型转换的。
 
 

回复

64

帖子

0

TA的资源

一粒金砂(初级)

板凳
 
找找三星的BSP包看看.
 
 
 

回复

63

帖子

0

TA的资源

一粒金砂(初级)

4
 
帮顶一下.
 
 
 

回复

71

帖子

0

TA的资源

一粒金砂(初级)

5
 
个人觉得IIC驱动程序应该采用的是Windows CE流驱动的标准形式编写,在IIC_Init的函数中,通过函数VirtualAlloc()和VirtualCopy(),把芯片中针对IIC的物理地址和操作系统的虚存空间联系起来,对虚拟地址空间的操作就相当于对芯片的物理地址进行超作。
在CE中,设备被当做一种特殊的文件,应用程序对设备文件的操作都转换为对驱动程序的请求。我觉得主要是对比文件操作和设备错做函数参数间的对应关系:
与DeviceIoControl对应的文件操作函数原型为:
BOOL XXX_IOControl( DWORD hOpenContext,
                    DWORD dwCode,
                    PBYTE pBufIn,
                    DWORD dwLenIn,
                    PBYTE pBufOut,
                    DWORD dwLenOut,
                    PDWORD pdwActualOut);
从上面函数得参数中可以看见,和DeviceIoControl函数的参数是一一对应的。应用程序通过调用IOControl函数来指定一个参数,接着操作系统对应地调用XXX_IOControl函数来完成这个任务。不过dwCode参数包含要执行的输入和输出操作,这些编码通常由每个设备驱动程序来指定,并且通过头文件提供给编程人员。
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表