FreeCalypso > hg > fc-usbser-tools
view cp2102/read_partno.c @ 68:5cbde3c80c24
fteeprom-{erase,prog}: detach logic: change to detach by default
As it turns out, detaching all ttyUSB interfaces of a multichannel device
does not require outside knowledge of how many channels there are, as in
our previous -d option design that is being removed here - instead we can
read the bNumInterfaces constant from the USB device's config descriptor
and thus know how many interfaces there are in total. Based on this
discovery, change the design of fteeprom-{erase,prog} as follows:
* remove -d option;
* flip the default to where we detach all interfaces by default;
* add -n option to NOT detach any interfaces.
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Wed, 13 Sep 2023 06:37:03 +0000 |
parents | 9a15eb300ab0 |
children | 8d35346f1d46 |
line wrap: on
line source
/* * This program locates a presumed-CP2102 device via libusb and reads its * vendor-specific part number register, seeking to distinguish between * the original CP2102 and the later CP2102N. */ #include <sys/types.h> #include <string.h> #include <strings.h> #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <usb.h> #include "../libuwrap/find_dev.h" #include "cp210x_defs.h" main(argc, argv) char **argv; { struct usb_device *dev; usb_dev_handle *usbh; u_char partno; int rc; if (argc != 2) { fprintf(stderr, "usage: %s device-selector\n", argv[0]); exit(1); } dev = find_usbdev_by_desc_string(argv[1]); if (!dev) { fprintf(stderr, "error: specified USB device not found\n"); exit(1); } usbh = usb_open(dev); if (!usbh) { fprintf(stderr, "error: usb_open() failed\n"); exit(1); } rc = usb_control_msg(usbh, DEVICE_IN_REQTYPE, CP210x_CONFIG, REG_PART_NUMBER, 0, (char *) &partno, 1, USB_READ_TIMEOUT); if (rc != 1) { fprintf(stderr, "REG_PART_NUMBER read error: usb_control_msg() returned %d\n", rc); exit(1); } usb_close(usbh); printf("0x%02X\n", partno); exit(0); }