一种使多个交错的追踪数据流的定时相关的方法。时间戳追踪流逻辑针对同步请求监视事件追踪流。当检测到同步请求、CTI触发或两者时,使EEP?ID增大,且将时间戳值连同EEP?ID和所检测到的同步请求中可获得的任何相关识别标记一起插入到追踪流中。
【技术实现步骤摘要】
用于追踪定时相关的方法
本专利技术的
为调试追踪产生。
技术介绍
嵌入式解决方案的调试一直是个难题。随着处理器变得更快且更复杂,用当前的调试技术进行调试和开发也变得更困难。为了解决这些复杂的问题,需要程序操作更透明。需要更多透明度的三个方面是程序计数器追踪、周期精确分析,以及负载和存储数据记录。可以通过专用调试端口来存取此类数据。然而,这些问题中的每一者都需要大量的信息。简单地供应大量高频接脚以查看所有此类数据既不实际也不具有成本效益,并且需要编码方案来进一步压缩所有此类数据。已经使用一种编码技术对程序计数器(PC)追踪、所有指令的周期精确定时以及负载和存储数据记录进行编码。所有此类数据可以跨越调试端口上的相同接脚进行传输。调试端口是用于将软件或硬件产生的追踪信息输出到外部记录器的工具。追踪端口利用对于任何给定实施方案能解决需求但不会显著损害到格式效率的传输格式。传输格式原语被视为追踪输出指令集。所有处理器使用这个指令集来描述装置内的系统活动。每一处理器可以使用指令集以及管理其使用的规则集以任何方式来描述系统活动。重要的是要注意到,外部传输速率/接脚是由所部署的接收器技术确定。这些速率将随时间过去而维持相对恒定。这暗示着随着CPU时钟速率增加,优化格式以获得系统活动的压缩程度最大的表示的压力也增加。需要做的只是维持现状。幸运的是,所用的传输格式提供了有效的构件来表示系统活动。然而,此效率的代价是为了获得压缩效率在芯片上硬件上的花费较大。这向处理器给予了改善其输出带宽的效率的能力,因为其输出带宽受到CPU时钟速率增加的压制。稳步前进到较快的CPU时钟速率以及较密集的制造工艺将需要利用所有的压缩机会以及最好的可用物理传输技术。传输格式经设计以向设计人员提供以下能力:优化带宽利用(以每秒最少的位发送最真实的信息)选择效率较低但更具成本效益的系统活动表示上述两种方法的组合(即,优化PC追踪传输效率的同时实施效率较低的存储器存取输出)。这向不同的处理器给予了以最适合于其架构的形式表示其系统活动的能力。必须要进行取舍,因为存在众多的成本/能力/带宽配置要求。可以进行调整以随着时间过去优化并改进格式。传输格式在所有处理器上都保持恒定,同时可以更改物理传输层的性质。这些更改可以采取三种形式:传输类型(差动串行或常规单端I/0)分配给传输的接脚的数目数据传输的频率这意味着表示系统活动的格式可以且被视为通过实际物理机构传输的数据。调试端口的收集和格式化部分的实施将不考虑物理传输层。这样允许针对可用接脚和传输带宽类型来优化物理层,而不用改变基本的物理实施方案。接收器组件被设计成与物理层和格式无关的。这样允许整个传输部分随时间演进。使用10位编码来表示PC追踪、数据记录以及定时信息。追踪格式宽度已经与传输接脚的数目去耦。此格式可与任何数目的传输接脚一起使用。PC追踪、存储器参考信息以及定时信息跨越相同的接脚来传输。包可含有操作码或数据,或者其两者。代码包含有指示正发送的信息的类型的操作码。操作码可为2位或10位长。代码包的其余部分将保存与所述操作码相关联的数据。在许多情况下,额外的数据需要与操作码相关联。此数据被编码在被称作数据包的后续包中。数据包含有应该与前一个操作码相关联的信息。以代码包开始且包含紧跟在所述代码包之后的所有数据包的包序列被称作命令。命令可具有零个或多个参数。每一参数是与所述命令中的操作码相关联的一条独立数据。预期的参数数目取决于操作码。命令的第一参数只是使用代码包之后的数据包来编码。后续参数的第一数据包用10个操作码来标记。命令的解译取决于两个因素,命令的操作码以及命令中包含的参数的数目。换句话说,如果代码包之后紧跟着另一代码包,那么所述代码包具有一个意思,但是如果它后面跟的是数据包,那么同一个包可能具有完全不同的意思。追踪操作码展示于表1中。操作码命令含义000000000无信息/缓冲器结尾0000000001开始重复单次0000000010PC追踪间隙0000000011寄存器重复0000000100NOPSP循环0000000101SPLOOP标记0000000110定时追踪间隙0000000111命令逃避0000001000异常发生0000001001异常发生与重复单次0000001010块重复00000001011块重复0与重复单次0000001100块重复10000001101块重复1与重复单次0000001110存储器参考追踪间隙0000001111周期数据同步点0000010xxx定时同步点0000011xxx存储器参考同步点000010xxxxPC同步点/第一/最后/000011000xPC事件冲突000011001x预留00001101xx预留0000111xxx预留00010xxxxx扩展定时数据00011xxxxxCPU和ASIC数据0010xxxxxx预留0011000000存储器参考追踪间隙(旧版操作码)0011000001周期数据同步点(旧版操作码)0011xxxxxx存储器参考块01xxxxxxxx相对转向命令/寄存器转向地址10xxxxxxxx继续11xxxxxxxx定时表1PC同步点命令用以指示若干程序事件。它用来标记周期性产生的PC和定时同步点、追踪段的开始、追踪段的结束、调试暂停、重置触发器,以及其它事件。此命令中的参数传达了PC同步点存在的原因。PC同步点、定时同步点以及数据同步点命令一起用来使PC追踪数据与定时信息一致。在产生PC同步点时,它们起始了存储器参考同步点。定时同步点只有在定时被开启时才会产生。当定时开启时,定时同步点和PC同步点对充当追踪数据解译的开始点。当定时关闭时,PC同步点足以用以解译追踪数据。当PC追踪关闭时,数据同步点足以用以解译追踪。在追踪流中插入周期性同步点向用户给出了多个点,在所述点处开始追踪数据的解译。它还允许在追踪接收器中的缓冲器溢出且追踪开始命令或先前的同步点被丢弃时进行数据解译。
技术实现思路
通常,由追踪源实施的追踪协议将包含至少一个事件流、本地定时流,以及周期性地使所述两者相关的构件。当SoC添加了多个追踪源时,便需要将所述多个追踪源交错且需要使所述多个追踪源上产生的信息相关。这个问题的解决方案是创建上游相关操作模式。在这个模式中,在追踪源的下游创建时间戳追踪流(TTS)。当认为适于(周期性地,或者同步/异步请求)创建“相关点”时,TTS支持逻辑便会将n位时间戳以及m位增量ID(其中m<<n)插入其追踪流中。同时,TTS支持逻辑会向上游追踪源发送请求以标记其本地时间且在其追踪流中标出ID值。附图说明本专利技术的这些和其它方面在图式中进行说明,其中:图1展示了ct_cpdtf追踪数据格式化器的框图;图2展示了ct_cpdtf的捕获块;图3展示了ct_cpdtf的仲裁块;图4展示了DSPTX流的数据格式;图5展示了EEP接口的信号描述;图6展示了调试时间戳的信号描述。具体实施方式本专利技术的一个实施例是德州仪器cToolsCorePacDSP追踪格式化器(ct_cpdtf)。ct_cpdtf模块的架构展示于图1中,并且由配置接口101、能够缓冲多个DSP追踪输出(DSPTX)源的捕获块102组成且管理调试时间戳本文档来自技高网...
【技术保护点】
【技术特征摘要】
2012.10.19 US 13/656,1871.一种用于追踪定时相关的方法,其包括以下步骤:接收来自本地追踪数据源的追踪数据源流,其包括追踪事件数据流和本地定时数据流;创建相关点;在创建所述相关点时,使外部事件分析EEP时间戳ID增大;在创建所述相关点时,将增大的EEP时间戳ID传送到所述本地追踪数据源;在接收所述增大的EEP时间戳ID时,在所述本地追踪数据源中插入本地定时信号和所述增大的EEP时间戳ID;及通过追踪端口将对应于包含追踪事件流的所述追踪数据源流和包含所述增大的EEP时间戳ID的所述本地定时数据流的数据传输至外部记录器。2.根据权利要求1所述的方法,其中:所述创建相关点的步骤响应于异步交叉触发接口CTI触发请求而操作。3.根据权利要求1所述的方法,其中:所述创建相关点的步骤响应于同步交叉触发接口CTI触发请求而操作。4.根据权利要求1所述的方法,其中:所述创...
【专利技术属性】
技术研发人员:杰森·L·佩克,布莱恩·托梅,
申请(专利权)人:德州仪器公司,
类型:发明
国别省市:
还没有人留言评论。发表了对其他浏览者有用的留言会获得科技券。