⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ser_avrdoper.c

📁 AVR Dopper Programmer
💻 C
📖 第 1 页 / 共 2 页
字号:
/* * avrdude - A Downloader/Uploader for AVR device programmers * Copyright (C) 2003-2004  Theodore A. Roth  <troth@openavr.org> * Copyright (C) 2006 Joerg Wunsch <j@uriah.heep.sax.de> * Copyright (C) 2006 Christian Starkjohann * * 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 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA *//* $Id: ser_avrdoper.c 251 2006-10-23 16:02:16Z cs $ *//* * Serial Interface emulation for USB programmer "AVR-Doper" in HID mode. */#include "ac_cfg.h"#if defined(HAVE_LIBUSB) || defined(WIN32NATIVE)/* ------------------------------------------------------------------------ */#define USB_HID_REPORT_TYPE_INPUT   1#define USB_HID_REPORT_TYPE_OUTPUT  2#define USB_HID_REPORT_TYPE_FEATURE 3/* Numeric constants for 'reportType' parameters */#define USB_ERROR_NONE      0#define USB_ERROR_ACCESS    1#define USB_ERROR_NOTFOUND  2#define USB_ERROR_BUSY      16#define USB_ERROR_IO        5/* These are the error codes which can be returned by functions of this * module. */typedef void    usbDevice_t;/* ------------------------------------------------------------------------ *//* ------------------------------------------------------------------------ *//* ------------------------------------------------------------------------ */#ifdef WIN32NATIVE#include <stdio.h>#include <windows.h>#include <setupapi.h>/*The following is a replacement for hidsdi.h from the Windows DDK. It defines someof the types and function prototypes of this header for our project. If youhave the Windows DDK version of this file or a version shipped with MinGW, usethat instead.*/#ifndef _HIDSDI_H#define _HIDSDI_H#include <pshpack4.h>#include <ddk/hidusage.h>#include <ddk/hidpi.h>typedef struct{    ULONG   Size;    USHORT  VendorID;    USHORT  ProductID;    USHORT  VersionNumber;}HIDD_ATTRIBUTES;void __stdcall      HidD_GetHidGuid(OUT LPGUID hidGuid);BOOLEAN __stdcall   HidD_GetAttributes(IN HANDLE device, OUT HIDD_ATTRIBUTES *attributes);BOOLEAN __stdcall   HidD_GetManufacturerString(IN HANDLE device, OUT void *buffer, IN ULONG bufferLen);BOOLEAN __stdcall   HidD_GetProductString(IN HANDLE device, OUT void *buffer, IN ULONG bufferLen);BOOLEAN __stdcall   HidD_GetSerialNumberString(IN HANDLE device, OUT void *buffer, IN ULONG bufferLen);BOOLEAN __stdcall   HidD_GetFeature(IN HANDLE device, OUT void *reportBuffer, IN ULONG bufferLen);BOOLEAN __stdcall   HidD_SetFeature(IN HANDLE device, IN void *reportBuffer, IN ULONG bufferLen);BOOLEAN __stdcall   HidD_GetNumInputBuffers(IN HANDLE device, OUT ULONG *numBuffers);BOOLEAN __stdcall   HidD_SetNumInputBuffers(IN HANDLE device, OUT ULONG numBuffers);#include <poppack.h>#endif#include <ddk/hidpi.h>#ifdef USB_DEBUG#define DEBUG_PRINT(arg)    printf arg#else#define DEBUG_PRINT(arg)#endif/* ------------------------------------------------------------------------ */static void convertUniToAscii(char *buffer){unsigned short  *uni = (void *)buffer;char            *ascii = buffer;    while(*uni != 0){        if(*uni >= 256){            *ascii++ = '?';        }else{            *ascii++ = *uni++;        }    }    *ascii++ = 0;}static int usbOpenDevice(usbDevice_t **device, int vendor, char *vendorName, int product, char *productName, int usesReportIDs){GUID                                hidGuid;        /* GUID for HID driver */HDEVINFO                            deviceInfoList;SP_DEVICE_INTERFACE_DATA            deviceInfo;SP_DEVICE_INTERFACE_DETAIL_DATA     *deviceDetails = NULL;DWORD                               size;int                                 i, openFlag = 0;  /* may be FILE_FLAG_OVERLAPPED */int                                 errorCode = USB_ERROR_NOTFOUND;HANDLE                              handle = INVALID_HANDLE_VALUE;HIDD_ATTRIBUTES                     deviceAttributes;				    HidD_GetHidGuid(&hidGuid);    deviceInfoList = SetupDiGetClassDevs(&hidGuid, NULL, NULL, DIGCF_PRESENT | DIGCF_INTERFACEDEVICE);    deviceInfo.cbSize = sizeof(deviceInfo);    for(i=0;;i++){        if(handle != INVALID_HANDLE_VALUE){            CloseHandle(handle);            handle = INVALID_HANDLE_VALUE;        }        if(!SetupDiEnumDeviceInterfaces(deviceInfoList, 0, &hidGuid, i, &deviceInfo))            break;  /* no more entries */        /* first do a dummy call just to determine the actual size required */        SetupDiGetDeviceInterfaceDetail(deviceInfoList, &deviceInfo, NULL, 0, &size, NULL);        if(deviceDetails != NULL)            free(deviceDetails);        deviceDetails = malloc(size);        deviceDetails->cbSize = sizeof(*deviceDetails);        /* this call is for real: */        SetupDiGetDeviceInterfaceDetail(deviceInfoList, &deviceInfo, deviceDetails, size, &size, NULL);        DEBUG_PRINT(("checking HID path \"%s\"\n", deviceDetails->DevicePath));        /* attempt opening for R/W -- we don't care about devices which can't be accessed */        handle = CreateFile(deviceDetails->DevicePath, GENERIC_READ|GENERIC_WRITE, FILE_SHARE_READ|FILE_SHARE_WRITE, NULL, OPEN_EXISTING, openFlag, NULL);        if(handle == INVALID_HANDLE_VALUE){            DEBUG_PRINT(("opening failed: %d\n", (int)GetLastError()));            /* errorCode = USB_ERROR_ACCESS; opening will always fail for mouse -- ignore */            continue;        }        deviceAttributes.Size = sizeof(deviceAttributes);        HidD_GetAttributes(handle, &deviceAttributes);        DEBUG_PRINT(("device attributes: vid=%d pid=%d\n", deviceAttributes.VendorID, deviceAttributes.ProductID));        if(deviceAttributes.VendorID != vendor || deviceAttributes.ProductID != product)            continue;   /* ignore this device */        errorCode = USB_ERROR_NOTFOUND;        if(vendorName != NULL && productName != NULL){            char    buffer[512];            if(!HidD_GetManufacturerString(handle, buffer, sizeof(buffer))){                DEBUG_PRINT(("error obtaining vendor name\n"));                errorCode = USB_ERROR_IO;                continue;            }            convertUniToAscii(buffer);            DEBUG_PRINT(("vendorName = \"%s\"\n", buffer));            if(strcmp(vendorName, buffer) != 0)                continue;            if(!HidD_GetProductString(handle, buffer, sizeof(buffer))){                DEBUG_PRINT(("error obtaining product name\n"));                errorCode = USB_ERROR_IO;                continue;            }            convertUniToAscii(buffer);            DEBUG_PRINT(("productName = \"%s\"\n", buffer));            if(strcmp(productName, buffer) != 0)                continue;        }        break;  /* we have found the device we are looking for! */    }    SetupDiDestroyDeviceInfoList(deviceInfoList);    if(deviceDetails != NULL)        free(deviceDetails);    if(handle != INVALID_HANDLE_VALUE){        *device = (usbDevice_t *)handle;        errorCode = 0;    }    return errorCode;}/* ------------------------------------------------------------------------ */static void    usbCloseDevice(usbDevice_t *device){    CloseHandle((HANDLE)device);}/* ------------------------------------------------------------------------ */static int usbSetReport(usbDevice_t *device, int reportType, char *buffer, int len){HANDLE  handle = (HANDLE)device;BOOLEAN rval = 0;DWORD   bytesWritten;    switch(reportType){    case USB_HID_REPORT_TYPE_INPUT:        break;    case USB_HID_REPORT_TYPE_OUTPUT:        rval = WriteFile(handle, buffer, len, &bytesWritten, NULL);        break;    case USB_HID_REPORT_TYPE_FEATURE:        rval = HidD_SetFeature(handle, buffer, len);        break;    }    return rval == 0 ? USB_ERROR_IO : 0;}/* ------------------------------------------------------------------------ */static int usbGetReport(usbDevice_t *device, int reportType, int reportNumber, char *buffer, int *len){HANDLE  handle = (HANDLE)device;BOOLEAN rval = 0;DWORD   bytesRead;    switch(reportType){    case USB_HID_REPORT_TYPE_INPUT:        buffer[0] = reportNumber;        rval = ReadFile(handle, buffer, *len, &bytesRead, NULL);        if(rval)            *len = bytesRead;        break;    case USB_HID_REPORT_TYPE_OUTPUT:        break;    case USB_HID_REPORT_TYPE_FEATURE:        buffer[0] = reportNumber;        rval = HidD_GetFeature(handle, buffer, *len);        break;    }    return rval == 0 ? USB_ERROR_IO : 0;}/* ------------------------------------------------------------------------ *//* ------------------------------------------------------------------------ *//* ------------------------------------------------------------------------ */#else /* WIN32NATIVE *//* ------------------------------------------------------------------------ *//* ------------------------------------------------------------------------ *//* ------------------------------------------------------------------------ */#include <stdio.h>#include <string.h>#include <usb.h>#define usbDevice   usb_dev_handle  /* use libusb's device structure *//* ------------------------------------------------------------------------- */#define USBRQ_HID_GET_REPORT    0x01#define USBRQ_HID_SET_REPORT    0x09static int  usesReportIDs;/* ------------------------------------------------------------------------- */static int  usbGetStringAscii(usb_dev_handle *dev, int index, int langid, char *buf, int buflen){char    buffer[256];int     rval, i;    if((rval = usb_control_msg(dev, USB_ENDPOINT_IN, USB_REQ_GET_DESCRIPTOR, (USB_DT_STRING << 8) + index, langid, buffer, sizeof(buffer), 1000)) < 0)        return rval;    if(buffer[1] != USB_DT_STRING)        return 0;    if((unsigned char)buffer[0] < rval)        rval = (unsigned char)buffer[0];    rval /= 2;    /* lossy conversion to ISO Latin1 */    for(i=1;i<rval;i++){        if(i > buflen)  /* destination buffer overflow */            break;        buf[i-1] = buffer[2 * i];        if(buffer[2 * i + 1] != 0)  /* outside of ISO Latin1 range */            buf[i-1] = '?';    }    buf[i-1] = 0;    return i-1;}static int usbOpenDevice(usbDevice_t **device, int vendor, char *vendorName, int product, char *productName, int _usesReportIDs){struct usb_bus      *bus;struct usb_device   *dev;usb_dev_handle      *handle = NULL;int                 errorCode = USB_ERROR_NOTFOUND;static int          didUsbInit = 0;    if(!didUsbInit){        usb_init();        didUsbInit = 1;    }    usb_find_busses();    usb_find_devices();    for(bus=usb_get_busses(); bus; bus=bus->next){        for(dev=bus->devices; dev; dev=dev->next){            if(dev->descriptor.idVendor == vendor && dev->descriptor.idProduct == product){                char    string[256];                int     len;                handle = usb_open(dev); /* we need to open the device in order to query strings */                if(!handle){                    errorCode = USB_ERROR_ACCESS;                    fprintf(stderr, "Warning: cannot open USB device: %s\n", usb_strerror());                    continue;                }                if(vendorName == NULL && productName == NULL){  /* name does not matter */                    break;                }                /* now check whether the names match: */                len = usbGetStringAscii(handle, dev->descriptor.iManufacturer, 0x0409, string, sizeof(string));                if(len < 0){                    errorCode = USB_ERROR_IO;                    fprintf(stderr, "Warning: cannot query manufacturer for device: %s\n", usb_strerror());                }else{                    errorCode = USB_ERROR_NOTFOUND;                    /* fprintf(stderr, "seen device from vendor ->%s<-\n", string); */                    if(strcmp(string, vendorName) == 0){                        len = usbGetStringAscii(handle, dev->descriptor.iProduct, 0x0409, string, sizeof(string));                        if(len < 0){                            errorCode = USB_ERROR_IO;                            fprintf(stderr, "Warning: cannot query product for device: %s\n", usb_strerror());                        }else{                            errorCode = USB_ERROR_NOTFOUND;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -