Inkonsistenter Bootloader-Fehler ATMEGA328P

Aug 19 2020

Ich erstelle ein drahtloses Ladegerät mit einem Mikrocontroller darauf.

Ich habe 3 Bretter zusammengebaut. Einer von ihnen hat einen Mikrocontroller, der gut funktioniert - brennt den Bootloader und lädt die Codeskizze gut hoch. Ich habe jedoch zwei andere Boards - gleiche Komponenten, die nicht funktionieren. Der Bootloader schlägt mit den folgenden Meldungen fehl:

Erstes Brett

     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.

Zweiter Vorstand

         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.

Für das spätere Board generiere ich oft device signature 0xffffff oder 0xfff000 oder 0x000fff oder 0x00ff00 etc.

Für Board 1 und 2 habe ich die Verbindungen manuell (vom QFN-Pin zum Arduino ISP) mit einem Multimeter überprüft. Die Spannungen sind auch ok - das Board bekommt normales 3v3.

Die einzige Angst für mich ist, die Chips beim Löten verbrannt zu haben. Ich habe 60/40 Lötdraht und Lötstation bei 300 Grad verwendet. Ist das zu hoch? Die Kontaktzeit war relativ gering (unter 5 Sekunden).

Hier sind einige Bilder mit meinem Setup: [![hier Bildbeschreibung eingeben][1]][1] [![hier Bildbeschreibung eingeben][2]][2]

Und hier ist mein Schema: [![hier Bildbeschreibung eingeben][3]][3]

Irgendwelche Hinweise warum? [1]:https://i.stack.imgur.com/pUEs3.jpg[2]:https://i.stack.imgur.com/R9LLc.jpg[3]:https://i.stack.imgur.com/F832p.png

Antworten

bem22 Sep 19 2020 at 17:49

Am Ende war dies ein Lötproblem. Ich habe beim Entwerfen des Boards mehrere Vorsichtsmaßnahmen nicht beachtet.

Zum Beispiel habe ich Vias in den ohnehin kurzen Pads verwendet, was die Oberflächenspannung des flüssigen Lots erhöhen würde, wodurch es nicht an Kupfer binden könnte.