电子元件及其用于屏蔽指令执行或数据处理的方法

文档序号:6419201阅读:549来源:国知局
专利名称:电子元件及其用于屏蔽指令执行或数据处理的方法
技术领域
本发明涉及电子元件及其用于屏蔽指令执行或数据处理的方法。
具体地说,本发明涉及的电子元件用于业务存取或数据存取受到严格控制的应用领域。这类电子元件形成的是围绕微处理器和存储器的体系结构,它们执行的算法使用的是存储在元件中的秘密数据,而这些数据外部不能得到。这样,一个秘密数据就可以用于完成有效的电子事务处理,例如进行购物,在任何时间该数据都不会在元件外部得到。
但是,在某些情况下,通过在外部观察某些参数,例如与外部系统交换的数据或元件的电源接线端消耗的电流,根据统计处理就可以检索与该元件有关的信息。特别是,通过根据时间观察数据总线上传播的信息(数据总线通常是一组总线),就可以获得在这些信息和该元件中所用的算法处理之间的相关性。
也可以通过观察电流随时间的功耗情况得到所说信息的相关性。这样就可以推出一个指令中处理的比特值。人们知道,在给定时间内一个特定指令消耗的电流根据处理的比特值“0”或“1”而变化。
本发明的目的在于屏蔽元件中的指令执行和数据处理的方法,以便不能观察电子元件的外部参数。
根据本发明,考虑随机地中断电子元件执行的主程序,从而执行一个辅助程序。由此,随时改变了程序的执行。从外部看起来,不再可能进行统计处理,这是因为记录的曲线暂时随机地全部偏离了。如果观察到了数据交换的例子,则不论外部如何控制,由卡对任何外部命令的响应时间随时都会发生变化,从而不再能够推断出任何相关信息。
对于观察电流消耗来讲,这种随时间消耗的电流自身截断,而且使电流消耗偏离正常的电流消耗曲线,也就不能得到任何相关信息。
这样,作为体现这种特征的本发明涉及的电子元件包括至少一个微处理器和存储设备,以便执行主要程序。
根据本发明,该元件还包括一个随机数值计算器,该计算器的输出产生一个结束计算信息信号作为输出,以便在要求由微处理器执行一个辅助程序时暂停所述主要程序的执行。
在本发明的一个实施方案中,该辅助程序的执行持续时间是恒定的。在本发明的另一个实施方案中,该执行持续时间是变化的,而且该执行持续时间甚至是随机的。
在一个改进的实施方案中,使该辅助程序启动电流消耗设备,所述电流消耗设备使元件的电流消耗曲线变形,这样也就更加有效屏蔽了所进行的操作和受控数据。
本发明还涉及屏蔽电子元件中的指令执行或数据处理的方法。
通过下面结合附图对示意性的非限定例子的说明将会详细了解本发明的其它特征和优点,其中

