ALL Power Labs
GCU Manual
Hardware version 2.01
Draft revision 0.5
G. Homsy
22 May, 2009
Table of Contents
1Introduction
1.1Features in brief
1.2Getting started
2Features in detail
2.1Power input
2.2CPU
2.3Thermocouple inputs
2.4Pressure inputs
2.5Auxiliary analog inputs
2.6FET outputs
2.7Display and keypad
2.8USB Host interface
2.9Frequency counter input
2.10PWM servo outputs
2.11CANbus
2.12Auxiliary RS-232 port
2.13SD-card slot
2.14Prototyping and modification area
3Operation in detail
4Firmware and support
4.1Getting started
4.2Modifying the firmware
5Internals
5.1ATmega1280 I/O pin assignments
5.2Firmware internals
6Appendices
6.1Warranty
6.2Resources on the web
6.3I/O connector pinouts
6.4Firmware repository
1Introduction
The Allpower Labs GCU is a standalone industrial process control kit, based on an Atmel ATmega 1280 microcontroller. To the core controller are attached numerous I/O peripherals, chosen specifically to be useful for Gasifier control and research.
The GCU is supplied with a basic standalone application preinstalled. This application, called the “Basic App” in this document, supports basic measurement and manual control, using the built-in keypad buttons and the built-in display. The Basic App, and all its supporting libraries, are Open-Source, and are distributed under the GPL (GNU General Public License). The source code is available from Allpower’s “gekgasifier” web site, and on SourceForge.net.
The microcontroller is also preprogrammed with the Arduino boot loader. This allows any user with basic microcontroller skills to write and modify their own gasifier control programs, using the Open-Source Arduino development kit, available for free download from the Arduino site.
The GCU is available as a board-level product only, with two different feature sets: The “basic” and the “full”. The “basic” may be upgraded to the “full” by a user experienced in surface mount soldering and electronics debugging techniques.
1.1Features in brief
- ATmega 1280 processor core
- Sixteen K-type thermocouple inputs
- Four differential or gauge pressure/vacuum inputs
- Eight PWM FET outputs
- Four auxiliary analog inputs
- Frequency counter input
- Three R/C hobby servo outputs
- Display and four button keypad
- USB serial host interface
- SD-card slot
- CANbus interface
- Auxiliary RS-232 interface
- User prototyping / expansion area
1.2Getting started
- Plug the power supply in
- (optional) Plug a K-type thermocouple into the connector labeled “T0”
- (optional) Attach a piece of tubing to one of the pressure ports on the pressure sensor labeled “PS0”
- (optional) Attach a hobby servo to the connector labeled “SRV0”. The black wire from the servo should be connected to PIN 1 on the connector (labeled with a dot)
- (optional) Attach a small (less than 2 amp) twelve-volt DC motor to pins 2 and 6 of the connector labeled “FET0 – FET3”
- Now, plug the GCU into the power supply
- The power LED should light, and the heartbeat LED should start flickering
- The menu of the “Basic App” should immediately appear on the display screen
- Practice navigating through the various display and control screens. You should be able to measure temperature and pressure, and control your hobby servo and your DC motor
- If it works, congratulations! If it doesn’t, refer to the “troubleshooting” section
2Features in detail
2.1Power input
The power input jack accepts 7 to 30 volts DC, center positive, on a 5 x 2.5 mm barrel connector. The input has a reverse blocking diode to prevent damage in case of reverse polarity connections.
Input power is applied directly to the FET output circuitry if jumpers JP1 and/or JP2 are installed. The reverse blocking diode will not protect the FET circuitry!
In parallel, the input power is fused by a resettable PTC fuse, F8, and then fed to a buck-mode switching regulator, to efficiently derive a 5 volt supply for the R/C hobby servos, and for the rest of the onboard circuitry.
2.2CPU
The MCU used is the Atmel ATmega1280, in the LQFP100 package.
2.2.1Feature set
The ATmega1280 features 128kB of in-circuit programmable flash memory, 4kB of EEPROM, and 8kB of on-chip SRAM.
The clock speed used in the GCU is 16MHz.
The MCU features four 8-bit PWM channels, and twelve programmable resolution PWM channels. Of these, only the programmable resolution PWM channels are used in the GCU. They are in groups of three, on four separate hardware timer/counters. Three groups are used for the FET PWM outputs, and one group is used for the R/C hobby servo outputs.
There are sixteen 10-bit analog inputs. Sadly, four are consumed by the JTAG interface. Five are used for the pressure and temperature sensors, four are auxiliary inputs, and three more are available for user expansion.
2.2.2Arduino environment
The GCU is supplied pre-flashed with the Arduino Mega bootloader. If you install the Arduino development environment on your PC and attach a USB cable to the GCU, then you will be able to upload Arduino sketches to the GCU.
2.2.3AVR-ISP
We encourage you to use the Arduino environment to develop enhancements to the GCU firmware. If you do not wish to use the Arduino environment, the MCU is programmable directly in-circuit using one of Atmel’s AVR ISP dongles, of either the six pin or the ten pin flavor. Consult Atmel’s web site for AVR development kits if you wish to develop your own firmware directly in C.
2.2.4JTAG
The GCU features a ten pin JTAG interface for in-circuit debugging. To use this feature, you must have a compatible JTAG dongle. Consult Atmel’s web site for compatible JTAG dongles.
2.2.5Compilers
The GCU firmwarelibraries are developed in C, and typically compiled in the Arduino environment, which uses the GCC / GNU Make toolchain. The hardware interfacing specification is open, therefore users may develop their own firmware if they wish. Other C compilers for the AVR series include:
- Xxx
- Xxx
- Xxx
The “Basic App” is also compiled and built in the Arduino environment.
2.3Thermocouple inputs
There are sixteen thermocouple inputs, labeled T0 through T15, and ideally suited for K-type thermocouples. They use a low-cost chopper stabilized differential amplifier circuit specifically designed for this application. Input is via Omega type PCC-SMP receptacles. The mating connectors are listed in XXX. Measurement range is from room temperature up to about 1250 degrees C.
The inputs have been designed to work with either case-grounded or case-floating thermocouples. For fastest response time, lowest cost, and best noise immunity, Allpower Labs suggests using case-grounded type thermocouples. In this case, it is important that the frame ground of your gasifier be at the same voltage as supply ground to the GCU. If your application requires floating the gasifier itself away from GCU ground, please consult Allpower Labs for further ideas and instruction.
Cold junction compensation is done in software, assuming the cold junction temperature is 20C. Therefore, the measurements will be in error by the amount by which the ambient air temperature differs from 20C. This was done to minimize costs, assuming most gasifier applications could live with +/- a few degrees accuracy. For more accuracy, provision has been made for a Dallas DS1821 semiconductor temperature sensor to be fitted at U106, to provide cold junction compensation based on the actual cold-junction temperature.
The thermocouple channels may be configured for other types of thermocouples via user firmware, by writing calibration routines specific to the type of thermocouple used. Alternatively, these inputs may be used to measure any low voltage differential signal, as long as the common mode voltage is between -0.3 and +0.7 volts. A good example might be current sensing using a shunt resistor.
2.4Pressure inputs
There are four pressure sensor positions, labeled PS0 through PS3. The board land patterns are compatible with Freescale pressure sensor case types 482-01, 482A-01, 1369-01, 1351-01, and 1735-01.
Any Freescale pressure transducer with internal temperature compensation and on chip signal amplification and conditioning that fits the land pattern on the GCU may be used. Examples are MPXx7002, MPXx5010, MPXx5004, MPXx4006, etc. Consult the Freescale web site for a selection guide.
The “basic” GCU kit is supplied with one MPXV7007DP sensor (at PS0), and one MPXV7002DP sensor (at PS3). These are dual-ported sensors which read differential pressure/vacuum bidirectionally. The 7007 reads from +28 inches to -28 inches of water (+/- 7kPa). The 7002 is more sensitive (but also more fragile). It reads from +8 inches to -8 inches of water (+/- 2kPa).
The “full” GCU kit is supplied with three MPXV7007DP sensors (at PS0, PS1, and PS2), and one MPXV7002DP sensor (at PS3).
2.5Auxiliary analog inputs
Four auxiliary analog inputs, ANA0 through ANA3, are provided via connector ANA. They have input voltage dividers whose gain is settable via user-supplied resistors.
R505 and R506 set the input gain of ANA0. Gain is R506/(R505+R506).
R507 and R508 set the input gain of ANA1. Gain is R508/(R507+R508).
R509 and R510 set the input gain of ANA2. Gain is R510/(R509+R510).
R511 and R512 set the input gain of ANA3. Gain is R512/(R511+R512).
The divided voltages are clamped to the range of 0..5 volts, via a zener shunt protection circuit. If you wish to overdrive the voltage on the analog inputs, please be sure to select input resistors with high enough impedance to limit the input current to 30 mA or less.
2.6FET outputs
Eight sink-to-ground type switched FET outputs are provided, at the connectors labeled FET0-3 and FET4-7. The device used is the Vishay Si4322DY, with integral Schottky diode. Vds is 30V, and Id is 18 amps, though thermal considerations will prevent sinking 18 amps continuous. Allpower Labs suggests not sinking more than 5 amps continuous per channel.
Pin 1 of each terminal strip is ground. Pins 2 through 5 are the FET outputs. Pin 6 is the positive supply for flyback protection.
Flyback protection is provided by D20 through D27. Flyback reference supply should either be presented at pin 6 of the terminal strip, or JP1 (resp. JP2) should be installed to use the supply input to the board as the flyback reference. If JP1 (resp. JP2) is installed, then the positive supply input to the board will be available at pin 6 of the terminal strip.
Overcurrent protection is provided by F0 through F7, resettable PTC fuses. As supplied, these are of type Littelfuse 30R300UU. Hold current is 3 amps, trip current is 6 amps, and the trip time is 10.8 seconds.
All FET outputs may be modulated via hardware PWM outputs of the MCU.
2.7Display and keypad
A 4x20 alphanumeric backlit LCD display is provided, along with four softswitches below it (PB0 through PB3). This facilitates stand-alone operation, without the use of a host computer.
If more softswitches are desired for your application, a 4 by 4 matrix keypad may be connected to the connector labeled “keypad”.
2.8USB Host interface
The USB host interface is the primary means for the GCU to communicate with a host computer. It behaves as a USB serial port.
The host interface uses an FTDI FT232RL chip. The drivers for this chip are already included with modern versions of the Windows, MacOS, and Linux operating systems. You should not have to download or install any drivers – the GCU should appear as a serial port when you plug it in via a USB cable. Examples might be COM7 or COM8 in windows, or /dev/ttyUSB0 in Linux.
You may talk directly to the GCU using a terminal program of your choice. Set your serial communication parameters to XXX baud, 8 data bits, no parity, 1 stop bit, no hardware flow control. Alternatively, you may write host-side programs to your own specifications to interface with the GCU.
2.9Frequency counter input
A single frequency counter input is provided via the connector labeled “TIMER”. This facilitates, for example, measurement of the RPM of an attached internal combustion engine (or a turbine, for that matter).
The input has a voltage divider whose gain is settable via user-supplied resistors.
R501 and R502 set the input gain of TIMER. Gain is R502/(R501+R502).
The divided voltage is clamped to the range of 0..5 volts, via a zener shunt protection circuit. If you wish to overdrive the voltage on the timer input, please be sure to select input resistors with high enough impedance to limit the input current to 30 mA or less.
2.10PWM servo outputs
Three R/C hobby style PWM servo outputs are provided, with standard pinouts. The connectors are labeled SRV0, SRV1, and SRV2. The BLACK (ground) wire of the servo should be aligned with pin 1 of the connector (labeled on the board with a white dot).
Power for the servos is 5 volts DC, derived from the input power to the board via the main switching regulator. The drive current per servo should not exceed 1 amp continuous.
Pulse frequency is nominally 62.5 Hz (i.e. 16 ms period). Pulse width is variable from approximately 500 us, to approximately 1500 us.
2.11CANbus
A CANbus interface is provided at the terminal strip labeled “CAN”. Presently no firmware support is provided. This might be used, for example, to interface with the motor management system on a modern automobile.
The hardware is an MCP2515 CAN controller chip, interfaced to the MCU via the SPI port.
2.12Auxiliary RS-232 port
An auxiliary RS-232 port is provided, with a DB-9M connector. The GCU functions as DTE. Presently no firmware support is provided.
IMPORTANT: Version 2.01 boards have a hardware error. The pinout on this connector is incorrect. Do not use without consulting first with Allpower Labs.
2.13SD-card slot
An SD card slot is provided. This is intended for data logging. No firmware support will be included in the early firmware versions.
The slot is interfaced to the MCU via SPI, so code may NOT be directly executed from the SD card, and data may NOT be fetched directly from the SD card directly through the data address space of the MCU. In the future, low level I/O firmware routines will be provided for interfacing to the SD card.
2.14Prototyping and modification area
Underneath the display (or on the back side of the board, if you wish to think of it that way), a generous breadboard area is provided. This area has approximately 800 plated-through holes, on 0.100” centers, to accommodate user circuitry.
All unused pins on the MCU are padded out to vias, to facilitate user interfacing to the MCU. Sadly, these vias are somewhat haphazardly placed, due to space restrictions on the board. Contact APL for details on via locations, or look at the board yourself with a loupe in the vicinity of the MCU.
3Operation in detail
XXX TBD
4Firmware and support
The “Basic App” supplied with the GCU is written in C, and compiled in the Arduino environment.
The decision to embed in the Arduino environment was made to make it very easy for you to modify the firmware to suit your application. This chapter explains how to get started with your custom modifications.
We hope (indeed, the GPL license requires) that if you make generally useful modifications and/or enhancements, that you will upload your enhanced source code to the GEK wiki GCU user’s community, so that others may also benefit.
4.1Getting started
4.1.1Obtaining and installing the Arduino environment
Go to and download the latest version of the Arduino development environment. As of this writing, version 0.15 is current. Unzip the environment onto your hard disk.
Go to the folder where you unzipped the environment, and double click Arduino.exe. You should now have the Arduino environment up and running.
4.1.2Obtaining and installing the source code
Go to the GEK Gasifier wiki, go to the GCU page, and find the link for the Kitchen Sink libraries zip file, and the Basic App zip file. Download these both to your hard disk.
Unzip the libraries into <arduino-install-dir>/hardware/libraries/KS
Unzip the Basic App into <My Documents>/Arduino/KS
4.1.3Recompiling
Now, terminate and restart the Arduino environment. This is necessary to get it to recognize that new libraries have been installed.
In your “sketchbook”, you should find a new sketch called “KS”. Load it. You will see the C source for the Basic App in the editor window.
Type Ctrl-R, or select SketchVerify/Compile.
If all is well, after some time, the diagnostic window will display “Binary sketch size: <xxx> bytes (of a 126976 byte maximum)”. If this message appears, you have successfully recompiled the Basic App.
If there are problems, scroll upward in the Arduino diagnostic window for hints as to what may have gone wrong. If all else fails, consult the GEK wiki user’s community, or contact Allpower Labs.
4.1.4Uploading to the GCU
Now, plug the GCU into a USB port on your computer. If all is well, the GCU should present itself as a serial RS-232 port. If you don’t know what port number it is, try looking in “Control panel/System/Hardware/Device manager” (on Windows), or do “dmesg” (on Linux).
Once you have found the correct port name or number, tell Arduino what board you’re using and where it is:
ToolsBoardArduino Mega <this tells Arduino what board you’re using
ToolsSerialPort<your port name> <this tells Arduino what serial port it’s on>
Now, the moment de la verité: Click the “Upload to I/O Board” button. After a few seconds, the heartbeat LED on your GCU should go out. After a few more moments, it should start again, the diagnostic window will display a happy message, and the Basic App menu will again appear in the display.