ХИДАПИ в два потока
Согласно https://github.com/signal11/hidapi/issues/72 HIDAPI должен быть поточно-ориентированным на машинах Linux. Однако я не могу заставить его работать вообще. Вот что я делаю:
#ifdef WIN32
#include <windows.h>
#endif
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <pthread.h>
#include <stdlib.h>
#include <assert.h>
#include "hidapi.h"
hid_device *handle;
static void *TaskCode(void *argument)
{
int res;
//hid_device *handle;
unsigned char buf[64];
// res = hid_init();
// if( res == -1 )
// {
// return (void*)1;
// }
//
// handle = hid_open(0x0911, 0x251c, NULL);
// if( handle == NULL )
// {
// return (void*)2;
// }
printf( "while 2\n");
while( 1 )
{
memset( buf, 64, 0 );
res = hid_read(handle, buf, 0);
if( res == -1 )
{
return (void*)3;
}
printf( "received %d bytes\n", res);
for (int i = 0; i < res; i++)
printf("Byte %d: %02x ", i+1, buf[i]);
//printf( "%02x ", buf[0]);
fflush(stdout);
}
return (void*)0;
}
int main(int argc, char* argv[])
{
int res;
//hid_device *handle;
unsigned char buf[65];
res = hid_init();
if( res == -1 )
{
return 1;
}
handle = hid_open(0x0911, 0x251c, NULL);
if( handle == NULL )
{
return 2;
}
hid_set_nonblocking( handle, 0 );
pthread_t thread;
int rc = pthread_create(&thread, NULL, TaskCode, NULL);
printf( "while 1\n");
while(1)
{
int a = getchar();
if( a == 'a')
{
// Get Device Type (cmd 0x82). The first byte is the report number (0x0).
buf[0] = 0x0;
buf[1] = 0x82;
res = hid_write(handle, buf, 65);
if( res != -1 )
printf( "write ok, transferred %d bytes\n", res );
else
{
printf( "write error\n" );
char* str = hid_error(handle);
printf( "error: %s\n", str );
return 1;
}
}
else if( a== 'b')
break;
}
void* trc;
rc = pthread_join(thread, &trc);
printf( "rc code: %d\n", (int)trc );
// Finalize the hidapi library
res = hid_exit();
return 0;
}
Если я не использую глобальный дескриптор, я каждый раз получаю сообщение об ошибке записи. Если я делаю, как в примере, формально все работает, но hid_read всегда возвращает 0 байт... Конечно, если я делаю простой hid_write(), за которым следует hid_read(), я получу правильный ответ на команду 0x82, как и предполагалось, Я действительно потерян здесь, я что-то упускаю?
РЕДАКТИРОВАТЬ: уточнить, нулевые байты возвращают также для всего, в том числе. кнопки на мышке и т. д. Так что, похоже, работает, но буфер данных всегда нулевые байты.
1 ответ
Позор мне, глупая ошибка. Код должен быть:
memset( buf, 0, 64 );
res = hid_read(handle, buf, 64);
и тогда это работает. Нужно больше спать и меньше писать!