图1是本发明电子元件的方框图;和图2是本发明另一实施例电子元件的另一方框图。
图1示出的是本发明电子元件CI的简单方框图。该电子元件包括一个微处理器1和与数据主线6相连的内源。所述内源主要包括一些存储器,一个计算器4和一个随机数值R的发生器5,在该实施例中所述存储器是一个程序存储器2和一个工作存储器3。
电子元件CI包括不同的外部连接端子。在该实施例中,是一组数据的输入/输出元件,因此具有一个数据输入/输出端子I/O。它还包括一个接地端子Vss,一个电源端子Vcc,和一些与控制信号相关的端子(未示出)。
微处理器在输入/输出接口8处接收指令和数据,该接口连接到与外部系统相关的数据输入/输出端子上。
微处理器内产生不同的控制信号,以便管理不同的内源。
在这些控制信号中,示出了计算器4的一个有效信号EN,计算器的一个起始信号LOAD和随机发生器5的一个激发信号SEL。
当计算器运行时(处于工作状态),该计算器产生一个计算结束信号ITO。该计算结束信息信号用作切断微处理器的信号。这样,该信号连接到微处理器的断路器7的输入。应注意的是,计算结束表示的是一种一般表达式,意思是计算器结束直到一个确定数值,或者是指从确定数值计算器结束向下计算到零。
应注意的是,在所示的具体实施例中,计算器是一个硬件。
微处理器1执行存储程序中的主程序,该程序与输入/输出接口8接收的指令或数据有关,而这些数据又与外部系统有关。
根据本发明,主程序的执行随时都会被屏蔽,并同时执行存储程序中的辅助程序。
为此,在开始主程序时,使计算器初始化运行时带有一个新的随机数值。实际上,该运行包括使计算器无效(EN处于不工作状态)的指令,先取出随机发生器5中的随机数值R,然后将该数值加到(LOAD)计算器中,最后启动计算器(EN处于工作状态)。
当计算器减到零时,该计算器就激励计算结束的信息信号ITO,这就切断微处理器的运行。当执行(由微处理器执行)辅助程序时,就屏蔽主程序。辅助程序对应于所考虑的切断管理运行。
辅助程序至少包括上述已经用于使计算器初始化到一个新随机数值的序列,以便能够产生一个新的切断。
该辅助程序可以对应于一个固定指令数值,在这种情况下,定时执行辅助程序。例如,如果辅助程序只有取出发生器5的新随机数值R和将该新随机数值R装入计算器4中(初始化)的指令,则定时地执行辅助程序。
在这种情况下,除了执行主程序外,同时还定期随机地进行若干编码(对应于辅助程序)。
在本发明的一个变型中,可以使辅助程序的执行持续时间发生变化。
在第一个实施例中,辅助程序在一个二元数据上进行试验,该数据每次做完程序就要修改,然后使执行的指令数成随试验结果而变化。也可以使可变执行持续时间依赖随数学函数,例如,假定该数学函数需要多次计算才能求得结果,则执行持续时间根据数学函数进行变化。所有这些求得一个可变持续时间的技术都是公知的。
在另一个实施例中,使该可变执行持续时间随机发生变化。在该实施例中,使辅助程序包括禁止该计算器,即先取出一个新的随机数值,再在反向计数回路中进行反向计数使该数值到达零,然后再用一个新的随机数值对计算器初始化。
在该变型中,将不定时进行的编码不定时地引入执行的主程序中。
实际上,本发明可以有多种变换。
特别是在主程序的执行持续时间减少不是很多的情况下,可以在当时就限制因执行辅助程序引起的总的延迟时间。
在本发明的另一个实施方案中,不仅随机瞬间地暂停主程序的执行,而且还消耗附加电流,该附加电流会“扰乱”执行主程序时的电流消耗。
这种附加电流的消耗可以是瞬间地由辅助程序中的指令引起的。例如,可以在该辅助程序中用一种算法进行多次计算,所述算法例如是加密算法。
所执行的这种运算是相应瞬间的电流消耗,也就是指执行指令的时间,由于该瞬间的电流消耗加入到了正常电流消耗中,所以就会扰乱主程序的正常消耗,主程序的正常消耗是由于执行主程序而随时间变化的。
也可以在某一段时间内增加电流的消耗,以便具有持久的作用。因此,辅助程序起动电流消耗设备,当执行辅助程序及主程序以后的指令时,该电流消耗设备至少在某一段时间消耗电流。
图2示出的是本发明该第二实施方式的电子元件的方框图。
除了上面已经描述过的那些标号与图1相同的元件以外,电子元件还有一个充电泵9。
该充电泵主要用于产生高压Vpp,该高压用于根据电源电压Vcc进行编程和清零,以便能够对一个电子编程存储器和/或电子清零存储器中的数据进行编程和/或清零,所述存储器例如通常称作EPROM,EEPROM,还有flash EPROM存储器的存储器。在本发明中,该充电泵与编程存储器相连。
在该实施例中,该泵由编程存储器的读出信号WE起动。
这种泵的特征为公知特征,它在输出产生高压期间和在编程或清零期间(几个毫秒)消耗大量电流。通过起动该泵,也就是说通过在辅助程序中提供编程指令,就会增加一个相当大的电流消耗,由此就会屏蔽辅助程序及主程序以后的指令。
本发明并不限于上述实施方案或变形型。本发明包括所有用于在某一固定时间、变化或随机时间内暂停地屏蔽主程序的设备,有或没有使用增加辅助电流消耗的设备均可以。
通过使用本发明上述任何一种变型或这些变型的组合进行屏蔽或干扰,就不可能出现任何统计处理。
实际上,选择这种或那种辅助程序可以取决于电子元件的用途。
本发明可应用到所有包括至少一个计算器和一个随机发生器的电子元件。对于给定的电子元件来讲,选择这种或那种辅助程序取决于所考虑的元件的来源以及与所要进行的用途相关的功能。
也可以使用与其它程序混合的不同辅助程序,为了改善干扰的效果,则在开始切断时就选择所要执行的辅助程序。
这种电子元件特别适用于智能卡,以便改善它们的不可侵犯性。
权利要求
1.一种电子元件,它包括至少一个用于执行主程序的微处理器(1)和存储设备(2,3),其特征在于该元件还包括一个计算随机数值(R)的计算器(4),所述计算器产生一个计算结束的信息信号(ITO)作为输出,以便当微处理器执行一个辅助程序时,暂停所述主要程序的执行。
2.根据权利要求1所述的电子元件,其特征在于该辅助程序的执行持续时间是恒定的。
3.根据权利要求1所述的电子元件,其特征在于该辅助程序的执行持续时间是变化的。
4.根据权利要求3所述的电子元件,其特征在于该辅助程序的执行持续时间是随机的。
5.根据上述任一权利要求所述的电子元件,其特征在于它还包括由辅助程序启动的电流消耗设备。
6.根据权利要求5所述的电子元件,其特征在于所述电流消耗设备包括一个充电泵(9)。
7.根据权利要求5或6所述的电子元件,其特征在于所述电流消耗设备具有产生电流瞬时消耗的指令。
8.一种用于屏蔽电子元件(CI)中的操作执行和数据处理的方法,该电子元件包括一个用于执行主程序的微处理器(1)和存储设备(2,3),其特征在于使用产生一个随机数值(R)的发生器(5)和一个计算器(4),以便当请求执行一个辅助程序时,随机瞬间地暂停所述主要程序的执行。
9.根据权利要求8所述的方法,其特征在于所述辅助程序在于使计算器(4)不起动,取出一个新的随机数值(R),用该新数值使计算器(4)初始化,在重新执行主要程序前进行反向计数。
10.根据权利要求8所述的方法,其特征在于随机地执行所述辅助程序。
11.根据权利要求10所述的方法,其特征在于辅助程序使计算器(4)不起动,取出一个新的随机数值(R),在辅助程序回路中进行反向计数使该新数值到达零,然后再取另一个新的随机数值(R)对计算器初始化到所说另一新值,在重新执行主要程序前起动计算器。
12.根据权利要求8至11之一所述的方法,其特征在于所述辅助程序还起动电流消耗设备。
13.根据权利要求12所述的方法,其特征在于电流消耗设备包括一个充电泵(9)。
14.根据权利要求12或13所述的方法,其特征在于所述电流消耗设备具有产生电流瞬时消耗的指令。
15.根据权利要求8至14之一所述的方法,其特征在于它包括不同的辅助程序。
全文摘要
本发明涉及一种电子元件(CI),它包括一个用于执行主要程序的微处理器(1)和存储设备(2,3)。一个随机数值(R)的发生器(4)的输出产生一个计算结束的信息信号(ITO),以便当执行一个辅助程序时,暂停所述主要程序的执行。本发明适用于智能卡。
文档编号G06F21/55GK1332860SQ99812249
公开日2002年1月23日 申请日期1999年10月15日 优先权日1998年10月16日
发明者P·安圭塔, D·纳卡彻 申请人:格姆普拉斯公司
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1