User Tools

Site Tools


products:atmega32u4breakout:index.html

This is an old revision of the document!


:products:atmega32u4breakout:headerplaced.jpg

About the Atmega32u4 Breakout board+

We like the AVR 8-bit family and were excited to see Atmel upgrade the series with a USB core. Having USB built in allows the chip to act like any USB device. For example, we can program the chip to 'pretend' its a USB joystick, or a keyboard, or a flash drive! Another nice bonus of having USB built in is that instead of having an FTDI chip or cable (like an Arduino), we can emulate the serial port directly in the chip. This costs some Flash space and RAM space but that's the trade-off.

The only bad news about this chip is that it is surface mount only (SMT), which means that it is not easy to solder the way the larger DIP chips are. For that reason, we made a breakout board. The board comes with some extras like a fuse, a 16mhz crystal, USB connector and a button to start the bootloader.

Why not use a Teensy

We've also carry a similar board from PJRC called the Teensy. The Teensy uses the same chip so you may be wondering, why did we design a different-but-still-basically-the-same board? We've used the Teensy in a few projects and like it a lot but there are a few details that we wanted to change. We wanted…

  • …a bootloader that would work with avrdude since that is our preferred software
  • …another LED, for power-good indication
  • …a 500mA fuse on the USB power-source pin
  • …mounting holes so we could attach it easily
  • …reprogramming ISP header so we could program the board directly without the bootloader
  • …a larger reset button
  • …all the pins broken out for use with a breadboard
  • …as of October 28, 2011 all boards come with an Arduino 1.0 "Leonardo" bootloader but the silkscreen does not have the Arduino pins labeled

That doesn't in any way mean that it is better or replaces the Teensy. Here are some reasons we will still use the teensy for many projects

  • It's really really small. A third the size of this breakout
  • The bootloader that is programmed in uses only 512 bytes (instead of 2K)
  • It works nicely with Teensyduino and auto-resets right before programming

Assembly

:products:atmega32u4breakout:atmega32u4_lrg.jpg

The breakout is almost completely assembled. We don't solder on the header or 6-pin ISP connector since we find its easy to do but hard to undo, in case you want to put different headers on, or just connect up wires directly.

The board ships with a strip of header, you can simply break the header into two pieces and place them in a breadboard

:products:atmega32u4breakout:header.jpg

Then place the board on top and solder it in place

:products:atmega32u4breakout:headerplaced.jpg

Design Specifications

This breakout board is designed to make it easy for you to get started with the Atmega32u4, a USB-native 8 bit AVR microcontroller. We tried to keep the design simple, while taking care of all the details so that you can focus on your project's firmware and hardware.

Microcontroller

The main chip is an ATmega32u4, an 8 bit AVR-core processor which has the bonus of a USB core built in. This makes writing USB native programs such as serial ports, mouse/keyboard, mass-storage-controller, MIDI, etc very easy. The chip has 32K of flash and 2.5K of RAM. The microcontroller is clocked at 16 MHz with an on-board crystal.

Power

The board is powered by the USB port at 5V. There is a 500mA polyfuse to protect your computer from a shorted circuit. If you'd like to run the board off of another voltage, you can do that by cutting the VCC solder jumper bridge underneath and connecting an external voltage to pin #2 of the ISP header. Note that running the board at 3.3v @16mhz is considered overclocking. We do it for prototypes and it seems to work fine but its out of spec!

There is a 3V pin from the microcontroller's internal regulator (USB signals are at 3V) you can use this for maybe 10mA or so, it might work as a reference voltage)

Newer Leonardo Bootloader

Shipments after Oct 28, 2011 have the newer leonardo bootloader. This bootloader is new and experimental but seems to work well. It does not use the BOOT LED to indicate it is active (we'll try to modify the bootloader to use the LED once we've determined it works well)

