You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
87 lines
3.8 KiB
Markdown
87 lines
3.8 KiB
Markdown
avr_boot
|
|
========
|
|
|
|
SD card bootloader for atmega processors
|
|
|
|
As easy as it can get! I spent days with this. Hopefully you wont!
|
|
|
|
- for any ATMega with 4096kb Bootloader
|
|
- uses Petit FatFs R0.03 for FAT12, FAT16, FAT32
|
|
- looks for FIRMWARE.BIN and flashes it nearly instantly
|
|
- without any interference to your application
|
|
- no CRC Check and no version bytes in EEPROM (see KISS)
|
|
|
|
### Boards Manager installation
|
|
|
|
avr_boot is integrated in Arduino IDE version 1.6.4 or greater!!! [See here for instructions.](https://github.com/zevero/avr_boot/tree/gh-pages)
|
|
|
|
### Manual installation
|
|
|
|
This is with avr-gcc and avrdude under linux with an Atmega1284p and AVRISP mkII! Adaption to your case (WinAvr, another Atmega, another flash-tool) will not be complicated...
|
|
|
|
- adapt Makefile
|
|
- MCU_TARGET: Your atmegaXXX
|
|
- BOOT_ADR: in bytes not words!
|
|
- F_CPU: CPU Frequency (not critical. A higher value will work as well)
|
|
- SD_CS_PORT: Data Register of the SD CS pin(see the datasheet for your microcontroller)
|
|
- SD_CS_DDR: Data Direction Register of the SD CS pin
|
|
- SD_CS_BIT: Bit of the SD CS pin
|
|
- USE_LED: For debugging 0...deactivate or 1...active
|
|
- USE_UART: For debugging 0...deactivate or divider (UBRR) for baudate see http://wormfood.net/avrbaudcalc.php
|
|
- update spi_pins.h with the SPI pins of your microcontroller if not already defined
|
|
- if using USE_LED adapt LED-pins in asmfunc.S
|
|
- if you want to add FAT12 adapt pff/src/pffconfh.h (default ist FAT16 + FAT32)
|
|
- if you want to support lower case filenames adapt pff/src/pffconfh.h (default is uppercase)
|
|
- if you prefer another filename instead of FIRMWARE.BIN adapt main.c
|
|
- make (you may need to do "sudo apt-get install avr-libc gcc-avr")
|
|
- set fuses: avrdude -c avrispmkII -p m1284p -U hfuse:w:0xda:m
|
|
- find high fuse in http://eleccelerator.com/fusecalc/fusecalc.php?chip=atmega1284p
|
|
- flash: avrdude -c avrispmkII -p m1284p -Uflash:w:./avr_boot.hex:i -Ulock:w:0x3F:m
|
|
|
|
### Put your sketch on SD card
|
|
|
|
- in Arduino IDE go to File > Preferences and check "Show verbose output during compiliation"
|
|
- compile sketch and find the location of your /tmp/buildxxx/sketch.cpp.hex
|
|
- make bin file: avr-objcopy -I ihex -O binary sketch.cpp.hex FIRMWARE.BIN
|
|
- copy the file into the root of an SD (FAT16/FAT32)
|
|
- put it into the SD slot of your ATmega
|
|
- reset it
|
|
- it might already have happend!
|
|
|
|
### Bootloader sizes
|
|
Compiled under linux for atmega328p / atmega1284p
|
|
- 3674 / 3724 bytes
|
|
- 3984 / 4034 bytes debugging with USE_LED
|
|
- 3992 / 4052 bytes debugging with USE_UART
|
|
|
|
### Tested successfully on
|
|
- ATmega168
|
|
- ATmega328P
|
|
- ATmega32u4
|
|
- ATmega1284P
|
|
- ATmega2560 (see issue #2)
|
|
|
|
### Serial support - Help wanted
|
|
it should not be impossible to fit a normal serial bootloader (with automatic baudrate detection?) into the remaining bytes ... help is appreciated!
|
|
|
|
### KISS
|
|
If you wish you *can* add CRC Check or versioning with EEPROM *but* I prefere to keep things simple. avr_boot will reflash your FIRMWARE.BIN as long as it is present.
|
|
Is this a problem? No! It happens nearly instantly and only differing bytes are flashed really.
|
|
You may consider putting your logic into your application and perform a CRC Check after the fact to inform the user and delete or rename FIRMWARE.BIN
|
|
|
|
### Thanks to
|
|
- https://github.com/per1234 - Boards Manager Installation and help with differenct MCUs
|
|
- http://elm-chan.org/fsw/ff/00index_p.html
|
|
- Wilfried Klaas for the MCSDepthLogger https://github.com/willie68/OpenSeaMapLogger
|
|
- https://github.com/mharizanov/avr_boot
|
|
- https://github.com/osbock/avr_boot
|
|
- and others???
|
|
|
|
### Alternatives
|
|
|
|
- https://spaces.atmel.com/gf/project/sdbootloader/
|
|
- https://github.com/thseiler/embedded/tree/master/avr/2boots
|
|
- http://www.mikrocontroller.net/articles/MMC/SD_Bootloader_f%C3%BCr_AT_Mega
|
|
|
|
... call me stupid, but I passed several days debugging those - without success ...
|