spi_butterfly - parport-to-butterfly adapter driver

This is a hardware and software project that includes building and using a parallel port adapter cable, together with an "AVR Butterfly" to run firmware for user interfacing and/or sensors. A Butterfly is a $US20 battery powered card with an AVR microcontroller and lots of goodies: sensors, LCD, flash, toggle stick, and more. You can use AVR-GCC to develop firmware for this, and flash it using this adapter cable.

You can make this adapter from an old printer cable and solder things directly to the Butterfly. Or (if you have the parts and skills) you can come up with something fancier, providing ciruit protection to the Butterfly and the printer port, or with a better power supply than two signal pins from the printer port. Or for that matter, you can use similar cables to talk to many AVR boards, even a breadboard.

This is more powerful than "ISP programming" cables since it lets kernel SPI protocol drivers interact with the AVR, and could even let the AVR issue interrupts to them. Later, your protocol driver should work easily with a "real SPI controller", instead of this bitbanger.

The first cable connections will hook Linux up to one SPI bus, with the AVR and a DataFlash chip; and to the AVR reset line. This is all you need to reflash the firmware, and the pins are the standard Atmel "ISP" connector pins (used also on non-Butterfly AVR boards). On the parport side this is like "sp12" programming cables.

Signal

Butterfly

Parport (DB-25)

SCK

J403.PB1/SCK

pin 2/D0

RESET

J403.nRST

pin 3/D1

VCC

J403.VCC_EXT

pin 8/D6

MOSI

J403.PB2/MOSI

pin 9/D7

MISO

J403.PB3/MISO

pin 11/S7,nBUSY

GND

J403.GND

pin 23/GND

Then to let Linux master that bus to talk to the DataFlash chip, you must (a) flash new firmware that disables SPI (set PRR.2, and disable pullups by clearing PORTB.[0-3]); (b) configure the mtd_dataflash driver; and (c) cable in the chipselect.

Signal

Butterfly

Parport (DB-25)

VCC

J400.VCC_EXT

pin 7/D5

SELECT

J400.PB0/nSS

pin 17/C3,nSELECT

GND

J400.GND

pin 24/GND

Or you could flash firmware making the AVR into an SPI slave (keeping the DataFlash in reset) and tweak the spi_butterfly driver to make it bind to the driver for your custom SPI-based protocol.

The "USI" controller, using J405, can also be used for a second SPI bus. That would let you talk to the AVR using custom SPI-with-USI firmware, while letting either Linux or the AVR use the DataFlash. There are plenty of spare parport pins to wire this one up, such as:

Signal

Butterfly

Parport (DB-25)

SCK

J403.PE4/USCK

pin 5/D3

MOSI

J403.PE5/DI

pin 6/D4

MISO

J403.PE6/DO

pin 12/S5,nPAPEROUT

GND

J403.GND

pin 22/GND

IRQ

J402.PF4

pin 10/S6,ACK

GND

J402.GND(P2)

pin 25/GND