This is an old revision of the document!

SpiffChorder hardware

The image below shows the schematics for the SpiffChorder hardware. The interface to the USB connection is handled with a few passive components. Since the USB communication is handled by bit-banging in the software, an accurate clock source is needed. A 12.000 MHz crystal provides this. Since the beginning of the SpiffChorder project, the AVR USB stack has been expanded to also work at 16 MHz and 16.5 MHz, but this has not been tested with the SpiffChorder.

SpiffChorder hardware schematics (click for larger version)

Bill of Materials

Below is a list of the components needed to build the SpiffChorder.

referencedescriptiondigikey part number
C1, C222pF ceramic capacitor.490-3709-ND
C3, C5100nF ceramic capacitor (decoupling).399-4328-ND
C410uF electrolytic capacitor, min. 10V.493-1767-ND
CON12×3 pin header, e.g. shrouded header from Harting.
CON2USB connector, alternatively cable with type-A plug.
CON3Connection to switches. Can be wired directly.
CON4Connection to LEDs. Optional.
D1, D23.6V zener-diode.1N4729ADICT-ND
IC1Atmel ATmega168.ATMEGA168-20PU-ND1)
28 pin socket for IC1ED90054-ND
R12.2 kOhm resistor.OD222JE-ND
R24.7 kOhm resistor.OD472JE-ND
R3, R482 Ohm resistor.OD820JE-ND
R5-R7LED current limiting resistors. About 1 kOhm, depending on selected LEDs.
R8-R18Optional pull-up resistors. 10 kOhm or 4.7 kOhm.4610X-1-103LF-ND
X112.000 MHz crystal.XC1380-ND
key switches401-1426-1-ND or CH196-ND 2)


  • C1 and C2 should ideally match the load capacitance Cl of the crystal X1. If Cl is not known, 22pF for C1 and C2 seems to work.
  • CON1 is for in-system programming. If a socket is used for the ATmega168, this is not needed. Work is being done to test the boot-loader on ATmega168. The boot loader needs to be installed in the ATmega8 before it is soldered in place (unless the CON1 connector is mounted).
  • CON2 is a USB connector. Use either a type-B receptacle, in combination with a USB type-A to type-B cable. Or find a USB cable with a type-A plug in one end, and cut off the other end. The schematics show the standard colors for the USB connections.
  • CON3 is for connecting the switches. A connector is not needed, as the switches can be wired directly. Each switch should connect one of the inputs to ground when pressed. In other words a normally open (NO) type switch should be used.
  • CON4 provides the connection to 3 status LEDs. These show the current mode of the SpiffChorder, and are therefore optional. Again the LEDs can be wired directly, no connector is needed. If the LEDs are not mounted, the current limiting resistors R5-R7 can be omitted as well.
  • IC1 is the ATmega168. The schematics show the pin-numbering for the P version (DIL package). If using the SMD version, use the pin-names instead. The ATmega168V should not be used, as it does not support running at 12MHz. I have used ATmega168-20PI, but the older non-ROHS compatible ATmega168-20PU will also work.
  • R5-R7 are current limiting resistors for the (optional) LEDs. The value of these depend on how bright the LEDs should be, and the voltage drop across the LED. For newer LEDs, a value of 1 kOhm seems to give plenty of light, but you can go as low as 220 Ohm, resulting in about 20 mA current through each LED. Note that this is a considerable amount of current compared to the rest of the SpiffChorder.
  • R8-R18 are optional pull-up resistors. These should only be needed if the wires between the microcontroller and the switches are excessively long. A value of 10 kOhm or 4.7 kOhm should work, but remember that the lower the value, the greater the current consumption when the switch is pressed. Also, if not all switches are connected, some of the resistors can be left out in any case.
With a slight change in the makefile you can still use the atmega8 digikey part number ATMEGA8-16PU-ND. Both chips are also available from the nice folks at tuxgraphics, they are at
I have used the Cherry MX series for years, see
spiffchorder/hardware.1210862306.txt.gz · Last modified: 2008/05/15 10:38 by priestdo
Top of the Wiki Creative Commons License Valid CSS Driven by DokuWiki Recent changes RSS feed Valid XHTML 1.0