Проблемы с загрузкой с новым Nano
Мой первый пост - я относительный новичок.
Я хочу сделать смарт-контроллер для своей лодки - я построил электронику, написал и протестировал скетч для Nano, и все работает совершенно нормально. Затем я решил, что хотел бы сохранить свою существующую Nano (Nano-A) в качестве системы разработки и купить другую (Nano-B) для фактического развертывания. Оба они - дешевые китайские клоны (от разных поставщиков).
Однако я не могу ничего загрузить в Nano-B. Кажется, что он в основном работает (светодиоды мигают), но не хочет принимать какие-либо загрузки скетчей. COM-порт, кажется, работает нормально, и я попробовал все различные варианты, доступные в Arduino IDE (платы, программаторы и т. Д.), Но безуспешно.
Поэтому я пришел к выводу, что, возможно, загрузчик на Nano-B нуждается в повторной прошивке.
Поэтому я настроил Nano-A в качестве программатора, загрузил "ArduinoISP", подключил контакты ISP и нажал "записать загрузчик".
Кажется, что это "почти работает". Я включил опцию -v (verbose) для avrdude и вставил журнал ниже. Мне кажется, что IDE дважды вызывает avrdude; (1) Чтобы установить предохранители и т. Д., И (2) чтобы загрузить фактический загрузчик. Мне кажется, что (1) работает нормально, но (2) терпит неудачу.
Я рвал на себе волосы уже около 3 недель и очень хотел бы получить кое-какие идеи. Заранее спасибо.
Arduino "burn bootloader" IDE Log - следует;
Arduino: 1.8.13 (Windows Store 1.8.42.0) (Windows 10), Board: "Arduino Nano, ATmega328P"
C:\Users\--\Documents\ArduinoData\packages\arduino\tools\avrdude\6.3.0-arduino17/bin/avrdude -CC:\Users\--\Documents\ArduinoData\packages\arduino\tools\avrdude\6.3.0-arduino17/etc/avrdude.conf -v -patmega328p -cstk500v1 -PCOM8 -b19200 -e -Ulock:w:0x3F:m -Uefuse:w:0xFD:m -Uhfuse:w:0xDA:m -Ulfuse:w:0xFF:m
avrdude: Version 6.3-20190619
Copyright (c) 2000-2005 Brian Dean, http://www.bdmicro.com/
Copyright (c) 2007-2014 Joerg Wunsch
System wide configuration file is "C:\Users\--\Documents\ArduinoData\packages\arduino\tools\avrdude\6.3.0-arduino17/etc/avrdude.conf"
Using Port : COM8
Using Programmer : stk500v1
Overriding Baud Rate : 19200
AVR Part : ATmega328P
Chip Erase delay : 9000 us
PAGEL : PD7
BS2 : PC2
RESET disposition : dedicated
RETRY pulse : SCK
serial program mode : yes
parallel program mode : yes
Timeout : 200
StabDelay : 100
CmdexeDelay : 25
SyncLoops : 32
ByteDelay : 0
PollIndex : 3
PollValue : 0x53
Memory Detail :
Block Poll Page Polled
Memory Type Mode Delay Size Indx Paged Size Size #Pages MinW MaxW ReadBack
----------- ---- ----- ----- ---- ------ ------ ---- ------ ----- ----- ---------
eeprom 65 20 4 0 no 1024 4 0 3600 3600 0xff 0xff
flash 65 6 128 0 yes 32768 128 256 4500 4500 0xff 0xff
lfuse 0 0 0 0 no 1 0 0 4500 4500 0x00 0x00
hfuse 0 0 0 0 no 1 0 0 4500 4500 0x00 0x00
efuse 0 0 0 0 no 1 0 0 4500 4500 0x00 0x00
lock 0 0 0 0 no 1 0 0 4500 4500 0x00 0x00
calibration 0 0 0 0 no 1 0 0 0 0 0x00 0x00
signature 0 0 0 0 no 3 0 0 0 0 0x00 0x00
Programmer Type : STK500
Description : Atmel STK500 Version 1.x firmware
Hardware Version: 2
Firmware Version: 1.18
Topcard : Unknown
Vtarget : 0.0 V
Varef : 0.0 V
Oscillator : Off
SCK period : 0.1 us
avrdude: AVR device initialized and ready to accept instructions
Reading | ################################################## | 100% 0.11s
avrdude: Device signature = 0x1e950f (probably m328p)
avrdude: erasing chip
avrdude: reading input file "0x3F"
avrdude: writing lock (1 bytes):
Writing | ################################################## | 100% 0.04s
avrdude: 1 bytes of lock written
avrdude: verifying lock memory against 0x3F:
avrdude: load data lock data from input file 0x3F:
avrdude: input file 0x3F contains 1 bytes
avrdude: reading on-chip lock data:
Reading | ################################################## | 100% 0.04s
avrdude: verifying ...
avrdude: 1 bytes of lock verified
avrdude: reading input file "0xFD"
avrdude: writing efuse (1 bytes):
Writing | ################################################## | 100% 0.04s
avrdude: 1 bytes of efuse written
avrdude: verifying efuse memory against 0xFD:
avrdude: load data efuse data from input file 0xFD:
avrdude: input file 0xFD contains 1 bytes
avrdude: reading on-chip efuse data:
Reading | ################################################## | 100% 0.04s
avrdude: verifying ...
avrdude: 1 bytes of efuse verified
avrdude: reading input file "0xDA"
avrdude: writing hfuse (1 bytes):
Writing | ################################################## | 100% 0.04s
avrdude: 1 bytes of hfuse written
avrdude: verifying hfuse memory against 0xDA:
avrdude: load data hfuse data from input file 0xDA:
avrdude: input file 0xDA contains 1 bytes
avrdude: reading on-chip hfuse data:
Reading | ################################################## | 100% 0.04s
avrdude: verifying ...
avrdude: 1 bytes of hfuse verified
avrdude: reading input file "0xFF"
avrdude: writing lfuse (1 bytes):
Writing | ################################################## | 100% 0.04s
avrdude: 1 bytes of lfuse written
avrdude: verifying lfuse memory against 0xFF:
avrdude: load data lfuse data from input file 0xFF:
avrdude: input file 0xFF contains 1 bytes
avrdude: reading on-chip lfuse data:
Reading | ################################################## | 100% 0.04s
avrdude: verifying ...
avrdude: 1 bytes of lfuse verified
avrdude done. Thank you.
C:\Users\--\Documents\ArduinoData\packages\arduino\tools\avrdude\6.3.0-arduino17/bin/avrdude -CC:\Users\--\Documents\ArduinoData\packages\arduino\tools\avrdude\6.3.0-arduino17/etc/avrdude.conf -v -patmega328p -cstk500v1 -PCOM8 -b19200 -Uflash:w:C:\Program Files\WindowsApps\ArduinoLLC.ArduinoIDE_1.8.42.0_x86__mdqgnx93n4wtt\hardware\arduino\avr/bootloaders/optiboot/optiboot_atmega328.hex:i -Ulock:w:0x0F:m
avrdude: Version 6.3-20190619
Copyright (c) 2000-2005 Brian Dean, http://www.bdmicro.com/
Copyright (c) 2007-2014 Joerg Wunsch
System wide configuration file is "C:\Users\--\Documents\ArduinoData\packages\arduino\tools\avrdude\6.3.0-arduino17/etc/avrdude.conf"
Using Port : COM8
Using Programmer : stk500v1
Overriding Baud Rate : 19200
AVR Part : ATmega328P
Chip Erase delay : 9000 us
PAGEL : PD7
BS2 : PC2
RESET disposition : dedicated
RETRY pulse : SCK
serial program mode : yes
parallel program mode : yes
Timeout : 200
StabDelay : 100
CmdexeDelay : 25
SyncLoops : 32
ByteDelay : 0
PollIndex : 3
PollValue : 0x53
Memory Detail :
Block Poll Page Polled
Memory Type Mode Delay Size Indx Paged Size Size #Pages MinW MaxW ReadBack
----------- ---- ----- ----- ---- ------ ------ ---- ------ ----- ----- ---------
eeprom 65 20 4 0 no 1024 4 0 3600 3600 0xff 0xff
flash 65 6 128 0 yes 32768 128 256 4500 4500 0xff 0xff
lfuse 0 0 0 0 no 1 0 0 4500 4500 0x00 0x00
hfuse 0 0 0 0 no 1 0 0 4500 4500 0x00 0x00
efuse 0 0 0 0 no 1 0 0 4500 4500 0x00 0x00
lock 0 0 0 0 no 1 0 0 4500 4500 0x00 0x00
calibration 0 0 0 0 no 1 0 0 0 0 0x00 0x00
signature 0 0 0 0 no 3 0 0 0 0 0x00 0x00
Programmer Type : STK500
Description : Atmel STK500 Version 1.x firmware
Hardware Version: 2
Firmware Version: 1.18
Topcard : Unknown
Vtarget : 0.0 V
Varef : 0.0 V
Oscillator : Off
SCK period : 0.1 us
avrdude: AVR device initialized and ready to accept instructions
Reading | ################################################## | 100% 0.11s
avrdude: Device signature = 0x1e950f (probably m328p)
avrdude: NOTE: "flash" memory has been specified, an erase cycle will be performed
To disable this feature, specify the -D option.
avrdude: erasing chip
avrdude: reading input file "C:\Program Files\WindowsApps\ArduinoLLC.ArduinoIDE_1.8.42.0_x86__mdqgnx93n4wtt\hardware\arduino\avr/bootloaders/optiboot/optiboot_atmega328.hex"
avrdude: writing flash (32768 bytes):
Writing | ################################################## | 100% 0.00s
avrdude: stk500_recv(): programmer is not responding
avrdude: stk500_recv(): programmer is not responding
avrdude: stk500_cmd(): programmer is out of sync
avrdude: stk500_cmd(): programmer is out of sync
avrdude: stk500_cmd(): programmer is out of sync
avrdude: 32768 bytes of flash written
avrdude: verifying flash memory against C:\Program Files\WindowsApps\ArduinoLLC.ArduinoIDE_1.8.42.0_x86__mdqgnx93n4wtt\hardware\arduino\avr/bootloaders/optiboot/optiboot_atmega328.hex:
avrdude: load data flash data from input file C:\Program Files\WindowsApps\ArduinoLLC.ArduinoIDE_1.8.42.0_x86__mdqgnx93n4wtt\hardware\arduino\avr/bootloaders/optiboot/optiboot_atmega328.hex:
avrdude: input file C:\Program Files\WindowsApps\ArduinoLLC.ArduinoIDE_1.8.42.0_x86__mdqgnx93n4wtt\hardware\arduino\avr/bootloaders/optiboot/optiboot_atmega328.hex contains 32768 bytes
avrdude: reading on-chip flash data:
Reading | ################################################## | 100% 0.00s
avrdude: loadaddr(): (b) protocol error, expect=0x14, resp=0x3f
avrdude: stk500_paged_load(): (a) protocol error, expect=0x14, resp=0x10
avrdude: stk500_cmd(): protocol error
avr_read(): error reading address 0x7e01
read operation not supported for memory "flash"
avrdude: failed to read all of flash memory, rc=-2
avrdude: stk500_disable(): protocol error, expect=0x14, resp=0xff
avrdude done. Thank you.
Error while burning bootloader.
Редактировать... Соединения между ардуино. Nano A - это программатор. Nano B - это цель
- Nano A Nano B
- ISP 1 -- ISP 1 (МИСО)
- ISP 2 -- ISP 2 (VCC - 5v)
- ISP 3 -- ISP 3 (SCK)
- ISP 4 -- ISP 4 (MOSI)
- ISP 6 -- ISP 6 (GND)
- D10 -- ISP 5 (СБРОС)
Теперь я также добавил резистор 60 Ом между сбросом и + 5 В на Nano A
Я также попытался подключить конденсатор между СБРОСОМ и GND. (2uF и 100uF - у меня не было 10uF) - но это не имело никакого значения
Дальнейшие исследования.
Я попытался запустить avrdude в режиме "терминал" и могу подтвердить, что могу выполнять все обычные операции чтения / записи, кроме записи в любое место флэш-памяти. По-видимому, это единственная операция, которая не работает. Теперь я попытаюсь разбить операцию записи flash на отдельные инструкции программирования SPI, чтобы посмотреть, смогу ли я понять, где она терпит неудачу. Я подозреваю, что мой MCU - это "кирпич", но я многому научился!
Еще одна правка; Теперь я использую команду avrdude terminal mode "send" для пошагового выполнения отдельных операций SPI по одной для записи флэш-памяти, и эй! это работает! (см. Ниже)
Итак, если это работает, почему ArduinoISP не загружает загрузчик? Я настрою это как еще один / новый вопрос
@Rob W, 👍2
Обсуждение3 ответа
Лучший ответ:
Теперь я исправил эту проблему, но до сих пор не до конца понимаю, в чем была первоначальная проблема.
Пожалуйста, посмотрите мой другой пост на этом qusetion, чтобы увидеть, что я сделал Ссылка на другой пост
Возможно, это не ответ на проблему загрузчика, но недавно я прошел через то же самое, я немного поздно понял, в чем именно проблема, поэтому я проверил uC на плате Nano, и у него есть ATmega168 вместо обычного ATmega328P.
Поэтому, если вы используете ArduinoIDE, вам нужно проверить опцию ATmega168 при выборе чипа uC (как на рисунке выше)... Иногда (как это случилось со мной, просто переход к основам решает все проблемы)
Надеюсь, это поможет тебе, приятель
Спасибо, Киборг. Я взглянул на uC, и это ATmega328P. Интересно (возможно), что он намного больше, чем uC, который находится на другом Nano - также 328p, @Rob W
Да, приятель, эта ссылка может помочь вам узнать что-то новое о пакетах ATmega328P: https://www.eeweb.com/the-different-atmega328-packages/, @k.Cyborg
В Nano есть более одного загрузчика, новый и старый. У меня была такая же проблема, поэтому я просто перешел к инструментам в IDE и переключился с нового на старый, это решило мои проблемы.
Спасибо, Гил, это одна из первых вещей, которые я попробовал - безуспешно., @Rob W
Извините, у меня закончились идеи. Я надеюсь, что кто-нибудь сможет вам помочь., @Gil
- Arduino Nano не отвечает, желтый светодиод быстро мигает
- Можно ли обновить загрузчик Arduino (Nano) через себя и Arduino IDE или требуется ISP?
- Запись загрузчика завершается словами "avrdude done. Thank you.". но загрузчик на самом деле не прошивался
- Не удается заставить "Burn Bootloader" работать - Arduino Nano
- Разница в загрузчике между Atmel328p (сквозное отверстие) и Atmel328p au (smd)
- Расширить пространство программы, избавившись от загрузчика на NANO
- Как компилятор/ассемблер работает с загрузчиком?
- Путаница по поводу: установки загрузчика на новый Nano v3.0 (классический)
Что, если вообще что-либо, вы сделали с сигналом сброса на nano, который запускает скетч arduino sp.ino?, @timemage
Не могли бы вы показать, как вы соединили оба Nano?, @StarCat
Я подключил два nanos с помощью 6-контактных разъемов ISP. следующим образом;, @Rob W
@RobW: пожалуйста, [отредактируйте] свой вопрос, чтобы добавить детали, не добавляйте их в качестве комментариев, @Mat