34d0d1db
pifou
seance 1
|
1
2
3
4
|
#include <libusb-1.0/libusb.h>
#include <stdio.h>
#include <stdlib.h>
|
9e490f23
pifou
recuperation des ...
|
5
6
7
|
#define ID_VENDOR 0x0951
#define ID_PRODUCT 0x01666
|
08e49fd9
pifou
Seance 2
|
8
9
|
// gcc file.c -l usb-1.0
|
34d0d1db
pifou
seance 1
|
10
11
12
13
14
15
16
17
18
19
20
21
22
|
int main(){
// init
libusb_context *context;
int status = libusb_init(&context);
if(status != 0){perror("libusb_init"); exit(-1);}
// devices list
libusb_device **devices;
ssize_t devices_count = libusb_get_device_list(context, &devices);
if(devices_count < 0){perror("libusb_get_device_list"); exit(-1);}
for(int i=0; i<devices_count; i++){
libusb_device *device = devices[i];
|
08e49fd9
pifou
Seance 2
|
23
24
25
26
27
28
29
30
31
32
|
// device description
struct libusb_device_descriptor desc;
int status = libusb_get_device_descriptor(device, &desc);
if(status != 0) continue;
// search for device
if(desc.idVendor != 0x0951
|| desc.idProduct != 0x01666)
continue;
|
34d0d1db
pifou
seance 1
|
33
34
|
// open connection
libusb_device_handle *handle;
|
08e49fd9
pifou
Seance 2
|
35
36
37
38
39
40
41
42
|
status = libusb_open(device, &handle);
if(status != 0){ perror("libusb_open"); exit(-1); }
// prepare config
struct libusb_config_descriptor *config_desc;
status = libusb_get_config_descriptor(device, 0, &config_desc);
if(status != 0){ perror("libusb_get_config_descriptor"); exit(-1); }
int configuration = config_desc->bConfigurationValue;
|
34d0d1db
pifou
seance 1
|
43
44
|
// detach kernel
|
08e49fd9
pifou
Seance 2
|
45
|
for(int j=0; j<config_desc->bNumInterfaces; j++){
|
9e490f23
pifou
recuperation des ...
|
46
47
48
49
|
int interface = config_desc->interface[j].altsetting[0].bInterfaceNumber;
if(libusb_kernel_driver_active(handle, interface)){
status = libusb_detach_kernel_driver(handle, interface);
if(status != 0){ perror("libusb_detach_kernel_driver"); exit(-1); }
|
08e49fd9
pifou
Seance 2
|
50
|
}
|
34d0d1db
pifou
seance 1
|
51
|
}
|
08e49fd9
pifou
Seance 2
|
52
|
|
34d0d1db
pifou
seance 1
|
53
|
// use config
|
34d0d1db
pifou
seance 1
|
54
|
status = libusb_set_configuration(handle, configuration);
|
08e49fd9
pifou
Seance 2
|
55
56
57
58
|
if(status != 0){ perror("libusb_set_configuration"); exit(-1); }
// claim interfaces
for(int j=0; j<config_desc->bNumInterfaces; j++){
|
9e490f23
pifou
recuperation des ...
|
59
60
61
62
63
64
65
66
|
libusb_interface_descriptor *interface_desc = config_desc->interface[j].altsetting[0];
int interface = interface_desc->bInterfaceNumber;
status = libusb_claim_interface(handle, interface);
if(status != 0){ perror("libusb_claim_interface"); exit(-1); }
// find endpoints
for(int k=0; k<interface_desc->bNumEndpoints; k++){
|
9d698fff
pifou
Listage des endpo...
|
67
|
libusb_endpoint_descriptor *endpoint_desc = interface_desc->endpoints[k];
|
9e490f23
pifou
recuperation des ...
|
68
|
|
9d698fff
pifou
Listage des endpo...
|
69
70
71
72
|
// list endpoints bEndpointAddress and bmAttributes
printf("Endpoint inter. %d, num. %d\n", j, k);
printf("bEndpointAddress = 0x%x\n", endpoint_desc->bEndpointAddress);
printf("bmAttributes = 0x%x\n", endpoint_desc->bmAttributes);
|
08e49fd9
pifou
Seance 2
|
73
|
}
|
9e490f23
pifou
recuperation des ...
|
74
75
76
77
|
// release interfaces
status = libusb_release_interface(handle, interface);
if(status != 0){ perror("libusb_release_interface"); exit(-1); }
|
08e49fd9
pifou
Seance 2
|
78
79
80
81
|
}
// free config
libusb_free_config_descriptor(config_desc);
|
34d0d1db
pifou
seance 1
|
82
83
84
85
86
87
88
89
|
// close connection
libusb_close(handle);
}
libusb_free_device_list(devices, 1);
libusb_exit(context);
}
|