datasheet

MSP430自毁功能设计

2018-07-11来源: eefocus 关键字:MSP430  自毁功能

了知识产权的保护,或其它一些目的,为了保护单片机中的软件不能被读出,可以选择具有加密功能的单片机,保护代码不被非法读取。由于MSP430可以进行FLASH自编程,当然就可以进行可升级的程序设计,以后可以通过串行口或者其它方式进行固件的升级。

用MSP430设计的硬件可能与计算机上运行的上位机程序协作完成一定功能,这样就可以在MSP430与软件之间建立一定的协议进行软件和硬件的保护,比如硬件的序列号,或软件的序列号,当软件发现硬件的序列号不正确时而不继续执行,当硬件发现使用的是非却破解版的控制程序,就可以进行自毁,自动销毁内部所有的程序,使得单片机程序被清空而不能使用。

进行自毁还可以产生硬件的损坏,如地求板上提供12V或更高的电压,通过一定的检测电路检测是否满足,不满足要求,程序则不继续执行,当需要自毁时把12V的电压直接加到3.3V或5V的器件上去进行硬件销毁。但这在一定程度上造成了危险性,如果设计不善可能会引发火灾,并推荐使用。

下面只说MSP430实现程序自毁。

方案1:通过全部擦除FLASH的指令擦除全部FLASH内容,但当前的程序正在使用FLASH,使得该指令不能够有效执行,这些操作在程序中不能完成。

方案2:将FLASH中擦除操作代码复制到RAM中,因为MSP430是冯氏结构,RAM与FLASH为同一地址空间,而程序中擦除代码用到的在RAM中的变量所使用的RAM只要不被覆盖,程序应该能够在RAM中执行,而且代码中不能有跳转指令,因为这些指令在编译成机器码时跳转的地址已经确定,使用这些指令就会使使程序跑飞,而会用访问FLASH,这样也会导致擦除操作失败。在开始擦除操作后还不能退出RAM进入到FASH,这样一访问FLASH也会导致擦除操作失败。

通过试验方案2并没有成功,可能复制到RAM后又跳转到了FLASH中造成操作失败,需要修改代码进一步试验。

方案3:擦除除擦除操作代码外的所有程序。这样也只留下很小一部分不重要的代码,实现代码保护的目的可以达到。

首先找到当前代码段所在的位置,通过块擦除操作擦除除当前代码所在块的所有程序;然后擦除该块中当前代码面前、后代码,这些操作不能通过擦除操作,但可以通过字节或字写入操作,因为写操作只能把1写成0,干脆直接全写成0,这样就可以仅剩下擦除操作的一小段代码,为了停止操作失败,在操作等待时做一无限循环,不要跑到其它位置的FLASH,以防碍扣除操作。

该方法已经取得成功。


关键字:MSP430  自毁功能

编辑:什么鱼 引用地址:http://www.eeworld.com.cn/mcu/2018/ic-news071140247.html
本网站转载的所有的文章、图片、音频视频文件等资料的版权归版权所有人所有,本站采用的非本站原创文章及图片等内容无法一一联系确认版权者。如果本网所选内容的文章作者及编辑认为其作品不宜公开自由传播,或不应无偿使用,请及时通过电子邮件或电话通知我们,以迅速采取适当措施,避免给双方造成不必要的经济损失。

上一篇:MSP430G2553 WDT的看门狗模式例子
下一篇:MSP430F149单片机实现uart数据接收中断

关注eeworld公众号 快捷获取更多信息
关注eeworld公众号
快捷获取更多信息
关注eeworld服务号 享受更多官方福利
关注eeworld服务号
享受更多官方福利

推荐阅读

MSP430单片机低功耗结构原理

当系统时钟发生器基本功能建立之后,CPU内状态寄存器SR的SCG1,SCG0,CPUOFF,OSCOFF位是重要的低功耗控制位。只要任意中断被响应,上述控制位就被压入堆栈保存,中断处理之后,又可恢复先前的工作方式。在中断处理子程序执行期间,通过间接访问堆栈数据,可以操作这些控制位;这样允许程序在中断返回(RETI) 后,以另一种功耗方式继续运行。各控制位的作用如下:SCG1: 复位,使能SMCLK;置位,禁止SMCLK。SCG0: 复位,激活直流发生器,只有SCG0置位,并且DCOCLK没有被用作MCLK或SMCLK时,直流发生器才能被禁止。OSCOFF:复位,激活LFXT1,只有当OSCOFF被置位并且LFXT1CLK不用于MCL
发表于 2018-11-21

基于MSP430F5529的金属循迹小车

Normal_speed  3500#define Turn_S_speed  3500#define Turn_B_speed  2500void initalRTC(void){    RTCCTL01 = RTCMODE + RTCBCD + RTCHOLD + RTCTEV_1;    RTCHOUR = 0x04;    RTCMIN = 0x30;    RTCSEC = 0x00;    RTCDAY
发表于 2018-10-17

MSP430F5529液晶SPI通信协议

;{           p1[b]=y+0x30;           y/=10;           b++;      }    }    else 
发表于 2018-10-17

msp430f5419/38学习笔记之USCI:UART模式

   msp430f541x、msp430f543x多达4个通用串行通信接口(USCI)模块,支持多种串行通信模式,不同的 USCI 模块支持不同的模式。  USCI_Ax模块支持:UART模式;IrDA通信的脉冲整形;LIN通信的自动波特率检测;SPI模式;  USCI_Bx模块支持:IIC模式;SPI模式;UART模式:    在异步模式下,USCI_Ax模块通过两个外部引脚UCAxRXD和UCAxTXD将芯片连接到外部系统。当UCSYNC位清零时,选择UART模式。  UART模块特征包括
发表于 2018-10-15
msp430f5419/38学习笔记之USCI:UART模式

msp430f5419/38学习笔记之时钟系统

),DCOCLK = 2*DCOCLKDIV = 2.097152MHz。    默认选择了使用 XT1的 FLL操作,为了启用 XT1功能,必须将与 XT1引脚对应的 PSEL置位。当 XT1CLK 使用 32768Hz 晶振时,由于XT1不会立即稳定,失效逻辑控制位会立即选择 REFOCLK 作为 ACLK 时钟源。一旦晶体振荡稳定后,由于 FLL的作用,MCLK 和SMCLK 都将稳定在 1.047586MHz,Fdco稳定在 2.097152MHz。    状态寄存器(SCG0,SCG1,OSCOFF和CPUOFF)用于配置 MSP430的工作模式,使能和禁止
发表于 2018-10-15
msp430f5419/38学习笔记之时钟系统

MSP430F5438A单片机基于SPI的FatFs移植笔记

省事只用了成功、读写错误、参数错误三个,原因是写保护我没有编写专门的函数去判断,而未准备好出现的概率很低。各个函数的输入参数具体到每个函数再进行一一说明那么下面首先以初始化程序DSTATUS disk_initialize (BYTE pdrv);具体说一下:通过TI的单片机MSP430F5438A进行函数的实现步骤这里需要参考的良心文档以及网站有:1. FatFs官方网站:http://www.elm-chan.org/fsw/ff/00index_e.html说明很浅显,优点是易懂缺点是靠他说的那点儿说明实现简直不可能2. 一个叫Tilen Majerle的老外的网站,基于STM32系列单片机开发的FatFs:http
发表于 2018-09-19

小广播

何立民专栏

单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号 电信业务审批[2006]字第258号函 京公海网安备110108001534 Copyright © 2005-2018 EEWORLD.com.cn, Inc. All rights reserved
pt type="text/javascript" src="//v3.jiathis.com/code/jia.js?uid=2113614" charset="utf-8">