源程序
/************ 相关说明 *****************/
//主单片机AVCC接VCC,利用AREF引脚控制锁死的单片机的VCC(5V电源电压能达到4.9V);
//主单片机的I/0寄存器ADMUX 控制AREF与AVCC的开关;
//三级管(9014)B极电阻100K,C极电阻1K,E极接GND(12.2V电源电压,能达到11.9V)
//锁死的单片机的RESET与VCC必须几乎同时加电压,不能有明显时间差;
//主单片机的熔丝位:禁用JTAG(因使用PORTC);1M内部时钟;
/************ C 源程序 ********************/
//Chip: ATmega16
//char is unsigned: Yes
//CodeVision AVR
#include <mega16.h>
#include <delay.h>
//引脚定义
#define DATA PORTA //锁死芯片的PORTB
#define RDY_BSY PINC.4 //锁死芯片的PD1
#define _OE PORTC.3 //锁死芯片的PD2始终为1
#define _WR PORTC.2 //锁死芯片的PD3
#define BS1 PORTC.1 //锁死芯片的PD4
#define XA0 PORTC.0 //锁死芯片的PD5
#define XA1 PORTD.7 //锁死芯片的PD6
#define PAGEL PORTD.6 //锁死芯片的PD7
#define BS2 PORTB.0 //锁死芯片的PA0
#define RST PORTD.2 //9014的B极电阻
#define XTAL1 PORTC.6 //XTAL1
#define LED PORTB.1 //LED
#define DDR_LED DDRB.1 //
#define VCC_ON ADMUX=0x40 //锁死芯片的VCC
#define VCC_OFF ADMUX=0x00
//进入编程状态
#define PROG_ENABLE BS1=0;XA0=0;XA1=0;PAGEL=0;
//初始化
void initial(void)
{
DDRB=0xFF;
DDRC=0xFF;DDRC.4=0;PORTC.4=1;
DDRD=0xFF;
DDRA=0xFF;
_OE=1;
_WR=1;
XA0=1;
XA1=1;
PAGEL=0;
BS2=0;
BS1=0;
RST=1;
XTAL1=0;
LED=0;
VCC_OFF;
DATA=0x00;
}
//芯片擦除
void chip_erase(void)
{
XA1=1;XA0=0;
BS1=0;
DATA=0x80;
XTAL1=1;XTAL1=0;
_WR=0;_WR=1;
while(RDY_BSY==0);
}
//重写熔丝位
void write_fuse(char LB,char HB)
{
XA1=1;XA0=0;
BS1=0;
DATA=0x40;
XTAL1=1;XTAL1=0;
XA1=0;XA0=1;
DATA=LB; //熔丝低位
XTAL1=1;XTAL1=0;
BS1=0;BS2=0;
_WR=0;_WR=1;
while(RDY_BSY==0);
XA1=1;XA0=0;
BS1=0;
DATA=0x40;
XTAL1=1;XTAL1=0;
XA1=0;XA0=1;
DATA=HB; //熔丝高位
XTAL1=1;XTAL1=0;
BS1=1;BS2=0;
_WR=0;_WR=1;
while(RDY_BSY==0);
}
//高压恢复
void recover_fuse(void)
{
PROG_ENABLE;
RST=0,VCC_ON; //最关键的时序问题
chip_erase(); //擦除
write_fuse(0xE1,0x19); //恢复熔丝为默认(也可自己设定为其他值)
}
//结束状态
void finish(void)
{
DDRB=0x00;PORTB=0x00;
DDRC=0x00;PORTC=0x00;
DDRD=0x00;PORTD=0x00;
DDRA=0x00;PORTA=0x00;
DDR_LED=1;LED=1;
VCC_OFF;
}
void main(void)
{
initial();
delay_ms(200);
recover_fuse();
finish();
}
下面是我做的实物并且解锁成功
非常成功的恢复了熔丝位
|