]> git.zerfleddert.de Git - fnordlicht-mini/blame - firmware/fnordlicht-controller/usbdrv/Readme.txt
reference eeprom contents
[fnordlicht-mini] / firmware / fnordlicht-controller / usbdrv / Readme.txt
CommitLineData
ec1bef8e 1This is the Readme file to Objective Development's firmware-only USB driver
2for Atmel AVR microcontrollers. For more information please visit
3http://www.obdev.at/vusb/
4
5This directory contains the USB firmware only. Copy it as-is to your own
6project and add all .c and .S files to your project (these files are marked
7with an asterisk in the list below). Then copy usbconfig-prototype.h as
8usbconfig.h to your project and edit it according to your configuration.
9
10
11TECHNICAL DOCUMENTATION
12=======================
13The technical documentation (API) for the firmware driver is contained in the
14file "usbdrv.h". Please read all of it carefully! Configuration options are
15documented in "usbconfig-prototype.h".
16
17The driver consists of the following files:
18 Readme.txt ............. The file you are currently reading.
19 Changelog.txt .......... Release notes for all versions of the driver.
20 usbdrv.h ............... Driver interface definitions and technical docs.
21* usbdrv.c ............... High level language part of the driver. Link this
22 module to your code!
23* usbdrvasm.S ............ Assembler part of the driver. This module is mostly
24 a stub and includes one of the usbdrvasm*.S files
25 depending on processor clock. Link this module to
26 your code!
27 usbdrvasm*.inc ......... Assembler routines for particular clock frequencies.
28 Included by usbdrvasm.S, don't link it directly!
29 asmcommon.inc .......... Common assembler routines. Included by
30 usbdrvasm*.inc, don't link it directly!
31 usbconfig-prototype.h .. Prototype for your own usbdrv.h file.
32* oddebug.c .............. Debug functions. Only used when DEBUG_LEVEL is
33 defined to a value greater than 0. Link this module
34 to your code!
35 oddebug.h .............. Interface definitions of the debug module.
36 usbportability.h ....... Header with compiler-dependent stuff.
37 usbdrvasm.asm .......... Compatibility stub for IAR-C-compiler. Use this
38 module instead of usbdrvasm.S when you assembler
39 with IAR's tools.
40 License.txt ............ Open Source license for this driver.
41 CommercialLicense.txt .. Optional commercial license for this driver.
42 USB-ID-FAQ.txt ......... General infos about USB Product- and Vendor-IDs.
43 USB-IDs-for-free.txt ... List and terms of use for free shared PIDs.
44
45(*) ... These files should be linked to your project.
46
47
48CPU CORE CLOCK FREQUENCY
49========================
50We supply assembler modules for clock frequencies of 12 MHz, 12.8 MHz, 15 MHz,
5116 MHz, 16.5 MHz 18 MHz and 20 MHz. Other clock rates are not supported. The
52actual clock rate must be configured in usbdrv.h unless you use the default
5312 MHz.
54
5512 MHz Clock
56This is the traditional clock rate of V-USB because it's the lowest clock
57rate where the timing constraints of the USB spec can be met.
58
5915 MHz Clock
60Similar to 12 MHz, but some NOPs inserted. On the other hand, the higher clock
61rate allows for some loops which make the resulting code size somewhat smaller
62than the 12 MHz version.
63
6416 MHz Clock
65This clock rate has been added for users of the Arduino board and other
66ready-made boards which come with a fixed 16 MHz crystal. It's also an option
67if you need the slightly higher clock rate for performance reasons. Since
6816 MHz is not divisible by the USB low speed bit clock of 1.5 MHz, the code
69is somewhat tricky and has to insert a leap cycle every third byte.
70
7112.8 MHz and 16.5 MHz Clock
72The assembler modules for these clock rates differ from the other modules
73because they have been built for an RC oscillator with only 1% precision. The
74receiver code inserts leap cycles to compensate for clock deviations. 1% is
75also the precision which can be achieved by calibrating the internal RC
76oscillator of the AVR. Please note that only AVRs with internal 64 MHz PLL
77oscillator can reach 16.5 MHz with the RC oscillator. This includes the very
78popular ATTiny25, ATTiny45, ATTiny85 series as well as the ATTiny26. Almost
79all AVRs can reach 12.8 MHz, although this is outside the specified range.
80
81See the EasyLogger example at http://www.obdev.at/vusb/easylogger.html for
82code which calibrates the RC oscillator based on the USB frame clock.
83
8418 MHz Clock
85This module is closer to the USB specification because it performs an on the
86fly CRC check for incoming packets. Packets with invalid checksum are
87discarded as required by the spec. If you also implement checks for data
88PID toggling on application level (see option USB_CFG_CHECK_DATA_TOGGLING
89in usbconfig.h for more info), this ensures data integrity. Due to the CRC
90tables and alignment requirements, this code is bigger than modules for other
91clock rates. To activate this module, you must define USB_CFG_CHECK_CRC to 1
92and USB_CFG_CLOCK_KHZ to 18000 in usbconfig.h.
93
9420 MHz Clock
95This module is for people who won't do it with less than the maximum. Since
9620 MHz is not divisible by the USB low speed bit clock of 1.5 MHz, the code
97uses similar tricks as the 16 MHz module to insert leap cycles.
98
99
100USB IDENTIFIERS
101===============
102Every USB device needs a vendor- and a product-identifier (VID and PID). VIDs
103are obtained from usb.org for a price of 1,500 USD. Once you have a VID, you
104can assign PIDs at will.
105
106Since an entry level cost of 1,500 USD is too high for most small companies
107and hobbyists, we provide some VID/PID pairs for free. See the file
108USB-IDs-for-free.txt for details.
109
110Objective Development also has some license offerings which include product
111IDs. See http://www.obdev.at/vusb/ for details.
112
113
114DEVELOPMENT SYSTEM
115==================
116This driver has been developed and optimized for the GNU compiler version 3
117(gcc 3). It does work well with gcc 4, but with bigger code size. We recommend
118that you use the GNU compiler suite because it is freely available. V-USB
119has also been ported to the IAR compiler and assembler. It has been tested
120with IAR 4.10B/W32 and 4.12A/W32 on an ATmega8 with the "small" and "tiny"
121memory model. Not every release is tested with IAR CC and the driver may
122therefore fail to compile with IAR. Please note that gcc is more efficient for
123usbdrv.c because this module has been deliberately optimized for gcc.
124
125
126USING V-USB FOR FREE
127====================
128The AVR firmware driver is published under the GNU General Public License
129Version 2 (GPL2) and the GNU General Public License Version 3 (GPL3). It is
130your choice whether you apply the terms of version 2 or version 3.
131
132If you decide for the free GPL2 or GPL3, we STRONGLY ENCOURAGE you to do the
133following things IN ADDITION to the obligations from the GPL:
134
135(1) Publish your entire project on a web site and drop us a note with the URL.
136Use the form at http://www.obdev.at/vusb/feedback.html for your submission.
137If you don't have a web site, you can publish the project in obdev's
138documentation wiki at
139http://www.obdev.at/goto.php?t=vusb-wiki&p=hosted-projects.
140
141(2) Adhere to minimum publication standards. Please include AT LEAST:
142 - a circuit diagram in PDF, PNG or GIF format
143 - full source code for the host software
144 - a Readme.txt file in ASCII format which describes the purpose of the
145 project and what can be found in which directories and which files
146 - a reference to http://www.obdev.at/vusb/
147
148(3) If you improve the driver firmware itself, please give us a free license
149to your modifications for our commercial license offerings.
150
151
152COMMERCIAL LICENSES FOR V-USB
153=============================
154If you don't want to publish your source code under the terms of the GPL,
155you can simply pay money for V-USB. As an additional benefit you get
156USB PIDs for free, reserved exclusively to you. See the file
157"CommercialLicense.txt" for details.
158
Impressum, Datenschutz