Blame view

test_list_endpoints.c 2.73 KB
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);
  }