-
Notifications
You must be signed in to change notification settings - Fork 83
HeaterMeter Bootloader
The HeaterMeter bootloader is the bit of software that runs on the ATmega microcontroller before the HeaterMeter software does. A blank from the factory ATmega chip used can only be programmed via the SPI bus, generally using the ICSP header. Because most communication with the microcontroller takes place over the Serial UART, either via an FTDI USB Serial Converter or the Router's TTL Serial ports, a bootloader is usually added which adds the ability to flash a program over this Serial UART. Optiboot is a 512 byte bootloader which converts a serial variant of the stk500v1 protocol to the necessary page_fill()/page_write() commands to program the ATmega.
Note: Bootloader is not required with HeaterMeter 4 when used with a Raspberry Pi
When used with the Raspberry Pi, the ATmega328P-PU chip is programmed directly from the rPi's SPI bus. A bootloader is not needed for this operation so any bootloader on it will actually be erased when HeaterMeter is flashed from the web interface / avrupdate.
Because we want to be able to flash programs over serial, we need to either get a chip with a bootloader on it or install it ourselves. There are a lot more ways to do this than are presented here. Our ultimate goal is to have a chip with the Optiboot 4.4 bootloader or above, which is the one included with Arduino-1.0. The Optiboot that ships with Arduino-0022 has a bug in it which can prevent HeaterMeter from fully booting properly.
Chips which come from Mouser or DigiKey are completely blank, fresh from the factory. As a service to folks who are looking to use them in Arduino-style projects, hobbyist stores provide ATmega chips with the Optiboot bootloader on them already for a small markup. (~$3.50 Mouser cost, ~$4.30 Sparkfun cost, ~$5.50 Sparkfun preloded cost) This is usually the most economical solution for users who aren't going to be building a lot of projects.
- Target the target chip/board is the device you want to put the bootloader on (i.e. the blank HeaterMeter ATmega)
- Host a host board is a system which already has a bootloader or some means to upload code from your PC / the Arduino IDE. Usually an Arduino Uno, Duemilanove or Diecimila, Boardadino with FTDI cable, etc.
The next option is to build a specialized ICSP programmer capable of flashing any program to the ATmega chip, including a bootloader. There are literally hundreds of ICSP programming circuits all over the Internet. One circuit, designed for programming ATmegas is the USBtinyISP ($22). This programmer has the advantage of being natively supported by the Arduino development environment.
To burn the bootloader using USBtinyISP, assemble the HeaterMeter board and hook the USBtinyISP to the ICSP header. Do not have your HeaterMeter board plugged in to anything else! From the Arduino IDE, select:
- Tools -> Board -> Arduino Uno
- Tools -> Programmer -> USBtinyISP
- Tools -> Burn Bootloader
- Wait about 2 minutes
If you have any other ATmega-based device you can upload sketches to, this is your preferred solution. Basically, you'll upload a sketch (Optiloader) to your working device, connect 6 wires to your target, and power up the host. Optiloader is a sketch that checks for a chip connected to it via the SPI bus, and flashes Optiboot on it.
- Tools -> Board -> Select your host chip (the Duemilanove or Diecimila or Uno)
- Upload the Optiloader sketch
- Unplug the host board and assemble the appropriate flashing circuit, 6 wires: Left - Right - Overview or use the Arduino as ISP breadboard section.
- Apply power. Optiloader will immediately begin flashing as soon as it powers up. You can open the Serial Monitor at 19200 baud to watch the progress.
- Wait about 5 seconds. Optiloader will tell you when it is done.
Type 'G' or hit RESET for next chip
This technique is the traditional way to flash a bootloader using an Arduino Duemilanove or Diecimila (or possibly an Uno). Use the circuit above, except 5V on the target should run to 5V on the host. Additional circuit diagrams are shown on the Arduino as ISP page. This method is much slower than the "Program from any ATmega" method and may require additional capacitors to prevent reset, and gosh there's just so many things that can go wrong I can't imagine why anyone would want to use it. Still, it is the semi-official Arduino way [which is awful] so it is included here for academics.
- Edit (your Arduino directory)/hardware/arduino/programmers.txt and change
arduinoisp.speed=19200
toarduinoisp.speed=9600
- Close all open Arduino windows, and restart the Arduino IDE
- Tools -> Board -> Select your host chip (the Duemilanove or Diecimila)
- File -> Examples -> ArduinoISP
- Change
Serial.begin(19200);
toSerial.begin(9600);
(around line 69) - Upload
- Assemble the appropriate flashing circuit
- Disable your host chip auto-reset feature by placing a 10u or higher capacitor between RESET and GND.
- Tools -> Board -> Arduino Uno (UNO, not the host board)
- Tools -> Programmer -> Arduino as ISP
- Tools -> Burn Bootloader
- Wait a couple minutes
Building the circuit can be simplified by using a shield designed for such a purpose, such as the Evil Mad Science ISP Shield