CaptureEvent = CreateEvent(NULL, FALSE, FALSE, NULL); //正常
//CaptureEvent = CreateEvent(NULL, TRUE, FALSE, NULL); //驱动加载时出错
if (!CaptureEvent)
{
RETAILMSG(CAM_ERR,(TEXT("Fail to create camera interrupt event/r/n")));
return FALSE;
}
bSuccess = InterruptInitialize(g_CamSysIntr_C, CaptureEvent, NULL, 0);
if (!bSuccess)
{
RETAILMSG(CAM_ERR,(TEXT("Fail to initialize camera interrupt event [capture]/r/n")));
return FALSE;
}
项目中要用到两个CAMERA,所以做了两个驱动,其实内容都一样,写寄存器的地方有点区别而已。 两个驱动都加载后,最后写寄存器部分只有首先加载的那个驱动有效。
CreateEvent的用法
HANDLE CreateEvent(
LPSECURITY_ATTRIBUTES lpEventAttributes, // SD
BOOL bManualReset, // reset type
BOOL bInitialState, // initial state
LPCTSTR lpName // object name
);
该函数创建一个Event同步对象,并返回该对象的Handle
lpEventAttributes 一般为NULL
bManualReset 创建的Event是自动复位还是人工复位 ,如果true,人工复位,
一旦该Event被设置为有信号,则它一直会等到ResetEvent()API被调用时才会恢复
为无信号. 如果为false,Event被设置为有信号,则当有一个wait到它的Thread时,
该Event就会自动复位,变成无信号.
bInitialState 初始状态,true,有信号,false无信号
lpName Event对象名
一个Event被创建以后,可以用OpenEvent()API来获得它的Handle,用CloseHandle()
来关闭它,用SetEvent()或PulseEvent()来设置它使其有信号,用ResetEvent()
来使其无信号,用WaitForSingleObject()或WaitForMultipleObjects()来等待
其变为有信号.
PulseEvent()是一个比较有意思的使用方法,正如这个API的名字,它使一个Event
对象的状态发生一次脉冲变化,从无信号变成有信号再变成无信号,而整个操作是原子的.
对自动复位的Event对象,它仅释放第一个等到该事件的thread(如果有),而对于
人工复位的Event对象,它释放所有等待的thread.
后面这一句太重要了,我的两个CAMERA驱动正是这种效果,所以猜想是由于自动reset event带来的问题。改成手动方式老是出错,搞了半天没什么进展,偶然发现MS网站上有这么一条:http://support.microsoft.com/kb/248684
使用标志 bManualReset 创建的中断服务线程 (IST) 的事件时 = TRUE,并调用 InterruptInitialize 函数与此事件句柄,如然后会始终得到了"错误的参数"错误消息所示代码示例。
示例代码
HANDLE hMoses;
hMoses = CreateEvent(NULL,TRUE,FALSE,0);
if (hMoses == INVALID_HANDLE_VALUE)
AfxMessageBox(_T("Handle invalid"));
AfxBeginThread(IST_Moses,this,THREAD_PRIORITY_TIME_CRITICAL);
if(!InterruptInitialize(SYSINTR_MOSES,hMoses,NULL,NULL))
AfxMessageBox(_T("INT Init failed"));
因为 IST 只允许使用自动重置事件,您收到"错误的参数"错误信息。
晕~~~~ 原来调用InterruptInitialize时只允许自动event!