I have an Atmega 328p on a breadboard that is configured to run off of the internal 8 MHz clock. I am unsuccessfully trying to upload a simple hello world to it from PlatformIO. I have verified that I am able to use the Atmel ICE programmer to upload a program via the VisualMicro Visual Studios Plugin and the Arduino IDE, but I am totally flailing around trying to figure out how to make it work in PlatformIO.
I’ve spent some time trying to understand the solution found in this post:
And I’m a little embarrassed that I am so lost after all of the instructions in that post.
Here is my “platformio.ini”:
[env:Breadboard ATMega328]
platform = atmelavr
board = 328p8m
framework = arduino
board_build.mcu = atmega328p
board_build.f_cpu = 8000000L
upload_protocol = atmel-ice
Result:
Verbose mode can be enabled via
-v, --verbose
option
CONFIGURATION: Redirecting...
PLATFORM: Atmel AVR 1.15.0 > Microduino Core (Atmega328P@8M,3.3V)
HARDWARE: ATMEGA328P 8MHz, 2KB RAM, 31.50KB Flash
PACKAGES: toolchain-atmelavr 1.50400.190710 (5.4.0), framework-arduinoavr 4.1.2, tool-avrdude 1.60300.190424 (6.3.0)
LDF: Library Dependency Finder → Library Dependency Finder (LDF) — PlatformIO latest documentation
LDF Modes: Finder ~ chain, Compatibility ~ soft
Found 5 compatible libraries
Scanning dependencies…
No dependencies
Building in release mode
Compiling .pio\build\Breadboard ATMega328\src\main.cpp.o
Archiving .pio\build\Breadboard ATMega328\libFrameworkArduinoVariant.a
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\CDC.cpp.o
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\HardwareSerial.cpp.o
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\HardwareSerial0.cpp.o
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\HardwareSerial1.cpp.o
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\HardwareSerial2.cpp.o
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\HardwareSerial3.cpp.o
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\IPAddress.cpp.o
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\PluggableUSB.cpp.o
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\Print.cpp.o
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\Stream.cpp.o
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\Tone.cpp.o
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\USBCore.cpp.o
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\WInterrupts.c.o
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\WMath.cpp.o
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\WString.cpp.o
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\abi.cpp.o
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\hooks.c.o
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\main.cpp.o
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\new.cpp.o
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\wiring.c.o
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\wiring_analog.c.o
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\wiring_digital.c.o
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\wiring_pulse.S.o
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\wiring_pulse.c.o
Compiling .pio\build\Breadboard ATMega328\FrameworkArduino\wiring_shift.c.o
Archiving .pio\build\Breadboard ATMega328\libFrameworkArduino.a
Linking .pio\build\Breadboard ATMega328\firmware.elf
Checking size .pio\build\Breadboard ATMega328\firmware.elf
Building .pio\build\Breadboard ATMega328\firmware.hex
Advanced Memory Usage is available via “PlatformIO Home > Project Inspect”
DATA: [= ] 10.0% (used 204 bytes from 2048 bytes)
PROGRAM: [= ] 5.3% (used 1724 bytes from 32256 bytes)
Configuring upload protocol…
AVAILABLE: atmel-ice
CURRENT: upload_protocol = atmel-ice
Looking for upload port…
Auto-detected: COM84
Uploading .pio\build\Breadboard ATMega328\firmware.hexavrdude: Can’t find programmer id “atmel-ice”
Valid programmers are:
2232HIO = FT2232H based generic programmer
4232h = FT4232H based generic programmer
arduino = Arduino
arduino-ft232r = Arduino: FT232R connected to ISP
arduinoisp = Arduino ISP Programmer
arduinoisporg = Arduino ISP Programmer
atmelice = Atmel-ICE (ARM/AVR) in JTAG mode
atmelice_dw = Atmel-ICE (ARM/AVR) in debugWIRE mode
atmelice_isp = Atmel-ICE (ARM/AVR) in ISP mode
atmelice_pdi = Atmel-ICE (ARM/AVR) in PDI mode
avr109 = Atmel AppNote AVR109 Boot Loader
avr910 = Atmel Low Cost Serial Programmer
avr911 = Atmel AppNote AVR911 AVROSP
avrftdi = FT2232D based generic programmer
avrisp = Atmel AVR ISP
avrisp2 = Atmel AVR ISP mkII
avrispmkII = Atmel AVR ISP mkIIavrispv2 = Atmel AVR ISP V2
buspirate = The Bus Pirate
buspirate_bb = The Bus Pirate (bitbang interface, supports TPI)
butterfly = Atmel Butterfly Development Board
butterfly_mk = Mikrokopter.de Butterfly
bwmega = BitWizard ftdi_atmega builtin programmer
C232HM = FT232H based module from FTDI and Glyn.com.au
c2n232i = serial port banging, reset=dtr sck=!rts mosi=!txd miso=!cts
dasa = serial port banging, reset=rts sck=dtr mosi=txd miso=cts
dasa3 = serial port banging, reset=!dtr sck=rts mosi=txd miso=cts
diecimila = alias for arduino-ft232r
dragon_dw = Atmel AVR Dragon in debugWire mode
dragon_hvsp = Atmel AVR Dragon in HVSP mode
dragon_isp = Atmel AVR Dragon in ISP mode
dragon_jtag = Atmel AVR Dragon in JTAG mode
dragon_pdi = Atmel AVR Dragon in PDI mode
dragon_pp = Atmel AVR Dragon in PP mode
flip1 = FLIP USB DFU protocol version 1 (doc7618)
flip2 = FLIP USB DFU protocol version 2 (AVR4023)
ft232r = FT232R Synchronous BitBang
ft245r = FT245R Synchronous BitBang
jtag1 = Atmel JTAG ICE (mkI)
jtag1slow = Atmel JTAG ICE (mkI)
jtag2 = Atmel JTAG ICE mkII
jtag2avr32 = Atmel JTAG ICE mkII im AVR32 mode
jtag2dw = Atmel JTAG ICE mkII in debugWire mode
jtag2fast = Atmel JTAG ICE mkII
jtag2isp = Atmel JTAG ICE mkII in ISP mode
jtag2pdi = Atmel JTAG ICE mkII PDI mode
jtag2slow = Atmel JTAG ICE mkII
jtag3 = Atmel AVR JTAGICE3 in JTAG mode
jtag3dw = Atmel AVR JTAGICE3 in debugWIRE mode
jtag3isp = Atmel AVR JTAGICE3 in ISP mode
jtag3pdi = Atmel AVR JTAGICE3 in PDI mode
jtagkey = Amontec JTAGKey, JTAGKey-Tiny and JTAGKey2
jtagmkI = Atmel JTAG ICE (mkI)
jtagmkII = Atmel JTAG ICE mkII
jtagmkII_avr32 = Atmel JTAG ICE mkII im AVR32 mode
lm3s811 = Luminary Micro LM3S811 Eval Board (Rev. A)
mib510 = Crossbow MIB510 programming board
mkbutterfly = Mikrokopter.de Butterfly
nibobee = NIBObee
o-link = O-Link, OpenJTAG from www.100ask.net
openmoko = Openmoko debug board (v3)
pavr = Jason Kyle’s pAVR Serial Programmer
pickit2 = MicroChip’s PICkit2 Programmer
ponyser = design ponyprog serial, reset=!txd sck=rts mosi=dtr miso=cts
siprog = Lancos SI-Prog http://www.lancos.com/siprogsch.html
stk500 = Atmel STK500
stk500hvsp = Atmel STK500 V2 in high-voltage serial programming mode
stk500pp = Atmel STK500 V2 in parallel programming mode
stk500v1 = Atmel STK500 Version 1.x firmware
stk500v2 = Atmel STK500 Version 2.x firmware
stk600 = Atmel STK600
stk600hvsp = Atmel STK600 in high-voltage serial programming mode
stk600pp = Atmel STK600 in parallel programming mode
ttl232r = FTDI TTL232R-5V with ICSP adapter
tumpa = TIAO USB Multi-Protocol Adapter
UM232H = FT232H based module from FTDI and Glyn.com.au
uncompatino = uncompatino with all pairs of pins shorted
usbasp = USBasp, USBasp - USB programmer for Atmel AVR controllers - fischl.de
usbasp-clone = Any usbasp clone with correct VID/PID
usbtiny = USBtiny simple USB programmer, USBtinyISP - Inexpensive USB AVR Programmer
wiring = Wiring
xplainedmini = Atmel AVR XplainedMini in ISP mode
xplainedmini_dw = Atmel AVR XplainedMini in debugWIRE mode
xplainedpro = Atmel AVR XplainedPro in JTAG mode*** [upload] Error 1
I have edited the “328p8m.json” file to:
{
"build": {
"core": "arduino",
"extra_flags": "-DARDUINO_AVR_MICRODUINO_CORE",
"f_cpu": "8000000L",
"mcu": "atmega328p",
"variant": "standard"
},
"frameworks": [
"arduino"
],
"name": "Microduino Core (Atmega328P@8M,3.3V)",
"upload": {
"maximum_ram_size": 2048,
"maximum_size": 32256
},
"url": "http://wiki.microduinoinc.com/Microduino-Module_Core",
"vendor": "Microduino"
}
Which removed some upload parameters I thought might be getting in the way:
"upload": {
"maximum_ram_size": 2048,
"maximum_size": 32256,
"protocol": "arduino",
"require_upload_port": true,
"speed": 57600
},
I feel like this line of the upload terminal output is the problem:
Looking for upload port…
Auto-detected: COM84
Uploading .pio\build\Breadboard ATMega328\firmware.hex
Because COM 84 is not the ICE programmer…
Does anyone see what I am doing wrong?
Thanks for reading,
-Dave