ความล้มเหลวของ bootloader ไม่สอดคล้องกัน ATMEGA328P

Aug 19 2020

ฉันกำลังสร้างที่ชาร์จไร้สายโดยมีไมโครคอนโทรลเลอร์อยู่

ฉันได้ประกอบบอร์ด 3 ตัว หนึ่งในนั้นมีไมโครคอนโทรลเลอร์ที่ทำงานได้ดี - เบิร์น bootloader และอัปโหลดร่างโค้ดได้ดี อย่างไรก็ตามฉันมีบอร์ดอีกสองตัว - ส่วนประกอบเดียวกันที่ใช้งานไม่ได้ bootloader ล้มเหลวด้วยข้อความต่อไปนี้:

คณะแรก

     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.

สำหรับบอร์ดรุ่นหลังฉันมักจะ gen device signature 0xffffffหรือ0xfff000หรือ0x000fffหรือ0x00ff00เป็นต้น

สำหรับบอร์ด 1 และ 2 ฉันตรวจสอบการเชื่อมต่อด้วยตนเอง (จากพิน QFN ไปยัง Arduino ISP) โดยใช้มัลติมิเตอร์ แรงดันไฟฟ้าก็โอเคเช่นกัน - บอร์ดได้รับ 3v3 ปกติ

สิ่งเดียวที่ฉันกลัวคือการเผาชิปในขณะที่บัดกรี ฉันใช้ลวดบัดกรี 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

ในท้ายที่สุดนี่คือปัญหาการบัดกรี ฉันไม่เคารพข้อควรระวังหลายประการในการออกแบบบอร์ด

ตัวอย่างเช่นฉันใช้ vias ในแผ่นอิเล็กโทรดแบบสั้นอยู่แล้วและสิ่งนี้จะเพิ่มความตึงผิวเผินของตัวประสานของเหลวจึงไม่อนุญาตให้จับกับทองแดง