2012-12-02 10:48:37 +00:00
|
|
|
/*
|
2013-01-14 00:30:11 +00:00
|
|
|
* Copyright 2012-2013 Andrew Smith
|
2013-05-30 12:53:07 +00:00
|
|
|
* Copyright 2013 Con Kolivas <kernel@kolivas.org>
|
2012-12-02 10:48:37 +00:00
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License as published by the Free
|
|
|
|
* Software Foundation; either version 3 of the License, or (at your option)
|
|
|
|
* any later version. See COPYING for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef USBUTILS_H
|
|
|
|
#define USBUTILS_H
|
|
|
|
|
|
|
|
#include <libusb.h>
|
|
|
|
|
2013-08-20 11:07:38 +00:00
|
|
|
#include "util.h"
|
|
|
|
|
2013-05-22 13:22:00 +00:00
|
|
|
#define EPI(x) (LIBUSB_ENDPOINT_IN | (unsigned char)(x))
|
|
|
|
#define EPO(x) (LIBUSB_ENDPOINT_OUT | (unsigned char)(x))
|
|
|
|
|
2013-05-19 14:48:15 +00:00
|
|
|
|
2013-05-20 11:58:04 +00:00
|
|
|
// For 0x0403:0x6014/0x6001 FT232H (and possibly others?) - BFL, BAS, BLT, LLT, AVA
|
2012-12-30 21:54:02 +00:00
|
|
|
#define FTDI_TYPE_OUT (LIBUSB_REQUEST_TYPE_VENDOR | LIBUSB_RECIPIENT_DEVICE | LIBUSB_ENDPOINT_OUT)
|
2013-05-27 05:43:22 +00:00
|
|
|
#define FTDI_TYPE_IN (LIBUSB_REQUEST_TYPE_VENDOR | LIBUSB_RECIPIENT_DEVICE | LIBUSB_ENDPOINT_IN)
|
2012-12-30 21:54:02 +00:00
|
|
|
|
|
|
|
#define FTDI_REQUEST_RESET ((uint8_t)0)
|
|
|
|
#define FTDI_REQUEST_MODEM ((uint8_t)1)
|
|
|
|
#define FTDI_REQUEST_FLOW ((uint8_t)2)
|
|
|
|
#define FTDI_REQUEST_BAUD ((uint8_t)3)
|
|
|
|
#define FTDI_REQUEST_DATA ((uint8_t)4)
|
2013-05-17 15:39:56 +00:00
|
|
|
#define FTDI_REQUEST_LATENCY ((uint8_t)9)
|
2012-12-30 21:54:02 +00:00
|
|
|
|
|
|
|
#define FTDI_VALUE_RESET 0
|
|
|
|
#define FTDI_VALUE_PURGE_RX 1
|
|
|
|
#define FTDI_VALUE_PURGE_TX 2
|
2013-05-17 15:39:56 +00:00
|
|
|
#define FTDI_VALUE_LATENCY 1
|
2012-12-30 21:54:02 +00:00
|
|
|
|
2013-05-17 15:39:56 +00:00
|
|
|
// Baud
|
|
|
|
#define FTDI_VALUE_BAUD_BFL 0xc068
|
|
|
|
#define FTDI_INDEX_BAUD_BFL 0x0200
|
|
|
|
#define FTDI_VALUE_BAUD_BAS FTDI_VALUE_BAUD_BFL
|
|
|
|
#define FTDI_INDEX_BAUD_BAS FTDI_INDEX_BAUD_BFL
|
|
|
|
// LLT = BLT (same code)
|
|
|
|
#define FTDI_VALUE_BAUD_BLT 0x001a
|
|
|
|
#define FTDI_INDEX_BAUD_BLT 0x0000
|
|
|
|
|
2013-05-28 14:01:54 +00:00
|
|
|
// Avalon
|
2013-05-27 05:43:22 +00:00
|
|
|
#define FTDI_VALUE_BAUD_AVA 0x001A
|
|
|
|
#define FTDI_INDEX_BAUD_AVA 0x0000
|
|
|
|
|
|
|
|
#define FTDI_VALUE_DATA_AVA 8
|
|
|
|
|
2013-07-29 11:39:29 +00:00
|
|
|
// BitBurner
|
|
|
|
#define BITBURNER_REQUEST ((uint8_t)0x42)
|
|
|
|
#define BITBURNER_VALUE 0x4242
|
|
|
|
#define BITBURNER_INDEX_SET_VOLTAGE 1
|
|
|
|
#define BITBURNER_INDEX_GET_VOLTAGE 2
|
2013-08-19 10:34:37 +00:00
|
|
|
#define BITBURNER_INDEX_GET_VERSION 4
|
2013-07-29 11:39:29 +00:00
|
|
|
|
2013-05-28 13:56:30 +00:00
|
|
|
// CMR = 115200 & 57600
|
|
|
|
#define FTDI_VALUE_BAUD_CMR_115 0xc068
|
|
|
|
#define FTDI_INDEX_BAUD_CMR_115 0x0200
|
|
|
|
|
|
|
|
#define FTDI_VALUE_BAUD_CMR_57 0x80d0
|
|
|
|
#define FTDI_INDEX_BAUD_CMR_57 0x0200
|
|
|
|
|
2013-05-17 15:39:56 +00:00
|
|
|
// Data control
|
|
|
|
#define FTDI_VALUE_DATA_BFL 0
|
|
|
|
#define FTDI_VALUE_DATA_BAS FTDI_VALUE_DATA_BFL
|
|
|
|
// LLT = BLT (same code)
|
|
|
|
#define FTDI_VALUE_DATA_BLT 8
|
2012-12-30 21:54:02 +00:00
|
|
|
|
|
|
|
#define FTDI_VALUE_FLOW 0
|
|
|
|
#define FTDI_VALUE_MODEM 0x0303
|
|
|
|
|
2013-05-19 14:48:15 +00:00
|
|
|
|
2013-05-20 11:58:04 +00:00
|
|
|
// For 0x10c4:0xea60 USB cp210x chip - AMU
|
2013-05-19 14:48:15 +00:00
|
|
|
#define CP210X_TYPE_OUT 0x41
|
|
|
|
|
2013-06-06 15:52:51 +00:00
|
|
|
#define CP210X_REQUEST_IFC_ENABLE 0x00
|
2013-05-19 14:48:15 +00:00
|
|
|
#define CP210X_REQUEST_DATA 0x07
|
|
|
|
#define CP210X_REQUEST_BAUD 0x1e
|
|
|
|
|
2013-06-06 15:52:51 +00:00
|
|
|
#define CP210X_VALUE_UART_ENABLE 0x0001
|
2013-05-19 14:48:15 +00:00
|
|
|
#define CP210X_VALUE_DATA 0x0303
|
|
|
|
#define CP210X_DATA_BAUD 0x0001c200
|
|
|
|
|
2013-05-20 11:58:04 +00:00
|
|
|
|
|
|
|
// For 0x067b:0x2303 Prolific PL2303 - ICA
|
|
|
|
#define PL2303_CTRL_DTR 0x01
|
|
|
|
#define PL2303_CTRL_RTS 0x02
|
|
|
|
|
|
|
|
#define PL2303_CTRL_OUT 0x21
|
|
|
|
#define PL2303_VENDOR_OUT 0x40
|
|
|
|
|
|
|
|
#define PL2303_REQUEST_CTRL 0x22
|
|
|
|
#define PL2303_REQUEST_LINE 0x20
|
|
|
|
#define PL2303_REQUEST_VENDOR 0x01
|
|
|
|
|
2013-05-22 13:22:00 +00:00
|
|
|
#define PL2303_REPLY_CTRL 0x21
|
|
|
|
|
2013-05-20 11:58:04 +00:00
|
|
|
#define PL2303_VALUE_CTRL (PL2303_CTRL_DTR | PL2303_CTRL_RTS)
|
|
|
|
#define PL2303_VALUE_LINE 0
|
|
|
|
#define PL2303_VALUE_LINE0 0x0001c200
|
2013-05-20 12:37:52 +00:00
|
|
|
#define PL2303_VALUE_LINE1 0x080000
|
2013-05-20 11:58:04 +00:00
|
|
|
#define PL2303_VALUE_LINE_SIZE 7
|
|
|
|
#define PL2303_VALUE_VENDOR 0
|
|
|
|
|
2012-12-02 10:48:37 +00:00
|
|
|
// Use the device defined timeout
|
|
|
|
#define DEVTIMEOUT 0
|
|
|
|
|
2013-09-26 10:58:29 +00:00
|
|
|
// The default intinfo structure used is the first one
|
|
|
|
#define DEFAULT_INTINFO 0
|
|
|
|
|
2013-09-13 15:18:14 +00:00
|
|
|
// For endpoints defined in usb_find_devices.intinfos.epinfos,
|
|
|
|
// the first two must be the default IN and OUT and both must always exist
|
2012-12-02 10:48:37 +00:00
|
|
|
#define DEFAULT_EP_IN 0
|
|
|
|
#define DEFAULT_EP_OUT 1
|
|
|
|
|
2013-09-13 15:18:14 +00:00
|
|
|
struct usb_epinfo {
|
2012-12-02 10:48:37 +00:00
|
|
|
uint8_t att;
|
|
|
|
uint16_t size;
|
|
|
|
unsigned char ep;
|
2013-09-27 03:07:04 +00:00
|
|
|
uint16_t wMaxPacketSize;
|
|
|
|
uint16_t PrefPacketSize;
|
2012-12-02 10:48:37 +00:00
|
|
|
bool found;
|
|
|
|
};
|
|
|
|
|
2013-09-13 15:18:14 +00:00
|
|
|
struct usb_intinfo {
|
|
|
|
int interface;
|
2013-09-26 10:58:29 +00:00
|
|
|
int ctrl_transfer;
|
2013-09-13 15:18:14 +00:00
|
|
|
int epinfo_count;
|
|
|
|
struct usb_epinfo *epinfos;
|
|
|
|
};
|
|
|
|
|
2013-05-16 12:16:15 +00:00
|
|
|
enum sub_ident {
|
2013-05-19 12:13:23 +00:00
|
|
|
IDENT_UNK = 0,
|
2013-05-16 12:16:15 +00:00
|
|
|
IDENT_BAJ,
|
|
|
|
IDENT_BAL,
|
|
|
|
IDENT_BAS,
|
|
|
|
IDENT_BAM,
|
|
|
|
IDENT_BFL,
|
2013-09-24 10:39:59 +00:00
|
|
|
IDENT_BFU,
|
2013-05-16 12:16:15 +00:00
|
|
|
IDENT_MMQ,
|
|
|
|
IDENT_AVA,
|
2013-07-29 11:39:29 +00:00
|
|
|
IDENT_BTB,
|
2013-10-03 10:11:37 +00:00
|
|
|
IDENT_BBF,
|
2013-10-03 13:19:18 +00:00
|
|
|
IDENT_KLN,
|
2013-05-16 12:16:15 +00:00
|
|
|
IDENT_ICA,
|
|
|
|
IDENT_AMU,
|
|
|
|
IDENT_BLT,
|
|
|
|
IDENT_LLT,
|
2013-05-28 12:44:03 +00:00
|
|
|
IDENT_CMR1,
|
|
|
|
IDENT_CMR2,
|
2013-05-16 12:16:15 +00:00
|
|
|
IDENT_ZTX
|
|
|
|
};
|
|
|
|
|
2012-12-02 10:48:37 +00:00
|
|
|
struct usb_find_devices {
|
|
|
|
int drv;
|
|
|
|
const char *name;
|
2013-05-16 12:16:15 +00:00
|
|
|
enum sub_ident ident;
|
2012-12-02 10:48:37 +00:00
|
|
|
uint16_t idVendor;
|
|
|
|
uint16_t idProduct;
|
2013-04-28 02:49:32 +00:00
|
|
|
char *iManufacturer;
|
|
|
|
char *iProduct;
|
2012-12-02 10:48:37 +00:00
|
|
|
int config;
|
|
|
|
unsigned int timeout;
|
2013-06-04 03:17:57 +00:00
|
|
|
uint16_t latency;
|
2013-09-13 15:18:14 +00:00
|
|
|
int intinfo_count;
|
|
|
|
struct usb_intinfo *intinfos;
|
2012-12-02 10:48:37 +00:00
|
|
|
};
|
|
|
|
|
2013-06-09 09:03:56 +00:00
|
|
|
/* Latency is set to 32ms to prevent a transfer ever being more than 512 bytes
|
|
|
|
* +2 bytes of status such as the ftdi chip, when the chips emulate a 115200
|
|
|
|
* baud rate, to avoid status bytes being interleaved in larger transfers. */
|
2013-06-04 03:17:57 +00:00
|
|
|
#define LATENCY_UNUSED 0
|
2013-06-09 09:03:56 +00:00
|
|
|
#define LATENCY_STD 32
|
2013-06-04 03:17:57 +00:00
|
|
|
|
2013-05-16 11:38:55 +00:00
|
|
|
enum usb_types {
|
|
|
|
USB_TYPE_STD = 0,
|
|
|
|
USB_TYPE_FTDI
|
|
|
|
};
|
|
|
|
|
2012-12-02 10:48:37 +00:00
|
|
|
struct cg_usb_device {
|
|
|
|
struct usb_find_devices *found;
|
|
|
|
libusb_device_handle *handle;
|
|
|
|
pthread_mutex_t *mutex;
|
|
|
|
struct libusb_device_descriptor *descriptor;
|
2013-05-16 11:38:55 +00:00
|
|
|
enum usb_types usb_type;
|
2013-05-16 12:16:15 +00:00
|
|
|
enum sub_ident ident;
|
|
|
|
uint16_t usbver;
|
2013-06-22 12:33:10 +00:00
|
|
|
int cps;
|
2013-06-25 11:35:21 +00:00
|
|
|
bool usecps;
|
2012-12-02 10:48:37 +00:00
|
|
|
char *prod_string;
|
|
|
|
char *manuf_string;
|
|
|
|
char *serial_string;
|
|
|
|
unsigned char fwVersion; // ??
|
|
|
|
unsigned char interfaceVersion; // ??
|
2013-06-04 15:07:16 +00:00
|
|
|
char *buffer;
|
|
|
|
uint32_t bufsiz;
|
|
|
|
uint32_t bufamt;
|
2013-08-20 11:07:38 +00:00
|
|
|
cgtimer_t cgt_last_write;
|
2013-06-25 11:35:21 +00:00
|
|
|
size_t last_write_siz;
|
2012-12-02 10:48:37 +00:00
|
|
|
};
|
|
|
|
|
2013-06-10 05:22:37 +00:00
|
|
|
#define USB_NOSTAT 0
|
|
|
|
|
2013-07-17 23:59:10 +00:00
|
|
|
#define USB_MAX_READ 8192
|
|
|
|
|
2013-07-20 02:56:57 +00:00
|
|
|
#define USB_TMO_0 50
|
|
|
|
#define USB_TMO_1 100
|
|
|
|
#define USB_TMO_2 500
|
|
|
|
#define USB_TMOS 3
|
|
|
|
|
|
|
|
struct cg_usb_tmo {
|
|
|
|
uint32_t count;
|
2013-07-20 03:20:24 +00:00
|
|
|
uint32_t min_tmo;
|
|
|
|
uint32_t max_tmo;
|
2013-07-20 02:56:57 +00:00
|
|
|
uint64_t total_over;
|
|
|
|
uint64_t total_tmo;
|
|
|
|
};
|
|
|
|
|
2013-01-22 10:46:21 +00:00
|
|
|
struct cg_usb_info {
|
|
|
|
uint8_t bus_number;
|
|
|
|
uint8_t device_address;
|
|
|
|
int usbstat;
|
|
|
|
bool nodev;
|
|
|
|
int nodev_count;
|
|
|
|
struct timeval last_nodev;
|
2013-05-30 06:00:41 +00:00
|
|
|
uint32_t ioerr_count;
|
|
|
|
uint32_t continuous_ioerr_count;
|
2013-06-10 08:52:18 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* for nodev and cgusb access (read and write)
|
|
|
|
* it's a pointer so MMQ can have it in multiple devices
|
|
|
|
*
|
|
|
|
* N.B. general mining code doesn't need to use the read
|
|
|
|
* lock for 'nodev' if it calls a usb_read/write/etc function
|
|
|
|
* that uses the lock - however, all usbutils code MUST use it
|
|
|
|
* to avoid devices disappearing while in use by multiple threads
|
|
|
|
*/
|
2013-10-07 12:34:01 +00:00
|
|
|
cglock_t devlock;
|
2013-06-16 11:58:01 +00:00
|
|
|
|
|
|
|
time_t last_pipe;
|
|
|
|
uint64_t pipe_count;
|
|
|
|
uint64_t clear_err_count;
|
|
|
|
uint64_t retry_err_count;
|
|
|
|
uint64_t clear_fail_count;
|
2013-06-25 12:23:06 +00:00
|
|
|
|
|
|
|
uint64_t read_delay_count;
|
|
|
|
double total_read_delay;
|
|
|
|
uint64_t write_delay_count;
|
|
|
|
double total_write_delay;
|
2013-07-17 23:59:10 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* We add 4: 1 for null, 2 for FTDI status and 1 to round to 4 bytes
|
|
|
|
* If a single device ever has multiple end points then it will need
|
|
|
|
* multiple of these
|
|
|
|
*/
|
|
|
|
unsigned char bulkbuf[USB_MAX_READ+4];
|
2013-07-20 02:56:57 +00:00
|
|
|
|
|
|
|
uint64_t tmo_count;
|
|
|
|
struct cg_usb_tmo usb_tmo[USB_TMOS];
|
2013-01-22 10:46:21 +00:00
|
|
|
};
|
|
|
|
|
2013-09-29 03:08:15 +00:00
|
|
|
#define ENUMERATION(a,b) a,
|
|
|
|
#define JUMPTABLE(a,b) b,
|
|
|
|
|
|
|
|
#define USB_PARSE_COMMANDS(USB_ADD_COMMAND) \
|
2013-09-22 12:38:45 +00:00
|
|
|
USB_ADD_COMMAND(C_REJECTED, "RejectedNoDevice") \
|
|
|
|
USB_ADD_COMMAND(C_PING, "Ping") \
|
|
|
|
USB_ADD_COMMAND(C_CLEAR, "Clear") \
|
|
|
|
USB_ADD_COMMAND(C_REQUESTVERSION, "RequestVersion") \
|
|
|
|
USB_ADD_COMMAND(C_GETVERSION, "GetVersion") \
|
|
|
|
USB_ADD_COMMAND(C_REQUESTFPGACOUNT, "RequestFPGACount") \
|
|
|
|
USB_ADD_COMMAND(C_GETFPGACOUNT, "GetFPGACount") \
|
|
|
|
USB_ADD_COMMAND(C_STARTPROGRAM, "StartProgram") \
|
|
|
|
USB_ADD_COMMAND(C_STARTPROGRAMSTATUS, "StartProgramStatus") \
|
|
|
|
USB_ADD_COMMAND(C_PROGRAM, "Program") \
|
|
|
|
USB_ADD_COMMAND(C_PROGRAMSTATUS, "ProgramStatus") \
|
|
|
|
USB_ADD_COMMAND(C_PROGRAMSTATUS2, "ProgramStatus2") \
|
|
|
|
USB_ADD_COMMAND(C_FINALPROGRAMSTATUS, "FinalProgramStatus") \
|
|
|
|
USB_ADD_COMMAND(C_SETCLOCK, "SetClock") \
|
|
|
|
USB_ADD_COMMAND(C_REPLYSETCLOCK, "ReplySetClock") \
|
|
|
|
USB_ADD_COMMAND(C_REQUESTUSERCODE, "RequestUserCode") \
|
|
|
|
USB_ADD_COMMAND(C_GETUSERCODE, "GetUserCode") \
|
|
|
|
USB_ADD_COMMAND(C_REQUESTTEMPERATURE, "RequestTemperature") \
|
|
|
|
USB_ADD_COMMAND(C_GETTEMPERATURE, "GetTemperature") \
|
|
|
|
USB_ADD_COMMAND(C_SENDWORK, "SendWork") \
|
|
|
|
USB_ADD_COMMAND(C_SENDWORKSTATUS, "SendWorkStatus") \
|
|
|
|
USB_ADD_COMMAND(C_REQUESTWORKSTATUS, "RequestWorkStatus") \
|
|
|
|
USB_ADD_COMMAND(C_GETWORKSTATUS, "GetWorkStatus") \
|
|
|
|
USB_ADD_COMMAND(C_REQUESTIDENTIFY, "RequestIdentify") \
|
|
|
|
USB_ADD_COMMAND(C_GETIDENTIFY, "GetIdentify") \
|
|
|
|
USB_ADD_COMMAND(C_REQUESTFLASH, "RequestFlash") \
|
|
|
|
USB_ADD_COMMAND(C_REQUESTSENDWORK, "RequestSendWork") \
|
|
|
|
USB_ADD_COMMAND(C_REQUESTSENDWORKSTATUS, "RequestSendWorkStatus") \
|
|
|
|
USB_ADD_COMMAND(C_RESET, "Reset") \
|
|
|
|
USB_ADD_COMMAND(C_SETBAUD, "SetBaud") \
|
|
|
|
USB_ADD_COMMAND(C_SETDATA, "SetDataCtrl") \
|
|
|
|
USB_ADD_COMMAND(C_SETFLOW, "SetFlowCtrl") \
|
|
|
|
USB_ADD_COMMAND(C_SETMODEM, "SetModemCtrl") \
|
|
|
|
USB_ADD_COMMAND(C_PURGERX, "PurgeRx") \
|
|
|
|
USB_ADD_COMMAND(C_PURGETX, "PurgeTx") \
|
|
|
|
USB_ADD_COMMAND(C_FLASHREPLY, "FlashReply") \
|
|
|
|
USB_ADD_COMMAND(C_REQUESTDETAILS, "RequestDetails") \
|
|
|
|
USB_ADD_COMMAND(C_GETDETAILS, "GetDetails") \
|
|
|
|
USB_ADD_COMMAND(C_REQUESTRESULTS, "RequestResults") \
|
|
|
|
USB_ADD_COMMAND(C_GETRESULTS, "GetResults") \
|
|
|
|
USB_ADD_COMMAND(C_REQUESTQUEJOB, "RequestQueJob") \
|
|
|
|
USB_ADD_COMMAND(C_REQUESTQUEJOBSTATUS, "RequestQueJobStatus") \
|
|
|
|
USB_ADD_COMMAND(C_QUEJOB, "QueJob") \
|
|
|
|
USB_ADD_COMMAND(C_QUEJOBSTATUS, "QueJobStatus") \
|
|
|
|
USB_ADD_COMMAND(C_QUEFLUSH, "QueFlush") \
|
|
|
|
USB_ADD_COMMAND(C_QUEFLUSHREPLY, "QueFlushReply") \
|
|
|
|
USB_ADD_COMMAND(C_REQUESTVOLTS, "RequestVolts") \
|
|
|
|
USB_ADD_COMMAND(C_GETVOLTS, "GetVolts") \
|
|
|
|
USB_ADD_COMMAND(C_SENDTESTWORK, "SendTestWork") \
|
|
|
|
USB_ADD_COMMAND(C_LATENCY, "SetLatency") \
|
|
|
|
USB_ADD_COMMAND(C_SETLINE, "SetLine") \
|
|
|
|
USB_ADD_COMMAND(C_VENDOR, "Vendor") \
|
|
|
|
USB_ADD_COMMAND(C_SETFAN, "SetFan") \
|
|
|
|
USB_ADD_COMMAND(C_FANREPLY, "GetFan") \
|
|
|
|
USB_ADD_COMMAND(C_AVALON_TASK, "AvalonTask") \
|
|
|
|
USB_ADD_COMMAND(C_AVALON_READ, "AvalonRead") \
|
|
|
|
USB_ADD_COMMAND(C_GET_AVALON_READY, "AvalonReady") \
|
|
|
|
USB_ADD_COMMAND(C_AVALON_RESET, "AvalonReset") \
|
|
|
|
USB_ADD_COMMAND(C_GET_AVALON_RESET, "GetAvalonReset") \
|
|
|
|
USB_ADD_COMMAND(C_FTDI_STATUS, "FTDIStatus") \
|
|
|
|
USB_ADD_COMMAND(C_ENABLE_UART, "EnableUART") \
|
|
|
|
USB_ADD_COMMAND(C_BB_SET_VOLTAGE, "SetCoreVoltage") \
|
2013-09-24 12:16:31 +00:00
|
|
|
USB_ADD_COMMAND(C_BB_GET_VOLTAGE, "GetCoreVoltage") \
|
2013-09-29 13:44:45 +00:00
|
|
|
USB_ADD_COMMAND(C_BF1_RESET, "BF1Reset") \
|
2013-09-25 21:24:09 +00:00
|
|
|
USB_ADD_COMMAND(C_BF1_OPEN, "BF1Open") \
|
2013-09-29 13:44:45 +00:00
|
|
|
USB_ADD_COMMAND(C_BF1_INIT, "BF1Init") \
|
2013-09-25 21:24:09 +00:00
|
|
|
USB_ADD_COMMAND(C_BF1_CLOSE, "BF1Close") \
|
|
|
|
USB_ADD_COMMAND(C_BF1_REQINFO, "BF1RequestInfo") \
|
|
|
|
USB_ADD_COMMAND(C_BF1_GETINFO, "BF1GetInfo") \
|
|
|
|
USB_ADD_COMMAND(C_BF1_REQRESET, "BF1RequestReset") \
|
|
|
|
USB_ADD_COMMAND(C_BF1_GETRESET, "BF1GetReset") \
|
|
|
|
USB_ADD_COMMAND(C_BF1_REQWORK, "BF1RequestWork") \
|
|
|
|
USB_ADD_COMMAND(C_BF1_GETWORK, "BF1GetWork") \
|
2013-09-26 23:39:26 +00:00
|
|
|
USB_ADD_COMMAND(C_BF1_GETRES, "BF1GetResults") \
|
|
|
|
USB_ADD_COMMAND(C_BF1_FLUSH, "BF1Flush") \
|
2013-09-27 00:50:33 +00:00
|
|
|
USB_ADD_COMMAND(C_BF1_IFLUSH, "BF1InterruptFlush") \
|
2013-09-26 23:39:26 +00:00
|
|
|
USB_ADD_COMMAND(C_BF1_IDENTIFY, "BF1Identify")
|
2013-09-22 12:38:45 +00:00
|
|
|
|
|
|
|
/* Create usb_cmds enum from USB_PARSE_COMMANDS macro */
|
2012-12-02 10:48:37 +00:00
|
|
|
enum usb_cmds {
|
2013-09-29 03:08:15 +00:00
|
|
|
USB_PARSE_COMMANDS(ENUMERATION)
|
2012-12-02 10:48:37 +00:00
|
|
|
C_MAX
|
|
|
|
};
|
|
|
|
|
2013-01-05 12:47:26 +00:00
|
|
|
struct device_drv;
|
2012-12-02 10:48:37 +00:00
|
|
|
struct cgpu_info;
|
|
|
|
|
2013-10-25 01:30:39 +00:00
|
|
|
bool async_usb_transfers(void);
|
2013-10-24 11:26:13 +00:00
|
|
|
void cancel_usb_transfers(void);
|
2013-03-13 00:04:05 +00:00
|
|
|
void usb_all(int level);
|
2013-03-29 14:21:02 +00:00
|
|
|
const char *usb_cmdname(enum usb_cmds cmd);
|
2013-10-27 20:41:15 +00:00
|
|
|
void usb_applog(struct cgpu_info *cgpu, enum usb_cmds cmd, char *msg, int amount, int err);
|
|
|
|
void usb_nodev(struct cgpu_info *cgpu);
|
2013-06-10 05:22:37 +00:00
|
|
|
struct cgpu_info *usb_copy_cgpu(struct cgpu_info *orig);
|
|
|
|
struct cgpu_info *usb_alloc_cgpu(struct device_drv *drv, int threads);
|
2013-10-07 12:34:01 +00:00
|
|
|
struct cgpu_info *usb_free_cgpu(struct cgpu_info *cgpu);
|
2012-12-02 10:48:37 +00:00
|
|
|
void usb_uninit(struct cgpu_info *cgpu);
|
|
|
|
bool usb_init(struct cgpu_info *cgpu, struct libusb_device *dev, struct usb_find_devices *found);
|
2013-01-05 12:47:26 +00:00
|
|
|
void usb_detect(struct device_drv *drv, bool (*device_detect)(struct libusb_device *, struct usb_find_devices *));
|
2012-12-02 10:48:37 +00:00
|
|
|
struct api_data *api_usb_stats(int *count);
|
|
|
|
void update_usb_stats(struct cgpu_info *cgpu);
|
2013-10-24 10:45:41 +00:00
|
|
|
int _usb_read(struct cgpu_info *cgpu, int intinfo, int epinfo, char *buf, size_t bufsiz, int *processed, unsigned int timeout, const char *end, enum usb_cmds cmd, bool readonce, bool cancellable);
|
2013-09-26 10:58:29 +00:00
|
|
|
int _usb_write(struct cgpu_info *cgpu, int intinfo, int epinfo, char *buf, size_t bufsiz, int *processed, unsigned int timeout, enum usb_cmds);
|
2013-05-19 14:48:15 +00:00
|
|
|
int _usb_transfer(struct cgpu_info *cgpu, uint8_t request_type, uint8_t bRequest, uint16_t wValue, uint16_t wIndex, uint32_t *data, int siz, unsigned int timeout, enum usb_cmds cmd);
|
2013-05-22 13:22:00 +00:00
|
|
|
int _usb_transfer_read(struct cgpu_info *cgpu, uint8_t request_type, uint8_t bRequest, uint16_t wValue, uint16_t wIndex, char *buf, int bufsiz, int *amount, unsigned int timeout, enum usb_cmds cmd);
|
2013-06-04 15:37:16 +00:00
|
|
|
int usb_ftdi_cts(struct cgpu_info *cgpu);
|
2013-09-26 10:58:29 +00:00
|
|
|
int _usb_ftdi_set_latency(struct cgpu_info *cgpu, int intinfo);
|
|
|
|
#define usb_ftdi_set_latency(_cgpu) _usb_ftdi_set_latency(_cgpu, DEFAULT_INTINFO)
|
2013-06-04 15:07:16 +00:00
|
|
|
void usb_buffer_enable(struct cgpu_info *cgpu);
|
|
|
|
void usb_buffer_disable(struct cgpu_info *cgpu);
|
|
|
|
void usb_buffer_clear(struct cgpu_info *cgpu);
|
|
|
|
uint32_t usb_buffer_size(struct cgpu_info *cgpu);
|
2013-06-25 11:35:21 +00:00
|
|
|
void usb_set_cps(struct cgpu_info *cgpu, int cps);
|
|
|
|
void usb_enable_cps(struct cgpu_info *cgpu);
|
|
|
|
void usb_disable_cps(struct cgpu_info *cgpu);
|
2013-09-26 10:58:29 +00:00
|
|
|
int _usb_interface(struct cgpu_info *cgpu, int intinfo);
|
|
|
|
#define usb_interface(_cgpu) _usb_interface(_cgpu, DEFAULT_INTINFO)
|
2013-06-26 02:53:05 +00:00
|
|
|
enum sub_ident usb_ident(struct cgpu_info *cgpu);
|
2013-09-27 03:07:04 +00:00
|
|
|
void _usb_set_pps(struct cgpu_info *cgpu, int intinfo, int epinfo, uint16_t PrefPacketSize);
|
|
|
|
#define usb_set_pps(_cgpu, _pps) _usb_set_pps(_cgpu, -1, -1, _pps)
|
2013-06-13 15:09:50 +00:00
|
|
|
void usb_set_dev_start(struct cgpu_info *cgpu);
|
2012-12-02 10:48:37 +00:00
|
|
|
void usb_cleanup();
|
2013-03-10 23:58:28 +00:00
|
|
|
void usb_initialise();
|
2013-05-27 13:30:18 +00:00
|
|
|
void *usb_resource_thread(void *userdata);
|
2012-12-02 10:48:37 +00:00
|
|
|
|
|
|
|
#define usb_read(cgpu, buf, bufsiz, read, cmd) \
|
2013-10-24 10:45:41 +00:00
|
|
|
_usb_read(cgpu, DEFAULT_INTINFO, DEFAULT_EP_IN, buf, bufsiz, read, DEVTIMEOUT, NULL, cmd, false, false)
|
2013-05-05 12:04:46 +00:00
|
|
|
|
2013-10-24 10:54:35 +00:00
|
|
|
#define usb_read_cancellable(cgpu, buf, bufsiz, read, cmd) \
|
|
|
|
_usb_read(cgpu, DEFAULT_INTINFO, DEFAULT_EP_IN, buf, bufsiz, read, DEVTIMEOUT, NULL, cmd, false, true)
|
|
|
|
|
2013-09-26 23:41:55 +00:00
|
|
|
#define usb_read_ii(cgpu, intinfo, buf, bufsiz, read, cmd) \
|
2013-10-24 10:45:41 +00:00
|
|
|
_usb_read(cgpu, intinfo, DEFAULT_EP_IN, buf, bufsiz, read, DEVTIMEOUT, NULL, cmd, false, false)
|
2013-09-26 23:41:55 +00:00
|
|
|
|
2013-05-05 12:04:46 +00:00
|
|
|
#define usb_read_once(cgpu, buf, bufsiz, read, cmd) \
|
2013-10-24 10:45:41 +00:00
|
|
|
_usb_read(cgpu, DEFAULT_INTINFO, DEFAULT_EP_IN, buf, bufsiz, read, DEVTIMEOUT, NULL, cmd, true, false)
|
2012-12-30 21:54:02 +00:00
|
|
|
|
2013-09-27 02:38:02 +00:00
|
|
|
#define usb_read_ii_once(cgpu, intinfo, buf, bufsiz, read, cmd) \
|
2013-10-24 10:45:41 +00:00
|
|
|
_usb_read(cgpu, intinfo, DEFAULT_EP_IN, buf, bufsiz, read, DEVTIMEOUT, NULL, cmd, true, false)
|
2013-09-27 02:38:02 +00:00
|
|
|
|
2013-05-27 05:43:22 +00:00
|
|
|
#define usb_read_once_timeout(cgpu, buf, bufsiz, read, timeout, cmd) \
|
2013-10-24 10:45:41 +00:00
|
|
|
_usb_read(cgpu, DEFAULT_INTINFO, DEFAULT_EP_IN, buf, bufsiz, read, timeout, NULL, cmd, true, false)
|
2013-05-27 05:43:22 +00:00
|
|
|
|
2013-10-24 11:26:13 +00:00
|
|
|
#define usb_read_once_timeout_cancellable(cgpu, buf, bufsiz, read, timeout, cmd) \
|
|
|
|
_usb_read(cgpu, DEFAULT_INTINFO, DEFAULT_EP_IN, buf, bufsiz, read, timeout, NULL, cmd, true, true)
|
|
|
|
|
2013-09-26 23:41:55 +00:00
|
|
|
#define usb_read_ii_once_timeout(cgpu, intinfo, buf, bufsiz, read, timeout, cmd) \
|
2013-10-24 10:45:41 +00:00
|
|
|
_usb_read(cgpu, intinfo, DEFAULT_EP_IN, buf, bufsiz, read, timeout, NULL, cmd, true, false)
|
2013-09-26 23:41:55 +00:00
|
|
|
|
2012-12-30 21:54:02 +00:00
|
|
|
#define usb_read_nl(cgpu, buf, bufsiz, read, cmd) \
|
2013-10-24 10:45:41 +00:00
|
|
|
_usb_read(cgpu, DEFAULT_INTINFO, DEFAULT_EP_IN, buf, bufsiz, read, DEVTIMEOUT, "\n", cmd, false, false)
|
2013-05-16 11:38:55 +00:00
|
|
|
|
2013-06-23 00:12:44 +00:00
|
|
|
#define usb_read_nl_timeout(cgpu, buf, bufsiz, read, timeout, cmd) \
|
2013-10-24 10:45:41 +00:00
|
|
|
_usb_read(cgpu, DEFAULT_INTINFO, DEFAULT_EP_IN, buf, bufsiz, read, timeout, "\n", cmd, false, false)
|
2013-06-23 00:11:22 +00:00
|
|
|
|
2013-05-16 11:38:55 +00:00
|
|
|
#define usb_read_ok(cgpu, buf, bufsiz, read, cmd) \
|
2013-10-24 10:45:41 +00:00
|
|
|
_usb_read(cgpu, DEFAULT_INTINFO, DEFAULT_EP_IN, buf, bufsiz, read, DEVTIMEOUT, "OK\n", cmd, false, false)
|
2012-12-02 10:48:37 +00:00
|
|
|
|
2013-06-09 07:15:48 +00:00
|
|
|
#define usb_read_ok_timeout(cgpu, buf, bufsiz, read, timeout, cmd) \
|
2013-10-24 10:45:41 +00:00
|
|
|
_usb_read(cgpu, DEFAULT_INTINFO, DEFAULT_EP_IN, buf, bufsiz, read, timeout, "OK\n", cmd, false, false)
|
2013-06-09 07:15:48 +00:00
|
|
|
|
2012-12-02 10:48:37 +00:00
|
|
|
#define usb_read_ep(cgpu, ep, buf, bufsiz, read, cmd) \
|
2013-10-24 10:45:41 +00:00
|
|
|
_usb_read(cgpu, DEFAULT_INTINFO, ep, buf, bufsiz, read, DEVTIMEOUT, NULL, cmd, false, false)
|
2012-12-02 10:48:37 +00:00
|
|
|
|
|
|
|
#define usb_read_timeout(cgpu, buf, bufsiz, read, timeout, cmd) \
|
2013-10-24 10:45:41 +00:00
|
|
|
_usb_read(cgpu, DEFAULT_INTINFO, DEFAULT_EP_IN, buf, bufsiz, read, timeout, NULL, cmd, false, false)
|
2013-09-26 10:58:29 +00:00
|
|
|
|
2013-10-24 10:54:35 +00:00
|
|
|
#define usb_read_timeout_cancellable(cgpu, buf, bufsiz, read, timeout, cmd) \
|
|
|
|
_usb_read(cgpu, DEFAULT_INTINFO, DEFAULT_EP_IN, buf, bufsiz, read, timeout, NULL, cmd, false, true)
|
|
|
|
|
2013-09-26 10:58:29 +00:00
|
|
|
#define usb_read_ii_timeout(cgpu, intinfo, buf, bufsiz, read, timeout, cmd) \
|
2013-10-24 10:45:41 +00:00
|
|
|
_usb_read(cgpu, intinfo, DEFAULT_EP_IN, buf, bufsiz, read, timeout, NULL, cmd, false, false)
|
2012-12-02 10:48:37 +00:00
|
|
|
|
2013-10-24 17:13:32 +00:00
|
|
|
#define usb_read_ii_timeout_cancellable(cgpu, intinfo, buf, bufsiz, read, timeout, cmd) \
|
|
|
|
_usb_read(cgpu, intinfo, DEFAULT_EP_IN, buf, bufsiz, read, timeout, NULL, cmd, false, true)
|
|
|
|
|
2012-12-02 10:48:37 +00:00
|
|
|
#define usb_read_ep_timeout(cgpu, ep, buf, bufsiz, read, timeout, cmd) \
|
2013-10-24 10:45:41 +00:00
|
|
|
_usb_read(cgpu, DEFAULT_INTINFO, ep, buf, bufsiz, read, timeout, NULL, cmd, false, false)
|
2012-12-02 10:48:37 +00:00
|
|
|
|
|
|
|
#define usb_write(cgpu, buf, bufsiz, wrote, cmd) \
|
2013-09-26 10:58:29 +00:00
|
|
|
_usb_write(cgpu, DEFAULT_INTINFO, DEFAULT_EP_OUT, buf, bufsiz, wrote, DEVTIMEOUT, cmd)
|
|
|
|
|
|
|
|
#define usb_write_ii(cgpu, intinfo, buf, bufsiz, wrote, cmd) \
|
|
|
|
_usb_write(cgpu, intinfo, DEFAULT_EP_OUT, buf, bufsiz, wrote, DEVTIMEOUT, cmd)
|
2012-12-02 10:48:37 +00:00
|
|
|
|
|
|
|
#define usb_write_ep(cgpu, ep, buf, bufsiz, wrote, cmd) \
|
2013-09-26 10:58:29 +00:00
|
|
|
_usb_write(cgpu, DEFAULT_INTINFO, ep, buf, bufsiz, wrote, DEVTIMEOUT, cmd)
|
2012-12-02 10:48:37 +00:00
|
|
|
|
|
|
|
#define usb_write_timeout(cgpu, buf, bufsiz, wrote, timeout, cmd) \
|
2013-09-26 10:58:29 +00:00
|
|
|
_usb_write(cgpu, DEFAULT_INTINFO, DEFAULT_EP_OUT, buf, bufsiz, wrote, timeout, cmd)
|
2012-12-02 10:48:37 +00:00
|
|
|
|
|
|
|
#define usb_write_ep_timeout(cgpu, ep, buf, bufsiz, wrote, timeout, cmd) \
|
2013-09-26 10:58:29 +00:00
|
|
|
_usb_write(cgpu, DEFAULT_INTINFO, ep, buf, bufsiz, wrote, timeout, cmd)
|
2012-12-02 10:48:37 +00:00
|
|
|
|
2012-12-30 21:54:02 +00:00
|
|
|
#define usb_transfer(cgpu, typ, req, val, idx, cmd) \
|
2013-05-19 14:48:15 +00:00
|
|
|
_usb_transfer(cgpu, typ, req, val, idx, NULL, 0, DEVTIMEOUT, cmd)
|
|
|
|
|
|
|
|
#define usb_transfer_data(cgpu, typ, req, val, idx, data, len, cmd) \
|
|
|
|
_usb_transfer(cgpu, typ, req, val, idx, data, len, DEVTIMEOUT, cmd)
|
2012-12-30 21:54:02 +00:00
|
|
|
|
2013-05-22 13:22:00 +00:00
|
|
|
#define usb_transfer_read(cgpu, typ, req, val, idx, buf, bufsiz, read, cmd) \
|
|
|
|
_usb_transfer_read(cgpu, typ, req, val, idx, buf, bufsiz, read, DEVTIMEOUT, cmd)
|
|
|
|
|
2012-12-02 10:48:37 +00:00
|
|
|
#endif
|