Kegagalan bootloader yang tidak konsisten ATMEGA328P
Saya membuat pengisi daya nirkabel dengan mikrokontroler di atasnya.
Saya telah mengumpulkan 3 papan. Salah satunya memiliki mikrokontroler yang berfungsi dengan baik - membakar bootloader dan mengunggah sketsa kode dengan baik. Namun, saya memiliki dua papan lain - komponen yang sama yang tidak berfungsi. Bootloader gagal dengan pesan berikut:
Papan Pertama
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.
Papan Kedua
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.
Untuk papan selanjutnya saya sering gen device signature
0xffffff atau 0xfff000 atau 0x000fff atau 0x00ff00 dll.
Untuk board 1 dan 2 saya cek koneksinya secara manual (dari pin QFN ke Arduino ISP) menggunakan multimeter. Tegangannya juga ok - board menjadi 3v3 normal.
Satu-satunya ketakutan bagi saya adalah membakar keripik saat menyolder. Saya menggunakan kawat solder 60/40 dan stasiun solder pada 300 derajat. Apakah ini terlalu tinggi? Waktu kontak relatif rendah (di bawah 5 detik).
Berikut adalah beberapa gambar dengan setup saya: [! [Masukkan deskripsi gambar di sini] [1]] [1] [! [Masukkan deskripsi gambar di sini] [2]] [2]
Dan inilah skema saya: [! [Masukkan deskripsi gambar di sini] [3]] [3]
Ada petunjuk kenapa? [1]:https://i.stack.imgur.com/pUEs3.jpg [2]: https://i.stack.imgur.com/R9LLc.jpg [3]: https://i.stack.imgur.com/F832p.png
Jawaban
Pada akhirnya, ini adalah masalah penyolderan. Saya tidak menghormati beberapa tindakan pencegahan saat mendesain papan.
Misalnya, saya menggunakan vias di bantalan yang sudah pendek dan ini akan meningkatkan tegangan superfisial dari solder cair, sehingga tidak memungkinkannya untuk mengikat ke tembaga.