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 Teensyduino

Edit Boards.txt

We'll need to tell the IDE about this breakout board. Open up Arduino IDE/hardware/teensy/boards.txt

Add the following text to the end of the file, save it

adafruit.name=Atmega32u4 breakout
adafruit.upload.protocol=avr109
adafruit.upload.maximum_size=28672
adafruit.upload.speed=57600
adafruit.upload.disable_flushing=true
#adafruit.serial.restart_cmd=true
adafruit.serial.safe_baud_rates_only=true
adafruit.upload.avrdude_wrapper=avrdude
adafruit.build.mcu=atmega32u4
adafruit.build.core=teensy
#adafruit.build.post_compile_script=teensy_post_compile
adafruit.build.serial_number=true
adafruit.menulist=usbtype,cpuspeed
adafruit.menu.usbtype.title=USB Type
adafruit.menu.usbtype.name0=Serial
adafruit.menu.usbtype.name1=Keyboard + Mouse
adafruit.menu.usbtype.name2=Disk(Internal) + Keyboard
adafruit.menu.usbtype.name3=Disk(SD Card) + Keyboard
adafruit.menu.usbtype.define0=-DUSB_SERIAL
adafruit.menu.usbtype.define1=-DUSB_HID
adafruit.menu.usbtype.define2=-DUSB_DISK
adafruit.menu.usbtype.define3=-DUSB_DISK_SDFLASH
adafruit.menu.usbtype.pref1.fake_serial=teensy_gateway
adafruit.menu.usbtype.pref2.fake_serial=teensy_gateway
adafruit.menu.usbtype.pref2.build.elfpatch=mktinyfat
adafruit.menu.usbtype.pref3.fake_serial=teensy_gateway
adafruit.menu.cpuspeed.title=CPU Speed
adafruit.menu.cpuspeed.name0=16 MHz
adafruit.menu.cpuspeed.name1=8 MHz
adafruit.menu.cpuspeed.name2=4 MHz
adafruit.menu.cpuspeed.name3=2 MHz
adafruit.menu.cpuspeed.name4=1 MHz
adafruit.menu.cpuspeed.pref0.build.f_cpu=16000000L
adafruit.menu.cpuspeed.pref1.build.f_cpu=8000000L
adafruit.menu.cpuspeed.pref2.build.f_cpu=4000000L
adafruit.menu.cpuspeed.pref3.build.f_cpu=2000000L
adafruit.menu.cpuspeed.pref4.build.f_cpu=1000000L

Fix avrdude and avrdude.conf

Arduino uses a really old version of Avrdude from 2007, before the chip existed. So we'll need to update it.

Download the following zip file AVRDUDE 5.10 (windows) and uncompress it. Copy avrdude.exe to ArduinoIDE/hardware/tools/avr/bin and avrdude.conf to ArduinoIDE/hardware/tools/avr/etc

If you're using Linux or Mac, just copy the avrdude.conf file

Update the Vendor ID

Open the file Arduino\hardware\teensy\cores\usb_serial\usb_private.h and find the lines

// Mac OS-X and Linux automatically load the correct drivers.  On
// Windows, even though the driver is supplied by Microsoft, an
// INF file is needed to load the driver.  These numbers need to
// match the INF file.
#define VENDOR_ID               0x16C0
#define PRODUCT_ID              0x0483

and change it to

// Mac OS-X and Linux automatically load the correct drivers.  On
// Windows, even though the driver is supplied by Microsoft, an
// INF file is needed to load the driver.  These numbers need to
// match the INF file.
#define VENDOR_ID               0x239A
#define PRODUCT_ID              0x0001

Update the USB descriptor

Open up ArduinoIDE/Hardware/Teensy/cores/usb_serial/usb.c

and change the text starting with static uint8_t PROGMEM device_descriptor[] = { to the following

static uint8_t PROGMEM device_descriptor[] = {
	18,					// bLength
	1,					// bDescriptorType
	0x01, 0x01,				// bcdUSB
	2,					// bDeviceClass
	0,					// bDeviceSubClass
	0,					// bDeviceProtocol
	ENDPOINT0_SIZE,				// bMaxPacketSize0
	LSB(VENDOR_ID), MSB(VENDOR_ID),		// idVendor
	LSB(PRODUCT_ID), MSB(PRODUCT_ID),	// idProduct
	0x00, 0x01,				// bcdDevice
	0,					// iManufacturer
	1,					// iProduct
	0,					// iSerialNumber
	1					// bNumConfigurations
};

Restart and test

If you are running the Arduino IDE, quit and restart

Now you can select the Atmega32u4 breakout board from the Teensyduino Boards menu.

You don't need to run the Teensy loader as avrdude works perfectly well on its own. You will need to press the bootloader button before uploading as we don't have an auto-reset function like the Teensy does.

Download

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