CN104391770B - 一种嵌入式数据安全系统用soc芯片的在线调试及上位机通讯模块 - Google Patents

一种嵌入式数据安全系统用soc芯片的在线调试及上位机通讯模块 Download PDF

Info

Publication number
CN104391770B
CN104391770B CN201410569042.7A CN201410569042A CN104391770B CN 104391770 B CN104391770 B CN 104391770B CN 201410569042 A CN201410569042 A CN 201410569042A CN 104391770 B CN104391770 B CN 104391770B
Authority
CN
China
Prior art keywords
bus
signal
chip
data
machine communication
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Fee Related
Application number
CN201410569042.7A
Other languages
English (en)
Other versions
CN104391770A (zh
Inventor
刘振宇
杨雪莹
杜青阳
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
SHANDONG WEIGU INFORMATION TECHNOLOGY Co Ltd
Original Assignee
SHANDONG WEIGU INFORMATION TECHNOLOGY Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by SHANDONG WEIGU INFORMATION TECHNOLOGY Co Ltd filed Critical SHANDONG WEIGU INFORMATION TECHNOLOGY Co Ltd
Priority to CN201410569042.7A priority Critical patent/CN104391770B/zh
Publication of CN104391770A publication Critical patent/CN104391770A/zh
Application granted granted Critical
Publication of CN104391770B publication Critical patent/CN104391770B/zh
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Landscapes

  • Storage Device Security (AREA)

Abstract

本发明涉及一种嵌入式数据安全系统用SOC芯片的在线调试及上位机通讯模块,其具有如下优点:本发明只需通过一条USB电缆,而无需其它外置设备,就可在主机和数据安全系统间建立数据通道,该通道既可以做“调试通道”,又可以做“通讯通路”。这种设计可以降低系统的复杂度、节省系统的成本、提高系统的可靠性。

Description

一种嵌入式数据安全系统用SOC芯片的在线调试及上位机通 讯模块
技术领域
本发明涉及一种SOC芯片,具体地说,涉及一种嵌入式数据安全系统用SOC芯片的在线调试及上位机通讯模块,属于电子技术领域。
背景技术
SOC即System On Chip的缩写,指的是片上系统芯片,也称作芯片级系统。SOC是属于专用集成电路范畴,其内部包含多种功能部件或模块,具有完整系统的功能,有的还可嵌入软件的功能。SOC技术的应用和发展,有助于电子设备减小体积重量、降低功耗、提高可靠性、降低系统成本。
随着现代社会信息化程度的不断提高,所有信息均可转变成了计算机所能识别的数据。数据可复制和易传输的特性为人们的生活和工作提供了巨大的便利。然而,数据的这种可复制和易传输特性也为信息泄露大开方便之门,给信息的安全性带来了空前的挑战。为了给信息传输提供安全保障,就需要用到数据安全系统。数据安全系统一般由软件和硬件两大部分构成。现有的数据安全系统硬件一般包含处理器芯片(如单片机)、数据存储器芯片、程序存储器芯片、密钥存储器芯片、接口电路芯片、电源电路芯片、时钟芯片、复位芯片等多个分立的部分组成,如图1所示,其中处理器芯片负责整个数据安全系统的任务调度管理等工作,数据存储器芯片为处理器芯片提供程序运行的空间,程序存储器芯片用来存储数据安全系统的程序,密钥存储器芯片用来存储系统密钥,接口电路芯片用来提供数据安全系统与上位机的接口,电源电路芯片为整个数据安全系统提供电源,时钟芯片为数据安全系统提供驱动时钟信号,复位芯片为数据安全系统提供复位信号。
对传统的数据安全系统来说,若要实现主机对数据安全系统的调试操作,需要通过一个外置的设备——仿真器(也可以叫模拟器),才能在主机和数据安全系统间建立“调试通路”;若要实现主机与数据安全系统的正常数据通讯,则需要在主机和数据安全系统间建立单独的“通讯通路”。
发明内容
本发明要解决的问题是针对以上不足,提供一种嵌入式数据安全系统用SOC芯片的在线调试及上位机通讯模块,降低了系统的复杂度、节省了系统的成本、提高了系统的可靠性。
为解决上述问题,本发明采用以下技术方案:
一种嵌入式数据安全系统用SOC芯片的在线调试及上位机通讯模块,其特征在于:所述在线调试及上位机通讯模块有两种工作模式:在线调试模式、上位机通讯模式;
在线调试模式下,上位机可以访问SOC芯片内部资源,也可以调试用户程序和烧写片内程序存储器ROM;
在上位机通讯模式下,可以实现SOC芯片与上位机的数据交互。
所述SOC芯片的外部设有引脚信号DEBUG_MODE,通过该引脚的电平设置可以实现对在线调试及上位机通讯模块工作模式的选择。
所述当DEBUG_MODE为高电平时,在线调试及上位机通讯模块处于在线调试模式;当DEBUG_MODE为低电平时,在线调试及上位机通讯模块处于上位机通讯模式。
所述在线调试及上位机通讯模块是片内总线上的一个主设备,其采用主设备总线接口同片内总线相连。
所述在线调试及上位机通讯模块通过互联总线连接有密钥存储器,密钥存储器包含NOR FLASH存储器和从设备总线接口,其中,NOR FLASH存储器用于存放用户密钥,从设备总线接口用于将密钥存储器同片内总线相连以实现数据和命令的交换。
所述主设备总线接口信号的类型以及数量与其它主设备的主设备总线接口信号相同,具体包括主设备地址信号输出m_addr_out[31:0]、主设备数据输入信号m_dada_in[31:0]、主设备数据信号输出m_data_out[31:0]、主设备选通输出信号m_sel_out、主设备写有效输出信号m_wr_out、主设备读有效输出信号m_rd_out、主设备应答输入信号m_ack_in。
所述在线调试及上位机通讯模块利用m_addr_out[31:0]信号从将地址信息传递给片内总线,利用m_data_in[31:0]信号从片内总线获取数据,利用m_data_out[31:0]信号将自身数据送到片内总线,利用m_sel_out信号将选通命令传送给片内总线,利用m_wr_out信号将写操作命令传送给片内总线,利用m_rd_out信号将读操作命令传送给片内总线,利用m_ack_in信号从片内总线获取应答信号。
本发明嵌入式数据安全系统用SOC芯片的在线调试及上位机通讯模块,其具有如下优点:本发明只需通过一条USB电缆,而无需其它外置设备,就可在主机和数据安全系统间建立数据通道,该通道既可以做“调试通道”,又可以做“通讯通路”。这种设计可以降低系统的复杂度、节省系统的成本、提高系统的可靠性。
下面结合附图和实施例对本发明进行详细说明。
附图说明
附图1是现有数据安全系统的典型硬件结构图;
附图2是采用本发明提供的专用SOC芯片的嵌入式数据安全系统的典型硬件结构图;
附图3是本发明实施例中SOC芯片的结构框图;
附图4是本发明实施例中SOC芯片的片内总线主设备与片内总线的连接示意及信号图;
附图5是本发明实施例中SOC芯片的片内总线从设备与片内总线的连接示意及信号图;
附图6是本发明实施例中SOC芯片的处理器结构图;
附图7是本发明实施例中SOC芯片在线调试及上位机通讯模块结构图;
附图8 是本发明实施例中SOC芯片的程序存储器ROM结构图;
附图9 是本发明实施例中SOC芯片的数据存储器RAM结构图;
附图10 是本发明实施例中SOC芯片的随机数发生器结构图;
附图11 是本发明实施例中SOC芯片的安全算法模块结构图;
附图12 是本发明实施例中SOC芯片的密钥存储器结构图;
附图13 是本发明实施例中SOC芯片的中断控制器结构图;
附图14 是本发明实施例中SOC芯片的电源转换器结构图。
具体实施方式
实施例,如图3所示,清楚地表述了本芯片的内部架构、功能模块种类数量以及各模块连接关系。
一种嵌入式数据安全系统用SOC芯片,该芯片集成如下子模块:RISC处理器、在线调试及上位机通讯模块、总线仲裁器、程序存储器ROM、数据存储器RAM、密钥存储器、随机数发生器、安全算法模块、定时器、中断控制器、UART串行通讯接口、SPI总线控制器I2C总线控制器、GPIO接口模块、电源转换器、时钟/复位发生器。
如图3所示,本发明实施例中嵌入式数据安全系统用SOC芯片内部采用总线式结构,利用片内互联总线连接各个片内子模块。
本专利选用的片内互联总线遵循WishBone标准,片内互联总线同一时刻只能被一个主设备访问,
本专利设计了总线仲裁器来控制片内互联总线的访问。RISC处理器和在线调试及上位机通讯模块为片内互联总线上的两个主设备。
片内互联总线上的从设备有:程序存储器ROM、数据存储器RAM、密钥存储器、随机数发生器、安全算法模块、定时器、中断控制器、UART串行通讯接口、SPI总线控制器、I2C总线控制器、GPIO接口模块、电源转换器、时钟/复位发生器。从设备不能主动访问总线,只能被动响应由主设备发起的总线访问。
如图4所示,本发明实施例中嵌入式数据安全系统用SOC芯片的片内总线上连接的所有主设备与片内总线的连接信号类型和数量相同,具体包含:
(1)主设备地址输出信号m_addr_out[31:0];
(2)主设备数据输入信号m_dada_in[31:0];
(3)主设备数据输出信号m_data_out[31:0];
(4)主设备选通输出信号m_sel_out;
(5)主设备写有效输出信号m_wr_out;
(6)主设备读有效输出信号m_rd_out;
(7)主设备应答输入信号m_ack_in。
主设备利用m_addr_out[31:0]信号从将地址信息传递给片内总线,利用m_data_in[31:0]信号从片内总线获取数据,利用m_data_out[31:0]信号将自身数据送到片内总线,利用m_sel_out信号将选通命令传送给片内总线,利用m_wr_out信号将写操作命令传送给片内总线,利用m_rd_out信号将读操作命令传送给片内总线,利用m_ack_in信号从片内总线获取应答信号。
如图5所示,本发明实施例中嵌入式数据安全系统用SOC芯片的片内总线上连接的所有从设备与片内总线的连接信号类型和数量相同,具体包含:
(1)从设备地址输入信号s_addr_in[31:0];
(2)从设备数据输入信号s_dada_in[31:0];
(3)从设备数据输出信号s_data_out[31:0];
(4)从设备选通输入信号s_sel_in;
(5)从设备写有效输入信号s_wr_in;
(6)从设备读有效输入信号s_rd_in;
(7)从设备应答输出信号s_ack_out。
从设备利用s_addr_in[31:0]信号从片内总线获取地址信息,利用s_data_in[31:0]信号从片内总线获取数据,利用s_data_out[31:0]信号将自身数据送到片内总线,利用s_sel_in信号从片内总线获取选通命令,利用m_wr_in信号从片内总线获取写操作命令,利用s_rd_in信号从片内总线获取读操作命令,利用s_ack_in信号将应答信号传递给片内总线。
主设备要对某一个从设备进行写数操作,其过程如下:
第一步,主设备通过m_sel_out信号向片内总线输出选通信息、通过m_wr_out向片内总线输出写有效信息、通过m_addr_out[31:0]信号向片内总线输出目标地址信息、通过m_data_out[31:0]向片内总线输出待写入数据信息。片内总线上所有从设备都可以通过s_addr_in[31:0]信号接收到主设备的地址信息、通过s_dada_in[31:0]信号接收到主设备的数据信息。
第二步,总线仲裁器根据主设备输送到片内总线的地址信息进行译码并选中访问目标(译码规则参见表1),并只将目标从设备的s_sel_in和s_wr_in信号置成有效状态,其它从设备的s_sel_in和s_wr_in信号保持无效状态。
第三步,当目标从设备检测到自身的s_sel_in和s_wr_in信号有效时,就会从自身的s_addr_in[31:0]信号上获取目标地址,并将目标数据通过自身s_dada_out[31:0]信号传送到片内总线,并通过自身的s_ack_out向片内总线发出操作应答信息。
第四步,总线仲裁器将目标从设备的操作应答信息通过片内总线传递到发起写操作的主设备的m_ack_in信号。主设备在收到此应答信息后,即确认整个写数操作结束。
主设备要对某一个从设备进行读数操作,其过程如下:
第一步,主设备通过m_sel_out信号向片内总线输出选通信息、通过m_rd_out向片内总线输出写有效信息、通过m_addr_out[31:0]信号向片内总线输出目标地址信息。片内总线上所有从设备都可以通过s_addr_in[31:0]信号接收到主设备的地址信息。
第二步,总线仲裁器根据主设备输送到片内总线的地址信息进行译码并选中访问目标(译码规则参见表1),并只将目标从设备的s_sel_in和s_rd_in信号置成有效状态,其它从设备的s_sel_in和s_rd_in信号保持无效状态;
第三步,当目标从设备检测到自身的s_sel_in和s_rd_in信号有效时,就会从自身的s_addr_in[31:0]信号上获取目标地址,并将自身s_dada_in[31:0]信号上的数据写入自身的目标区域,然后,通过自身的s_ack_out向片内总线发出操作应答信息;
第四步,总线仲裁器将目标从设备的操作应答信息通过片内总线传递到发起写操作的主设备的m_ack_in信号。主设备在收到此应答信息后,就立即通过自身的m_dada_in[31:0]信号从片内总线获取要读取的数据,然后确认整个读数操作结束。
如图3所示,本发明实施例中嵌入式数据安全系统用SOC芯片中集成总线仲裁器,总线仲裁器根据主设备访问请求的先后顺序来裁决下一时刻片内互联总线给哪一个主设备使用。总线仲裁器根据主设备的最高7位地址信号(即m_addr_out[31:25])来译码决定被访问的目标从设备,译码规则如表1所示。
表1 总线仲裁器地址译码表
[1]:x表示既可以是1,也可以是0。
如图6所示,本发明实施例中嵌入式数据安全系统用SOC芯片内部集成处理器,处理器是整个SOC芯片的核心,其包括整型处理单元、数据缓存、指令缓存以及主设备总线接口四个组成部分。采用哈佛体系结构,配置有彼此独立数据缓存和指令缓存。整型处理单元通过数据通道同数据缓存连接,通过指令通道同指令缓存连接。这种结构可以使得处理器的数据通道与指令通道彼此分离,避免总线竞争,有助于提高数据和指令的访问效率,进而提高处理器的运算处理能力。
整型处理单元采用OpenRisc标准,OpenRisc是一种精简指令集处理器,缩写为RISC,其由OpenCores组织提供,是一种基于GPL协议的开放式的指令集,可以节省高额的授权费用,进而降低产品的成本。
如图4所示,本发明实施例中嵌入式数据安全系统用SOC芯片的RISC处理器是片内总线上的一个主设备,其采用主设备总线接口同片内总线相连,主设备总线接口信号的类型以及数量与其它主设备的主设备总线接口信号相同,
具体包括主设备地址信号输出m_addr_out[31:0]、主设备数据输入信号m_dada_in[31:0]、主设备数据信号输出m_data_out[31:0]、主设备选通输出信号m_sel_out、主设备写有效输出信号m_wr_out、主设备读有效输出信号m_rd_out、主设备应答输入信号m_ack_in。处理器利用m_addr_out[31:0]信号从将地址信息传递给片内总线,利用m_data_in[31:0]信号从片内总线获取数据,利用m_data_out[31:0]信号将自身数据送到片内总线,利用m_sel_out信号将选通命令传送给片内总线,利用m_wr_out信号将写操作命令传送给片内总线,利用m_rd_out信号将读操作命令传送给片内总线,利用m_ack_in信号从片内总线获取应答信号。
如图7所示,本发明实施例中嵌入式数据安全系统用SOC芯片内部集成在线调试及上位机通讯模块。该模块内部嵌入USB从设备接口,SOC芯片利用该模块通过USB从设备接口同上位机相连,实现通讯。在线调试及上位机通讯模块有两种工作模式:在线调试模式、上位机通讯模式。在线调试模式下,上位机可以通过USB从设备接口访问SOC芯片内部资源,如寄存器、程序存储器ROM、数据存储器RAM等,也可以调试用户程序和烧写片内程序存储器ROM。在上位机通讯模式下,在相应底层软件和上层软件的配合下,可以实现SOC芯片与上位机的数据交互,如传递加密和解密数据、更新密钥等。本发明实施例设计了一个芯片的外部引脚信号DEBUG_MODE,通过该引脚的电平设置可以实现对在线调试及上位机通讯模块工作模式的选择。如图7所示,当DEBUG_MODE为高电平时,在线调试及上位机通讯模块处于在线调试模式;当DEBUG_MODE为低电平时,在线调试及上位机通讯模块处于上位机通讯模式。
本发明实施例的在线调试及上位机通讯模块是片内总线上的一个主设备,其采用主设备总线接口同片内总线相连,主设备总线接口信号的类型以及数量与其它主设备的主设备总线接口信号相同,具体包括主设备地址信号输出m_addr_out[31:0]、主设备数据输入信号m_dada_in[31:0]、主设备数据信号输出m_data_out[31:0]、主设备选通输出信号m_sel_out、主设备写有效输出信号m_wr_out、主设备读有效输出信号m_rd_out、主设备应答输入信号m_ack_in。在线调试及上位机通讯模块利用m_addr_out[31:0]信号从将地址信息传递给片内总线,利用m_data_in[31:0]信号从片内总线获取数据,利用m_data_out[31:0]信号将自身数据送到片内总线,利用m_sel_out信号将选通命令传送给片内总线,利用m_wr_out信号将写操作命令传送给片内总线,利用m_rd_out信号将读操作命令传送给片内总线,利用m_ack_in信号从片内总线获取应答信号。
由于本发明中集成了“在线调试及上位机通讯模块”,所以只需通过一条USB电缆,而无需其它外置设备,就可在主机和数据安全系统间建立数据通道,该通道既可以做“调试通道”,又可以做“通讯通路”。这种设计可以降低系统的复杂度、节省系统的成本、提高系统的可靠性。
本发明实施例中嵌入式数据安全系统用SOC芯片内部集成程序存储器ROM。如图8所示,程序存储器ROM内部包括一块容量为2048K字节的NOR FLASH存储器和从设备总线接口。其中NOR FLASH存储器用于存储用户开发的底层应用程序,从设备总线接口用于将程序存储器ROM同片内总线相连以实现数据和命令的交换。
程序存储器ROM为片内总线的一个从设备,其通过从设备总线接口与片内总线相连接。从设备总线接口的接口信号包括从设备地址输入信号s_addr_in[31:0]、从设备数据输入信号s_dada_in[31:0]、从设备数据输出信号s_data_out[31:0]、从设备选通输入信号s_sel_in、从设备写有效输入信号s_wr_in、从设备读有效输入信号s_rd_in、从设备应答输出信号s_ack_out。程序存储器ROM利用s_addr_in[31:0]信号从片内总线获取地址信息,利用s_data_in[31:0]信号从片内总线获取数据,利用s_data_out[31:0]信号将自身数据送到片内总线,利用s_sel_in信号从片内总线获取选通命令,利用s_wr_in信号从片内总线获取写操作命令,利用s_rd_in信号从片内总线获取读操作命令,利用s_ack_in信号将应答信号传递给片内总线。
本发明实施例中嵌入式数据安全系统用SOC芯片内部集成数据存储器RAM。如图9所示,数据存储器RAM内部包括一块容量为4096K字节的同步RAM存储器和从设备总线接口。其中同步RAM存储器用于运行用户开发的底层应用程序,从设备总线接口用于将数据存储器RAM同片内总线相连以实现数据和命令的交换。
数据存储器RAM为片内总线的一个从设备,其通过从设备总线接口与片内总线相连接。从设备总线接口的接口信号包括从设备地址输入信号s_addr_in[31:0]、从设备数据输入信号s_dada_in[31:0]、从设备数据输出信号s_data_out[31:0]、从设备选通输入信号s_sel_in、从设备写有效输入信号s_wr_in、从设备读有效输入信号s_rd_in、从设备应答输出信号s_ack_out。数据存储器RAM利用s_addr_in[31:0]信号从片内总线获取地址信息,利用s_data_in[31:0]信号从片内总线获取数据,利用s_data_out[31:0]信号将自身数据送到片内总线,利用s_sel_in信号从片内总线获取选通命令,利用s_wr_in信号从片内总线获取写操作命令,利用s_rd_in信号从片内总线获取读操作命令,利用s_ack_in信号将应答信号传递给片内总线。
本发明实施例中嵌入式数据安全系统用SOC芯片内部集成随机数发生器,其产生的随机数用于参与安全算法运算。如图10所示,随机数发生器内部包括随机数发生函数SJS_GEN、随机数长度寄存器SJS_LEN_REG、随机数缓存SJS_BUF、从设备总线接口。其中随机数发生函数SJS_GEN用来产生随机数,随机数长度寄存器SJS_LEN_REG用来设定所产生的随机数的长度,随机数缓存SJS_BUF用来存储随机数,从设备总线接口用于将随机数发生器同片内总线相连以实现数据和命令的交换,随机数发生器产生的随机数的长度位于1~1024比特之间,且可以通过用户软件进行设置。本发明实施例中设计一个11比特的随机数长度寄存器SJS_LEN_REG来设置随机数的长度,产生的随机数存储在一个1024×32比特的随机数缓存SJS_BUF中,随机数缓存SJS_BUF最多可以存储32组随机数,RISC处理器可以通过片内总线访问随机数长度寄存器SJS_LEN_REG和随机数缓存SJS_BUF。
随机数发生器为片内总线的一个从设备,其通过从设备总线接口与片内总线相连接。从设备总线接口的接口信号包括从设备地址输入信号s_addr_in[31:0]、从设备数据输入信号s_dada_in[31:0]、从设备数据输出信号s_data_out[31:0]、从设备选通输入信号s_sel_in、从设备写有效输入信号s_wr_in、从设备读有效输入信号s_rd_in、从设备应答输出信号s_ack_out。随机数发生器利用s_addr_in[31:0]信号从片内总线获取地址信息,利用s_data_in[31:0]信号从片内总线获取数据,利用s_data_out[31:0]信号将自身数据送到片内总线,利用s_sel_in信号从片内总线获取选通命令,利用s_wr_in信号从片内总线获取写操作命令,利用s_rd_in信号从片内总线获取读操作命令,利用s_ack_in信号将应答信号传递给片内总线。
本发明实施例中嵌入式数据安全系统用SOC芯片内部集成安全算法模块,该模块主要用于进行安全算法运算,如加密、解密等。如图11所示,安全算法模块包含待运算数据缓存BUF_IN、运算结果数据缓存BUF_OUT、数据安全算法矩阵、算法选择寄存器SF_SEL、从设备总线接口。其中待运算数据缓存BUF_IN用于存放等待计算的数据,运算结果数据缓存BUF_OUT用于存放计算后的结果,数据安全算法矩阵存放了8套安全算法,算法选择寄存器SF_SEL用于选择当前由哪一套算法参与运算,从设备总线接口用于将随机数发生器同片内总线相连以实现数据和命令的交换。待运算的数据由上位机通过USB接口经在线调试及上位机通讯模块,再经片内总线写入待运算数据缓存BUF_IN,安全算法模块从待运算缓存中取数经运算后,将结果写入运算结果数据缓存BUF_OUT。待运算数据缓存BUF_IN和运算结果数据缓存BUF_OUT的容量均为1024×32比特,处理器可以通过片内总线从运算结果数据缓存BUF_OUT中读取运算结果。安全算法模块中的数据安全算法矩阵中内嵌8套数据安全算法,具体使用哪一套算法进行运算,则由算法选择寄存器SF_SEL的状态来决定,当SF_SEL=“000”时,数据安全算法0有效;当SF_SEL=“001”时,数据安全算法1有效;当SF_SEL=“010”时,数据安全算法2有效;当SF_SEL=“011”时,数据安全算法3有效;当SF_SEL=“100”时,数据安全算法4有效;当SF_SEL=“101”时,数据安全算法5有效;当SF_SEL=“110”时,数据安全算法6有效;当SF_SEL=“111”时,数据安全算法7有效。如图6所示,待运算数据缓存BUF_IN、运算结果数据缓存BUF_OUT、算法选择寄存器SF_SEL均可以被片内总线访问。
安全算法模块为片内总线的一个从设备,其通过从设备总线接口与片内总线相连接。从设备总线接口的接口信号包括从设备地址输入信号s_addr_in[31:0]、从设备数据输入信号s_dada_in[31:0]、从设备数据输出信号s_data_out[31:0]、从设备选通输入信号s_sel_in、从设备写有效输入信号s_wr_in、从设备读有效输入信号s_rd_in、从设备应答输出信号s_ack_out。安全算法模块利用s_addr_in[31:0]信号从片内总线获取地址信息,利用s_data_in[31:0]信号从片内总线获取数据,利用s_data_out[31:0]信号将自身数据送到片内总线,利用s_sel_in信号从片内总线获取选通命令,利用s_wr_in信号从片内总线获取写操作命令,利用s_rd_in信号从片内总线获取读操作命令,利用s_ack_in信号将应答信号传递给片内总线。
本发明实施例中嵌入式数据安全系统用SOC芯片内部集成密钥存储器。如图12所示,密钥存储器包含NOR FLASH存储器和从设备总线接口。其中,NOR FLASH存储器用于存放用户密钥,从设备总线接口用于将密钥存储器同片内总线相连以实现数据和命令的交换。上位机可以通过USB接口经在线调试及上位机通讯模块,再经片内总线将用户密钥写入密钥存储器,以供安全算法模块取用。本发明实施例涉及的密钥存储器物理实现形态为NORFLASH存储器,容量为64×32bit。为了保护用户密钥的安全性和不被非法窃取,密钥存储器内的从设备总线接口被设计成单向数据接口,即只有被写入的数据通道,而没有被读出的数据通道。这样就只允许片内总线往密钥存储器写入用户密钥,而没办法从密钥存储器中读取数据。
密钥存储器为片内总线的一个从设备,其通过从设备总线接口与片内总线相连接。从设备总线接口的接口信号包括从设备地址输入信号s_addr_in[31:0]、从设备数据输入信号s_dada_in[31:0]从设备选通输入信号s_sel_in、从设备写有效输入信号s_wr_in、从设备应答输出信号s_ack_out。密钥存储器利用s_addr_in[31:0]信号从片内总线获取地址信息,利用s_data_in[31:0]信号从片内总线获取数据,利用s_sel_in信号从片内总线获取选通命令,利用m_wr_in信号从片内总线获取写操作命令,利用s_ack_in信号将应答信号传递给片内总线。如前所述,为了保护用户密钥的安全性和不被非法窃取,密钥存储器内的从设备总线接口被设计成单向数据接口,即只有被写入的数据通道,而没有被读出的数据通道。因此,密钥存储器的从设备总线接口不包含从设备数据输出信号s_data_out[31:0]和从设备读有效输入信号s_rd_in两组信号。
本发明实施例中嵌入式数据安全系统用SOC芯片内部集成定时器,用来进行系统定时。该定时器的精度为一个系统时钟周期,该定时器的定时长度为由时长寄存器TIMER_LEN来决定。时长寄存器TIMER_LEN为一个32比特宽的寄存器,故该定时器的定时长度为2的32次方个系统时钟周期。定时器为片内总线的一个从设备,其通过从设备总线接口与片内总线相连接。从设备总线接口的接口信号包括从设备地址输入信号s_addr_in[31:0]、从设备数据输入信号s_dada_in[31:0]、从设备数据输出信号s_data_out[31:0]、从设备选通输入信号s_sel_in、从设备写有效输入信号s_wr_in、从设备读有效输入信号s_rd_in、从设备应答输出信号s_ack_out。定时器利用s_addr_in[31:0]信号从片内总线获取地址信息,利用s_data_in[31:0]信号从片内总线获取数据,利用s_data_out[31:0]信号将自身数据送到片内总线,利用s_sel_in信号从片内总线获取选通命令,利用s_wr_in信号从片内总线获取写操作命令,利用s_rd_in信号从片内总线获取读操作命令,利用s_ack_in信号将应答信号传递给片内总线。
本发明实施例中嵌入式数据安全系统用SOC芯片内部集成中断控制器,用来管理和处理片内各个子模块产生的中断。如图13所示,本发明实施例中SOC芯片共有9个中断源:SPI总线控制器中断、I2C总线控制器中断、定时器中断、UART串行通讯接口中断、片内总线异常中断、安全算法模块中断、在线调试及上位机通讯模块中断、外部输入中断0、外部输入中断1。中断控制器按照时间先后顺序以及中断优先级,对这些中断源进行处理,形成中断向量表INT_LIST,并输出一个总的中断信号送给处理器。处理器进行中断响应时,首先通过片内总线读取中断向量表INT_LIST,以便明确是哪一个中断源有效,进而进行相应的处理。中断控制器为片内总线的一个从设备,其通过从设备总线接口与片内总线相连接。从设备总线接口的接口信号包括从设备地址输入信号s_addr_in[31:0]、从设备数据输入信号s_dada_in[31:0]、从设备数据输出信号s_data_out[31:0]、从设备选通输入信号s_sel_in、从设备写有效输入信号s_wr_in、从设备读有效输入信号s_rd_in、从设备应答输出信号s_ack_out。中断控制器利用s_addr_in[31:0]信号从片内总线获取地址信息,利用s_data_in[31:0]信号从片内总线获取数据,利用s_data_out[31:0]信号将自身数据送到片内总线,利用s_sel_in信号从片内总线获取选通命令,利用s_wr_in信号从片内总线获取写操作命令,利用s_rd_in信号从片内总线获取读操作命令,利用s_ack_in信号将应答信号传递给片内总线。
本发明实施例中嵌入式数据安全系统用SOC芯片内部集成UART串行通讯接口、SPI总线控制器、I2C总线控制器、GPIO接口模块,这些模块用于连接外部设备,方便SOC芯片进行功能扩展。UART串行通讯接口、SPI总线控制器、I2C总线控制器以及GPIO接口等模块均为片内总线的从设备,它们通过各自的从设备总线接口与片内总线相连接。从设备总线接口的接口信号包括从设备地址输入信号s_addr_in[31:0]、从设备数据输入信号s_dada_in[31:0]、从设备数据输出信号s_data_out[31:0]、从设备选通输入信号s_sel_in、从设备写有效输入信号s_wr_in、从设备读有效输入信号s_rd_in、从设备应答输出信号s_ack_out。ART串行通讯接口、SPI总线控制器、I2C总线控制器以及GPIO接口等模块均利用各自的s_addr_in[31:0]信号从片内总线获取地址信息,利用各自的s_data_in[31:0]信号从片内总线获取数据,利用各自的s_data_out[31:0]信号将自身数据送到片内总线,利用各自的s_sel_in信号从片内总线获取选通命令,利用各自的s_wr_in信号从片内总线获取写操作命令,利用各自的s_rd_in信号从片内总线获取读操作命令,利用s_ack_in信号将应答信号传递给片内总线。
本发明实施例中嵌入式数据安全系统用SOC芯片内部集成时钟及复位发生器,该模块是一个独立的模块,既不是片内总线的主设备,也不是从设备。时钟及复位发生器主要用来产生片内时钟信号和复位信号。时钟信号通过片内时钟网络传递给片内所有的子模块,复位信号通过片内复位网络传递给片内所有的子模块。
一般来说,当今主流的深亚微米集成电路工艺生产出来的芯片产品均有两种电源,一种为IO电源VDD_IO(常见的有3.3V),其为芯片的引脚提供电源;另一种为内核电源VDD_CORE(常见的有1.8V、1.2V等),其为芯片的内部逻辑资源(如触发器、门电路等)提供电源。为了使芯片正常工作,系统必须为芯片提供两种电源,这将增加了系统设计的复杂度。如图3所示,本发明实施例中嵌入式数据安全系统用SOC芯片内部集成电源转换器,其输入为片外电源VDD,其输出有两路,一路为IO电源VDD_IO,为芯片的引脚提供电源;另一路为内核电源VDD_CORE,为芯片内部逻辑资源提供电源;这种片内集成电源转换器的设计思路,使得本发明实施例中嵌入式数据安全系统用SOC芯片仅需要片外电源VDD单电源供电即可正常工作,而无需外界提供IO电源VDD_IO和内核电源VDD_CORE两种电源。这种设计思路可以降低系统设计的复杂性。本发明实施例中嵌入式数据安全系统用SOC芯片内部集成电源转换器的结构如图14所示。
以上所述为本发明最佳实施方式的举例,其中未详细述及的部分均为本领域普通技术人员的公知常识。本发明的保护范围以权利要求的内容为准,任何基于本发明的技术启示而进行的等效变换,也在本发明的保护范围之内。

Claims (3)

1.一种嵌入式数据安全系统用SOC芯片的在线调试及上位机通讯模块,其特征在于:所述在线调试及上位机通讯模块有两种工作模式:在线调试模式、上位机通讯模式;
在线调试模式下,上位机可以访问SOC芯片内部资源,也可以调试用户程序和烧写片内程序存储器ROM;
在上位机通讯模式下,可以实现SOC芯片与上位机的数据交互;
所述SOC芯片的外部设有引脚信号DEBUG_MODE,通过该引脚的电平设置可以实现对在线调试及上位机通讯模块工作模式的选择;
当DEBUG_MODE为高电平时,在线调试及上位机通讯模块处于在线调试模式;当DEBUG_MODE为低电平时,在线调试及上位机通讯模块处于上位机通讯模式;
所述在线调试及上位机通讯模块是片内总线上的一个主设备,其采用主设备总线接口同片内总线相连;
所述在线调试及上位机通讯模块通过互联总线连接有密钥存储器,密钥存储器包含NOR FLASH存储器和从设备总线接口,其中,NOR FLASH存储器用于存放用户密钥,从设备总线接口用于将密钥存储器同片内总线相连以实现数据和命令的交换。
2.如权利要求1所述的嵌入式数据安全系统用SOC芯片的在线调试及上位机通讯模块,其特征在于:所述主设备总线接口信号的类型以及数量与其它主设备的主设备总线接口信号相同,具体包括主设备地址信号输出m_addr_out[31:0]、主设备数据输入信号m_dada_in[31:0]、主设备数据信号输出m_data_out[31:0]、主设备选通输出信号m_sel_out、主设备写有效输出信号m_wr_out、主设备读有效输出信号m_rd_out、主设备应答输入信号m_ack_in。
3.如权利要求2所述的嵌入式数据安全系统用SOC芯片的在线调试及上位机通讯模块,其特征在于:所述在线调试及上位机通讯模块利用m_addr_out[31:0]信号从将地址信息传递给片内总线,利用m_data_in[31:0]信号从片内总线获取数据,利用m_data_out[31:0]信号将自身数据送到片内总线,利用m_sel_out信号将选通命令传送给片内总线,利用m_wr_out信号将写操作命令传送给片内总线,利用m_rd_out信号将读操作命令传送给片内总线,利用m_ack_in信号从片内总线获取应答信号。
CN201410569042.7A 2014-10-23 2014-10-23 一种嵌入式数据安全系统用soc芯片的在线调试及上位机通讯模块 Expired - Fee Related CN104391770B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201410569042.7A CN104391770B (zh) 2014-10-23 2014-10-23 一种嵌入式数据安全系统用soc芯片的在线调试及上位机通讯模块

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201410569042.7A CN104391770B (zh) 2014-10-23 2014-10-23 一种嵌入式数据安全系统用soc芯片的在线调试及上位机通讯模块

Publications (2)

Publication Number Publication Date
CN104391770A CN104391770A (zh) 2015-03-04
CN104391770B true CN104391770B (zh) 2016-08-24

Family

ID=52609678

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201410569042.7A Expired - Fee Related CN104391770B (zh) 2014-10-23 2014-10-23 一种嵌入式数据安全系统用soc芯片的在线调试及上位机通讯模块

Country Status (1)

Country Link
CN (1) CN104391770B (zh)

Families Citing this family (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2017166211A1 (zh) * 2016-03-31 2017-10-05 华为技术有限公司 测试功能组件及数据调试方法
CN106230665B (zh) * 2016-09-09 2023-04-07 深圳市艾特智能科技有限公司 调试器
CN106598873A (zh) * 2017-01-11 2017-04-26 深圳市博巨兴实业发展有限公司 一种实现mcu芯片的用户调试模式的方案
CN109697085A (zh) * 2018-11-22 2019-04-30 北京深思数盾科技股份有限公司 一种嵌入式电子产品的生产优化方法和设备
CN111045980A (zh) * 2019-12-24 2020-04-21 广东嘉泰智能技术有限公司 一种多核处理器
CN112015119B (zh) * 2020-09-02 2021-11-12 南京英锐创电子科技有限公司 调试控制电路和调试控制方法
CN114413434B (zh) * 2022-02-15 2023-10-27 上海美控智慧建筑有限公司 空调机组及其数据上传方法和数据上传装置

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1542629A (zh) * 2003-03-19 2004-11-03 ���µ�����ҵ��ʽ���� 调试系统,微处理器,以及调试器
CN1991874A (zh) * 2005-12-30 2007-07-04 中兴通讯股份有限公司 一种智能卡驱动系统

Family Cites Families (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
GB0025594D0 (en) * 2000-10-18 2000-12-06 Sgs Thomson Microelectronics On-chip emulator communication
CN101458652B (zh) * 2007-12-14 2012-01-25 上海海尔集成电路有限公司 微控制器嵌入式在线仿真调试系统
CN100592266C (zh) * 2008-04-25 2010-02-24 浙江大学 一种微处理器调试方法及所用的微处理器调试模块
CN101963934B (zh) * 2010-10-27 2012-08-08 山东大学 一种基于8051核的片上系统的在线调试方法

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1542629A (zh) * 2003-03-19 2004-11-03 ���µ�����ҵ��ʽ���� 调试系统,微处理器,以及调试器
CN1991874A (zh) * 2005-12-30 2007-07-04 中兴通讯股份有限公司 一种智能卡驱动系统

Also Published As

Publication number Publication date
CN104391770A (zh) 2015-03-04

Similar Documents

Publication Publication Date Title
CN104391770B (zh) 一种嵌入式数据安全系统用soc芯片的在线调试及上位机通讯模块
CN104391813B (zh) 一种嵌入式数据安全系统用soc芯片
CN103810112B (zh) 一种非易失性内存系统及其管理方法
CN102184365B (zh) 基于SoC芯片外部数据安全存储系统及存取控制方法
CN107924380A (zh) 使用业务类别分配高速缓存的方法、装置和系统
CN1878055B (zh) 一种分离式大数据量加/解密设备及实现方法
CN104541256B (zh) 智能远存储器带宽缩放
CN107466418A (zh) 用于多级别单元模式非易失性存储器的成本优化单级别单元模式非易失性存储器
CN104021104B (zh) 一种基于双总线结构的协同系统及其通信方法
CN102724035B (zh) 一种加密卡的加解密方法
CN103389963A (zh) 一种嵌入式系统控制器
CN103744644A (zh) 采用四核结构搭建的四核处理器系统及数据交换方法
CN105159617B (zh) 一种池化存储系统架构
CN108470129A (zh) 一种数据保护专用芯片
CN104679681B (zh) Ahb总线访问片上sram的高速桥装置及其工作方法
CN106250348A (zh) 一种基于gpu访存特性的异构多核架构缓存管理方法
CN109388608A (zh) 一种基于多核处理器的星载计算机
CN104850516B (zh) 一种ddr变频设计方法和装置
CN104298486B (zh) 一种嵌入式数据安全系统用soc芯片的随机数发生器
CN1968085B (zh) 一种实现智能卡高速安全通讯的方法
CN108710591A (zh) 一种基于申威1621处理器的服务器主板
CN103365799B (zh) 用于检测对掉电设备的访问的装置、方法、系统和设备
CN202102448U (zh) 基于SoC芯片外部数据安全存储架构
CN106599677A (zh) 一种用于基板管理控制器的密码控制系统及控制方法
CN106548099A (zh) 一种电路系统安全保护的芯片

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
C14 Grant of patent or utility model
GR01 Patent grant
CF01 Termination of patent right due to non-payment of annual fee

Granted publication date: 20160824

Termination date: 20201023

CF01 Termination of patent right due to non-payment of annual fee