Непоследовательный сбой загрузчика ATMEGA328P

Aug 19 2020

Я создаю беспроводное зарядное устройство с микроконтроллером на нем.

Собрал 3 доски. Один из них имеет микроконтроллер, который отлично работает - записывает загрузчик и выгружает скетч кода. Однако у меня есть две другие платы - те же компоненты, которые не работают. Загрузчик выдает следующие сообщения:

Первая доска

     System wide configuration file is "/home/bem22/tools/arduino-1.8.10/hardware/tools/avr/etc/avrdude.conf"
     User configuration file is "/home/bem22/.avrduderc"
     User configuration file does not exist or is not a regular file, skipping

     Using Port                    : /dev/ttyUSB0
     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.02s

avrdude: Device signature = 0x000000 (retrying)

Reading | ################################################## | 100% 0.02s

avrdude: Device signature = 0x000000 (retrying)

Error while burning bootloader.
Reading | ################################################## | 100% 0.02s

avrdude: Device signature = 0x000000
avrdude: Yikes!  Invalid device signature.
         Double check connections and try again, or use -F to override
         this check.


avrdude done.  Thank you.

Вторая доска

         System wide configuration file is "/home/bem22/tools/arduino-1.8.10/hardware/tools/avr/etc/avrdude.conf"
         User configuration file is "/home/bem22/.avrduderc"
         User configuration file does not exist or is not a regular file, skipping

         Using Port                    : /dev/ttyUSB0
         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

Error while burning bootloader.
Reading | ################################################## | 100% 0.02s

avrdude: Device signature = 0xff007f
avrdude: Expected signature for ATmega328P is 1E 95 0F
         Double check chip, or use -F to override this check.

avrdude done.  Thank you.

Для последующего правления я часто ген device signature 0xffffff или 0xfff000 или 0x000fff или 0x00ff00 и т.д.

Для плат 1 и 2 я проверил соединения вручную (от вывода QFN до Arduino ISP) с помощью мультиметра. Напряжения тоже нормальные - на плате нормальный 3в3.

Единственное опасение для меня - обжечь микросхемы при пайке. Я использовал паяльную проволоку 60/40 и паяльную станцию ​​на 300 градусов. Это слишком высоко? Время контакта было относительно небольшим (менее 5 секунд).

Вот несколько изображений с моей настройкой: [! [Введите описание изображения здесь] [1]] [1] [! [Введите описание изображения здесь] [2]] [2]

А вот моя схема: [! [Введите описание изображения здесь] [3]] [3]

Есть подсказки, почему? [1]:https://i.stack.imgur.com/pUEs3.jpg [2]: https://i.stack.imgur.com/R9LLc.jpg [3]: https://i.stack.imgur.com/F832p.png

Ответы

bem22 Sep 19 2020 at 17:49

В конце концов, это была проблема с пайкой. При разработке платы я не соблюдал некоторые меры предосторожности.

Например, я использовал переходные отверстия в уже коротких контактных площадках, и это увеличило бы поверхностное натяжение жидкого припоя, не позволяя ему связываться с медью.