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);
}