You can enter the bootloader by pressing the RESET button. The board will then show up as a Serial or COM port, and you can use avrdude to program it. The 'programmer name' is stk500v1 or arduino so for example, to test you should run avrdude -p m32u4 -P COM3 -c stk500v1 which will initialize the bootloader.

The bootloader will time out eventually (after about 3 seconds) Because we are not using a USB/serial converter, bootloading is tremendously fast, we can program a full chip in under 2 seconds!

The bootloader will 'auto reset' when used with Arduino 1.0 so you don't have to press the button anymore. The bootloader source code is in the Arduino 1.0 download (in the hardware bootloaders folder called "DiskLoader"). You can auto-reset the board yourself by connecting to it at 1200 baud and then closing the port which signals you want to jump to the bootloader.

The bootloader takes up the last 2K of FLASH, so be aware that you will only have 30K instead of 32K. We have found that this isn't very constricting as 30K is still plenty. If you'd like more space, you can always use the 6-pin ISP connector and an AVR programmer (which will delete the bootloader)

If you're using windows, you will need an inf driver file, you can download it below (in the Downloads section)

Older Bootloader

Shipments before Oct 28, 2011 have the older avr109 bootloader. You can tell the bootloader is active when the green 'Boot' LED pulses/breathes The board will then show up as a Serial or COM port, and you can use avrdude to program it. The 'programmer name' is avr109 so for example, to test you should run avrdude -p m32u4 -P COM3 -c avr109 which will initialize the bootloader.

The bootloader will time out eventually (after about 10 seconds) Because we are not using a USB/serial converter, bootloading is tremendously fast, we can program a full chip in under 2 seconds!

The bootloader takes up the last 4K of FLASH, so be aware that you will only have 28K instead of 32K. We have found that this isn't very constricting as 28K is still plenty. If you'd like more space, you can always use the 6-pin ISP connector and an AVR programmer (which will delete the bootloader)

If you ever want to disable the bootloader you can cut the bottom 'HWB' jumper trace. This will disconnect the 'hardware bootloader' pin, you can then use the button as a plain reset button. For the first few runs of this board we set the fuses to still use the bootloader even with the HWB jumper cut, if you want to get rid of the bootloader, please set the fuses to remove the BOOTRST fuse. Sorry!

If you're using windows, you will need an inf driver file, you can download it below (in the Downloads section)

USB Development

The very nice thing about this chip is the USB core built in which makes USB-device development easy. What makes it even easier & better is the full USB stack already written for you by Dean Camera. Called "LUFA", the package comes with tons of working examples for all sorts of USB devices and its compeltely open source. We use the firmware as a 'starting point' which we then expand upon. Please check it out and if you find it useful consider donating time (fixing bugs, improving documentation) or funds to Dean.

Using Arduino v1.0

You can use this board with Arduino v1.0 (RC2 or higher) by selecting Leonardo as the board type, and the matching serial port.

The Arduino pins are as follows

PB0 - digital 14 / also RX LED
PB1 - digital 15 / SPI SCK
PB2 - digital 16 / SPI MOSI
PB3 - digital 17 / SPI MISO

PB4 - digital 8
PB5 - digital 9
PB6 - digital 10
PB7 - digital 11

PC6 - digital 5
PC7 - digital 13

PD0 - digital 3
PD1 - digital 2
PD2 - digital 0 / serial RX
PD3 - digital 1 / serial TX
PD4 - digital 4 / A6
PD5 - used as Serial TX LED
PD6 - digital 12
PD7 - digital 6

PE2 - unused - HWB
PE6 - (also the green BOOT LED) digital 7

PF7 - A0
PF6 - A1
PF5 - A2
PF4 - A3
PF1 - A4 
PF0 - A5 

Note that some pins are used as the RX/TX LEDs and so you shouldnt use them in your code because the IDE 'takes over' the pins for LED blinking

Using Teensyduino

Download

/home/ladyada/public_html/wiki/data/attic/products/atmega32u4breakout/index.html.1319836784.txt.gz · Last modified: 2016/01/28 18:05 (external edit)