butterfly.rst 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. ===================================================
  2. spi_butterfly - parport-to-butterfly adapter driver
  3. ===================================================
  4. This is a hardware and software project that includes building and using
  5. a parallel port adapter cable, together with an "AVR Butterfly" to run
  6. firmware for user interfacing and/or sensors. A Butterfly is a $US20
  7. battery powered card with an AVR microcontroller and lots of goodies:
  8. sensors, LCD, flash, toggle stick, and more. You can use AVR-GCC to
  9. develop firmware for this, and flash it using this adapter cable.
  10. You can make this adapter from an old printer cable and solder things
  11. directly to the Butterfly. Or (if you have the parts and skills) you
  12. can come up with something fancier, providing circuit protection to the
  13. Butterfly and the printer port, or with a better power supply than two
  14. signal pins from the printer port. Or for that matter, you can use
  15. similar cables to talk to many AVR boards, even a breadboard.
  16. This is more powerful than "ISP programming" cables since it lets kernel
  17. SPI protocol drivers interact with the AVR, and could even let the AVR
  18. issue interrupts to them. Later, your protocol driver should work
  19. easily with a "real SPI controller", instead of this bitbanger.
  20. The first cable connections will hook Linux up to one SPI bus, with the
  21. AVR and a DataFlash chip; and to the AVR reset line. This is all you
  22. need to reflash the firmware, and the pins are the standard Atmel "ISP"
  23. connector pins (used also on non-Butterfly AVR boards). On the parport
  24. side this is like "sp12" programming cables.
  25. ====== ============= ===================
  26. Signal Butterfly Parport (DB-25)
  27. ====== ============= ===================
  28. SCK J403.PB1/SCK pin 2/D0
  29. RESET J403.nRST pin 3/D1
  30. VCC J403.VCC_EXT pin 8/D6
  31. MOSI J403.PB2/MOSI pin 9/D7
  32. MISO J403.PB3/MISO pin 11/S7,nBUSY
  33. GND J403.GND pin 23/GND
  34. ====== ============= ===================
  35. Then to let Linux master that bus to talk to the DataFlash chip, you must
  36. (a) flash new firmware that disables SPI (set PRR.2, and disable pullups
  37. by clearing PORTB.[0-3]); (b) configure the mtd_dataflash driver; and
  38. (c) cable in the chipselect.
  39. ====== ============ ===================
  40. Signal Butterfly Parport (DB-25)
  41. ====== ============ ===================
  42. VCC J400.VCC_EXT pin 7/D5
  43. SELECT J400.PB0/nSS pin 17/C3,nSELECT
  44. GND J400.GND pin 24/GND
  45. ====== ============ ===================
  46. Or you could flash firmware making the AVR into an SPI slave (keeping the
  47. DataFlash in reset) and tweak the spi_butterfly driver to make it bind to
  48. the driver for your custom SPI-based protocol.
  49. The "USI" controller, using J405, can also be used for a second SPI bus.
  50. That would let you talk to the AVR using custom SPI-with-USI firmware,
  51. while letting either Linux or the AVR use the DataFlash. There are plenty
  52. of spare parport pins to wire this one up, such as:
  53. ====== ============= ===================
  54. Signal Butterfly Parport (DB-25)
  55. ====== ============= ===================
  56. SCK J403.PE4/USCK pin 5/D3
  57. MOSI J403.PE5/DI pin 6/D4
  58. MISO J403.PE6/DO pin 12/S5,nPAPEROUT
  59. GND J403.GND pin 22/GND
  60. IRQ J402.PF4 pin 10/S6,ACK
  61. GND J402.GND(P2) pin 25/GND
  62. ====== ============= ===================