Проблемы с загрузкой с новым 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 по одной для записи флэш-памяти, и эй! это работает! (см. Ниже) Windows command interpreter - avrdude session

Итак, если это работает, почему ArduinoISP не загружает загрузчик? Я настрою это как еще один / новый вопрос

, 👍2

Обсуждение

Что, если вообще что-либо, вы сделали с сигналом сброса на nano, который запускает скетч arduino sp.ino?, @timemage

Не могли бы вы показать, как вы соединили оба Nano?, @StarCat

Я подключил два nanos с помощью 6-контактных разъемов ISP. следующим образом;, @Rob W

@RobW: пожалуйста, [отредактируйте] свой вопрос, чтобы добавить детали, не добавляйте их в качестве комментариев, @Mat


3 ответа


Лучший ответ:

0

Теперь я исправил эту проблему, но до сих пор не до конца понимаю, в чем была первоначальная проблема.

Пожалуйста, посмотрите мой другой пост на этом qusetion, чтобы увидеть, что я сделал Ссылка на другой пост

,

0

Возможно, это не ответ на проблему загрузчика, но недавно я прошел через то же самое, я немного поздно понял, в чем именно проблема, поэтому я проверил 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


0

В Nano есть более одного загрузчика, новый и старый. У меня была такая же проблема, поэтому я просто перешел к инструментам в IDE и переключился с нового на старый, это решило мои проблемы.

,

Спасибо, Гил, это одна из первых вещей, которые я попробовал - безуспешно., @Rob W

Извините, у меня закончились идеи. Я надеюсь, что кто-нибудь сможет вам помочь., @Gil