autosave
This commit is contained in:
parent
5e222b5ad6
commit
b7776b7ec8
@ -4,7 +4,7 @@ AVRGCC=/home/jpt/arduino-1.8.8/hardware/tools/avr/bin/avr-gcc
|
||||
AVROBJCOPY=/home/jpt/arduino-1.8.8/hardware/tools/avr/bin/avr-objcopy
|
||||
|
||||
DEVICE=atmega328p
|
||||
F_CPU=16000000
|
||||
F_CPU=20000000
|
||||
CFLAGS="-Iusbdrv -I. -DDEBUG_LEVEL=0"
|
||||
COMPILE="$AVRGCC -Wall -Os -DF_CPU=$F_CPU $CFLAGS -mmcu=$DEVICE"
|
||||
|
||||
|
||||
@ -60,13 +60,13 @@ section at the end of this file).
|
||||
|
||||
/* ----------------------- Optional Hardware Config ------------------------ */
|
||||
|
||||
/* #define USB_CFG_PULLUP_IOPORTNAME D */
|
||||
#define USB_CFG_PULLUP_IOPORTNAME D
|
||||
/* If you connect the 1.5k pullup resistor from D- to a port pin instead of
|
||||
* V+, you can connect and disconnect the device from firmware by calling
|
||||
* the macros usbDeviceConnect() and usbDeviceDisconnect() (see usbdrv.h).
|
||||
* This constant defines the port on which the pullup resistor is connected.
|
||||
*/
|
||||
/* #define USB_CFG_PULLUP_BIT 4 */
|
||||
#define USB_CFG_PULLUP_BIT 4
|
||||
/* This constant defines the bit number in USB_CFG_PULLUP_IOPORT (defined
|
||||
* above) where the 1.5k pullup resistor is connected. See description
|
||||
* above for details.
|
||||
@ -109,7 +109,7 @@ section at the end of this file).
|
||||
* (e.g. HID), but never want to send any data. This option saves a couple
|
||||
* of bytes in flash memory and the transmit buffers in RAM.
|
||||
*/
|
||||
#define USB_CFG_INTR_POLL_INTERVAL 10
|
||||
#define USB_CFG_INTR_POLL_INTERVAL 40
|
||||
/* If you compile a version with endpoint 1 (interrupt-in), this is the poll
|
||||
* interval. The value is in milliseconds and must not be less than 10 ms for
|
||||
* low speed devices.
|
||||
@ -241,8 +241,8 @@ section at the end of this file).
|
||||
#define USB_CFG_DEVICE_VERSION 0x00, 0x01
|
||||
/* Version number of the device: Minor number first, then major number.
|
||||
*/
|
||||
#define USB_CFG_VENDOR_NAME 'o', 'b', 'd', 'e', 'v', '.', 'a', 't'
|
||||
#define USB_CFG_VENDOR_NAME_LEN 8
|
||||
#define USB_CFG_VENDOR_NAME 'b', 'e', 'n', 'i', 's'
|
||||
#define USB_CFG_VENDOR_NAME_LEN 5
|
||||
/* These two values define the vendor name returned by the USB device. The name
|
||||
* must be given as a list of characters under single quotes. The characters
|
||||
* are interpreted as Unicode (UTF-16) entities.
|
||||
@ -251,8 +251,8 @@ section at the end of this file).
|
||||
* obdev's free shared VID/PID pair. See the file USB-IDs-for-free.txt for
|
||||
* details.
|
||||
*/
|
||||
#define USB_CFG_DEVICE_NAME 'T', 'e', 'm', 'p', 'l', 'a', 't', 'e'
|
||||
#define USB_CFG_DEVICE_NAME_LEN 8
|
||||
#define USB_CFG_DEVICE_NAME 'r', 'o', 'f', 'l'
|
||||
#define USB_CFG_DEVICE_NAME_LEN 4
|
||||
/* Same as above for the device name. If you don't want a device name, undefine
|
||||
* the macros. See the file USB-IDs-for-free.txt before you assign a name if
|
||||
* you use a shared VID/PID.
|
||||
@ -271,7 +271,7 @@ section at the end of this file).
|
||||
/* See USB specification if you want to conform to an existing device class.
|
||||
* Class 0xff is "vendor specific".
|
||||
*/
|
||||
#define USB_CFG_INTERFACE_CLASS 0 /* define class here if not at device level */
|
||||
#define USB_CFG_INTERFACE_CLASS 3 /* define class here if not at device level */
|
||||
#define USB_CFG_INTERFACE_SUBCLASS 0
|
||||
#define USB_CFG_INTERFACE_PROTOCOL 0
|
||||
/* See USB specification if you want to conform to an existing device class or
|
||||
|
||||
107
usbtest.c
107
usbtest.c
@ -1,28 +1,121 @@
|
||||
#include <util/delay.h>
|
||||
#include <avr/io.h>
|
||||
#include <avr/interrupt.h>
|
||||
#include <avr/wdt.h>
|
||||
|
||||
#include <avr/eeprom.h>
|
||||
#include <avr/pgmspace.h> /* required by usbdrv.h */
|
||||
|
||||
#include "usbdrv/usbdrv.h"
|
||||
|
||||
#include <util/delay.h>
|
||||
|
||||
USB_PUBLIC uchar usbFunctionSetup(uchar data[8]) {
|
||||
return 0; // nothing for now
|
||||
/* ------------------------------------------------------------------------- */
|
||||
/* ----------------------------- USB interface ----------------------------- */
|
||||
/* ------------------------------------------------------------------------- */
|
||||
|
||||
PROGMEM const char usbHidReportDescriptor[22] = { /* USB report descriptor */
|
||||
0x06, 0x00, 0xff, // USAGE_PAGE (Generic Desktop)
|
||||
0x09, 0x01, // USAGE (Vendor Usage 1)
|
||||
0xa1, 0x01, // COLLECTION (Application)
|
||||
0x15, 0x00, // LOGICAL_MINIMUM (0)
|
||||
0x26, 0xff, 0x00, // LOGICAL_MAXIMUM (255)
|
||||
0x75, 0x08, // REPORT_SIZE (8)
|
||||
0x95, 0x80, // REPORT_COUNT (128)
|
||||
0x09, 0x00, // USAGE (Undefined)
|
||||
0xb2, 0x02, 0x01, // FEATURE (Data,Var,Abs,Buf)
|
||||
0xc0 // END_COLLECTION
|
||||
};
|
||||
/* Since we define only one feature report, we don't use report-IDs (which
|
||||
* would be the first byte of the report). The entire report consists of 128
|
||||
* opaque data bytes.
|
||||
*/
|
||||
|
||||
/* The following variables store the status of the current data transfer */
|
||||
static uchar currentAddress;
|
||||
static uchar bytesRemaining;
|
||||
|
||||
/* ------------------------------------------------------------------------- */
|
||||
|
||||
/* usbFunctionRead() is called when the host requests a chunk of data from
|
||||
* the device. For more information see the documentation in usbdrv/usbdrv.h.
|
||||
*/
|
||||
uchar usbFunctionRead(uchar *data, uchar len)
|
||||
{
|
||||
if(len > bytesRemaining)
|
||||
len = bytesRemaining;
|
||||
eeprom_read_block(data, (uchar *)0 + currentAddress, len);
|
||||
currentAddress += len;
|
||||
bytesRemaining -= len;
|
||||
return len;
|
||||
}
|
||||
|
||||
/* usbFunctionWrite() is called when the host sends a chunk of data to the
|
||||
* device. For more information see the documentation in usbdrv/usbdrv.h.
|
||||
*/
|
||||
uchar usbFunctionWrite(uchar *data, uchar len)
|
||||
{
|
||||
if(bytesRemaining == 0)
|
||||
return 1; /* end of transfer */
|
||||
if(len > bytesRemaining)
|
||||
len = bytesRemaining;
|
||||
eeprom_write_block(data, (uchar *)0 + currentAddress, len);
|
||||
currentAddress += len;
|
||||
bytesRemaining -= len;
|
||||
return bytesRemaining == 0; /* return 1 if this was the last chunk */
|
||||
}
|
||||
|
||||
/* ------------------------------------------------------------------------- */
|
||||
|
||||
usbMsgLen_t usbFunctionSetup(uchar data[8])
|
||||
{
|
||||
usbRequest_t *rq = (void *)data;
|
||||
|
||||
if((rq->bmRequestType & USBRQ_TYPE_MASK) == USBRQ_TYPE_CLASS){ /* HID class request */
|
||||
if(rq->bRequest == USBRQ_HID_GET_REPORT){ /* wValue: ReportType (highbyte), ReportID (lowbyte) */
|
||||
/* since we have only one report type, we can ignore the report-ID */
|
||||
bytesRemaining = 128;
|
||||
currentAddress = 0;
|
||||
return USB_NO_MSG; /* use usbFunctionRead() to obtain data */
|
||||
}else if(rq->bRequest == USBRQ_HID_SET_REPORT){
|
||||
/* since we have only one report type, we can ignore the report-ID */
|
||||
bytesRemaining = 128;
|
||||
currentAddress = 0;
|
||||
return USB_NO_MSG; /* use usbFunctionWrite() to receive data from host */
|
||||
}
|
||||
}else{
|
||||
/* ignore vendor type requests, we don't use any */
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* ------------------------------------------------------------------------- */
|
||||
|
||||
|
||||
void setupLed() {
|
||||
DDRB |= 1;
|
||||
PORTB &= ~1; // turn led off initially
|
||||
}
|
||||
|
||||
void toggleLed() {
|
||||
PORTB ^= 1;
|
||||
}
|
||||
|
||||
int main() {
|
||||
uchar i;
|
||||
|
||||
setupLed();
|
||||
wdt_enable(WDTO_1S); // enable 1s watchdog timer
|
||||
|
||||
usbInit();
|
||||
usbDeviceDisconnect(); // enforce re-enumeration
|
||||
toggleLed();
|
||||
for(i = 0; i<250; i++) {
|
||||
wdt_reset(); // keep watchdog happy
|
||||
_delay_ms(2);
|
||||
_delay_ms(1);
|
||||
}
|
||||
toggleLed();
|
||||
usbDeviceConnect();
|
||||
|
||||
sei(); // enable interrupts after re-enumeration
|
||||
|
||||
sei();
|
||||
while(1) {
|
||||
wdt_reset();
|
||||
usbPoll();
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user