1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
|
VUSB-based USB to I2C conversion board.
This setup assumes that you have a VUSB board with level conversion on D+ and D-
<http://vusb.wdfiles.com/local--files/hardware/level-conversion-with-zener.gif>,
use an ATTiny and have D+ is connected to INT0, D- to INT1,
SDA to PB6 and SCL to PB7. hardware pull-ups must be connected to SDA and SCL.
The commandline utilities are meant to be similar to the i2c-tools utilities.
vusb-i2cdetect can be used to scan a bus, while vusb-i2cget and vusb-i2cset
read/write data.
For instance, to set a MicroMoody's color to yellow:
> vusb-i2cset 17 0 0 255 255 0 0 1
Or, to read out the temperature from a TC74 thermal sensor:
> vusb-i2cget 77 0
The original VUSB readme follows:
-----
This is the README file for the PowerSwitch USB device.
PowerSwitch is an example application using Objective Development's
firmware-only USB driver for Atmel's AVR microcontrollers. It provides 8 bits
of parallel output intended to switch e.g. the power supply to electronic
devices. The PowerSwitch firmware is accompanied by a command line tool to
control the device.
Objective Development's USB driver is a firmware-only implementation of the
USB 1.1 standard (low speed device) on cheap single chip microcomputers of
Atmel's AVR series, such as the ATtiny2313 or even some of the small 8 pin
devices. It implements the standard to the point where useful applications
can be implemented. See the file "firmware/usbdrdv/usbdrv.h" for features
and limitations.
BUILDING AND INSTALLING
Both, the firmware and Unix command line tool are built with "make". You may
need to customize both makefiles.
Firmware:
The firmware for PowerSwitch requires avr-gcc and avr-libc (a C-library for
the AVR controller). Please read the instructions at
http://www.nongnu.org/avr-libc/user-manual/install_tools.html for how to
install the GNU toolchain (avr-gcc, assembler, linker etc.) and avr-libc.
If you are on Windows, download WinAVR (see http://winavr.sourceforge.net/).
For the Mac, we recommend AVR MacPack at http://www.obdev.at/avrmacpack/.
Once you have the GNU toolchain for AVR microcontrollers installed, you can
run "make" in the subdirectory "firmware". You may have to edit the Makefile
to use your preferred downloader with "make flash". Our current version is
built for avrdude with our AVR-Doper programmer.
Command Line Tool on Unix:
The command line tool requires libusb. Please download libusb from
http://libusb.sourceforge.net/ and install it before you compile. Change to
directory "commandline", check the settings in Makefile and edit them as
appropriate. Then type "make" to build the executable "powerSwitch" which can
be used to control the device.
Command Line Tool on Windows:
The command line tool uses libusb-win32. Please download libusb-win32 from
http://libusb-win32.sourceforge.net/. The small package
(libusb-win32-device-bin) should be sufficient. We need usb.h and libusb.a for
gcc (or your favorite compiler). Make sure that usb.h is in the include path
and libusb.a in the library search path (edit Makefile to achieve this).
Although it should be possible to compile the command line tool with any
compiler, we recommend that you use MSYS (to run make and other Unix tools)
and MinGW (for the gcc toolchain). Both can be downloaded for free from
http://www.mingw.org/.
If you want to develop Windows drivers without libusb-win32, see our
"Automator" project for an example.
WORKING WITH POWERSWITCH
Once you have compiled and flashed the firmware and compiled the command line
tool, you can move on to the fun part: Connect the device to a free USB port
of your computer or USB-hub. You should now be able to find the device in
any USB analyzer tool, e.g. SystemProfiler on Mac OS X. If you connect it
to a Windows PC, the "New Hardware" dialog will pop up and you can create
the appropriate info files with libusb-win32's inf-wizard.
The next step is to try the command line tool, e.g.:
./powerSwitch off 3
to turn off port 3 (all ports are on when the device has been cleared) or
for i in 0 1 2 3 4 5 6 7; do ./powerSwitch off $i; done
in an sh or bash (not csh or tcsh) type shell to turn off all ports.
You can also switch a port on or off temporarily. Try
./powerSwitch on 0 2.5
to activate port 0 for two and a half seconds.
FILES IN THE DISTRIBUTION
Readme.txt ........ The file you are currently reading.
firmware .......... Source code of the controller firmware.
firmware/usbdrv ... USB driver -- See Readme.txt in this directory for info
commandline ....... Source code of the host software (needs libusb).
circuit ........... Circuit diagrams in PDF and EAGLE 4 format. A free version
of EAGLE is available for Linux, Mac OS X and Windows from
http://www.cadsoft.de/.
License.txt ....... Public license (GNU GPL2) for all contents of this project.
Changelog.txt ..... Logfile documenting changes in soft-, firm- and hardware.
Pitfalls.txt ...... List of possible pitfalls and solutions.
USING THE USB DRIVER FOR YOUR OWN PROJECTS
PowerSwitch is mainly an example, although it may be very useful by itself.
If you want to implement your own application based on our USB driver, see
the file "firmware/main.c" for the application specific part of the firmware.
PowerSwitch uses only the most basic driver interface. More information and a
full technical description of the driver's interface can be found in
"firmware/usbdrv/usbdrv.h". Please review the configuration options in
"firmware/usbdrv/usbconfig-prototype.h". PowerSwitch uses Objective
Development's free shared USB IDs by default. You may set your own USB IDs
in usbconfig.h. For more information about USB descriptors and IDs see the
document "USB in a Nutshell" available at
http://www.beyondlogic.org/usbnutshell/usb1.htm or the USB 1.1 standard
available at http://www.usb.org/. Don't forget to check the license agreement
for Objective Development's firmware-only USB driver!
ABOUT THE LICENSE
It is our intention to make our USB driver and this demo application
available to everyone. Moreover, we want to make a broad range of USB
projects and ideas for USB devices available to the general public. We
therefore want that all projects built with our USB driver are published
under an Open Source license. Our license for the USB driver and demo code is
the GNU General Public License Version 2 (GPL2). See the file "License.txt"
for details.
If you don't want to publish your source code under the GPL2, you can simply
pay money for AVR-USB. As an additional benefit you get USB PIDs for free,
licensed exclusively to you. See the file "CommercialLicense.txt" for details.
MORE INFORMATION
For more information about Objective Development's firmware-only USB driver
for Atmel's AVR microcontrollers please visit the URL
http://www.obdev.at/products/avrusb/
A technical documentation of the driver's interface can be found in the file
"firmware/usbdrv/usbdrv.h".
(c) 2005, 2006, 2007 by OBJECTIVE DEVELOPMENT Software GmbH.
http://www.obdev.at/
|