head.s分析(2):SYSCFG配置

本文介绍如何在ADI BF561 DSP上配置和使用Cycle Counter进行性能统计。通过对SYSCFG寄存器的设置,启用64位周期计数器,并详细解释了CYCLES和CYCLES2寄存器的功能及读取方法。

 

快乐虾

http://blog.csdn.net/lights_joy/

lights@hb165.com

  

本文适用于

ADI bf561 DSP

uclinux-2008r1.5-rc3 (移植到vdsp5)

Visual DSP++ 5.0(update 5)

 

欢迎转载,但请保留作者信息

 

     /* Enable Cycle Counter and Nesting Of Interrupts */

#ifdef CONFIG_BFIN_SCRATCH_REG_CYCLES

     R0 = SYSCFG_SNEN;

#else

     R0 = SYSCFG_SNEN | SYSCFG_CCEN;

#endif

     SYSCFG = R0;

这几行代码用于设置SYSCFG的值,关于SYSCFG这个寄存器,vdsp文件这样说:

The System Configuration Register (SYSCFG) shown in Figure 4-3 controls the configuration of the processor

对于BF561而言,只有CCENSSSTEP两位有效,在这里将CCEN位设置为1,表示要启用64位的cycle counter。而对SNEN的置位将被忽略。

System Configuration  Register

在启用了CCEN之后,CYCLESCYCLES2两个寄存器将开始统计CCLK的个数。

下面是vdsp文档中对CYCLESCYCLES2这两个寄存器的一个说明:

The cycle counter counts CCLK cycles while the program is executing. All cycles, including execution, wait state, interrupts, and events, are counted while the processor is in User or Supervisor mode, but the cycle counter stops counting in Emulator mode.

The cycle counter is 64 bits wide and increments every cycle. The count value is stored in two 32-bit registers, CYCLES and CYCLES2. The least significant 32 bits (LSBs) are stored in CYCLES. The most significant 32 bits (MSBs) are stored in CYCLES2.

Note: To ensure read coherency, first read CYCLES, then CYCLES2, and then CYCLES again, to detect if an overflow has occurred in the LSBs during the read operations.

In User mode, these two registers may be read, but not written. In Supervisor and Emulator modes, they are read/write registers.

To enable the cycle counters, set the CCEN bit in the SYSCFG register. The following example shows how to use the cycle counter:

R2 = 0;

CYCLES = R2;

CYCLES2 = R2;

R2 = SYSCFG;

BITSET(R2,1);

SYSCFG = R2;

/* Insert code to be benchmarked here. */

R2 = SYSCFG;

BITCLR(R2,1);

SYSCFG = R2;

通常这两个寄存器可以用于性能统计。但是由于这两个寄存器在几种模式下均是可写的,因此也可以将它们当成通用寄存器使用。在uclinux内核中,提供了一个叫CONFIG_BFIN_SCRATCH_REG_CYCLES的选项来控制CYCLES的用途:

config BFIN_SCRATCH_REG_CYCLES

     bool "CYCLES"

     help

       Use the CYCLES register in the Blackfin exception handler

       as a stack scratch register.  This means you cannot

       safely use the CYCLES performance registers on a Blackfin

       board at anytime, but you can debug the system with a JTAG

       ICE and use the NMI.

当设置了CONFIG_BFIN_SCRATCH_REG_CYCLES后,在linux-2.6.x/arch/blackfin/mach-common/entry.S文件中将CYCLES做为普通寄存器使用:

#if defined(CONFIG_BFIN_SCRATCH_REG_RETN)

# define EX_SCRATCH_REG RETN

#elif defined(CONFIG_BFIN_SCRATCH_REG_RETE)

# define EX_SCRATCH_REG RETE

#else

# define EX_SCRATCH_REG CYCLES

#endif

自然,在此时CYCLES是不应该自动计数的,因此SYSCFG_CCEN应该保持为0

uclinux内核代码中搜索CYCLES,可以发现有以下几个文件使用了它:

linux-2.6.x/drivers/char/bfin_timer_latency.c

linux-2.6.x/drivers/media/video/blackfin/blackfin_cam.c

linux-2.6.x/drivers/zaptel/bfsi-spi-framework.c

linux-2.6.x/drivers/zaptel/bfsi.c

当要使用这几个驱动时,就一定需要使SYSCFG_CCEN=1

 

1       参考资料

head.s分析(1):保存u-boot传递过来的指针(2009-1-19)

09:46:37.1626 [INFO] Loaded monitor commands from: E:\Software\Renode\scripts/monitor.py 09:46:42.1768 [INFO] Including script: E:\Software\Renode\scripts\single-node\stm32f4_discovery.resc 09:46:42.2197 [INFO] System bus created. 09:46:44.2268 [INFO] sysbus: Loaded SVD: E:\Software\Renode\platforms\cpus\STM32F40x.svd. Name: STM32F40x. Description: STM32F40x. 09:46:44.9408 [INFO] sysbus: Loading segment of 78080 bytes length at 0x8000000. 09:46:44.9671 [INFO] sysbus: Loading segment of 25952 bytes length at 0x8013100. 09:46:45.0388 [INFO] cpu: Guessing VectorTableOffset value to be 0x8000000. 09:46:45.0530 [INFO] cpu: Setting initial values: PC = 0x8000CFD, SP = 0x20020000. 09:46:45.0611 [INFO] STM32F4_Discovery: Machine started. 09:46:45.1743 [WARNING] rcc: Unhandled write to offset 0xC, value 0x0. 09:46:45.1905 [WARNING] rcc: Unhandled write to offset 0x4. Unhandled bits: [29] when writing value 0x7405408. Tags: RESERVED (0x0). 09:46:45.1915 [WARNING] flash_controller: Unhandled write to offset 0x0. Unhandled bits: [9-10] when writing value 0x605. Tags: ICEN (0x1), DCEN (0x1). 09:46:45.2371 [WARNING] uart4: Unhandled read from offset 0x14. (2) 09:46:45.2382 [WARNING] uart4: Unhandled write to offset 0x14, value 0x0. 09:46:45.2969 [WARNING] sysbus: Read from an unimplemented register SYSCFG:EXTICR3 (0x40013810), returning a value from SVD: 0x0. 09:46:45.2989 [WARNING] sysbus: Write of value 0x0 to an unimplemented register SYSCFG:EXTICR3 (0x40013810) generated from SVD. 09:46:45.2989 [WARNING] sysbus: Read from an unimplemented register SYSCFG:EXTICR3 (0x40013810), returning a value from SVD: 0x0. 09:46:45.2999 [WARNING] sysbus: Write of value 0x0 to an unimplemented register SYSCFG:EXTICR3 (0x40013810) generated from SVD. 09:46:45.2999 [WARNING] sysbus: Read from an unimplemented register SYSCFG:EXTICR1 (0x40013808), returning a value from SVD: 0x0. 09:46:45.2999 [WARNING] sysbus: Write of value 0x0 to an unimplemented register SYSCFG:EXTICR1 (0x40013808) generated from SVD. 09:46:45.2999 [WARNING] sysbus: Read from an unimplemented register SYSCFG:EXTICR1 (0x40013808), returning a value from SVD: 0x0. 09:46:45.3060 [WARNING] sysbus: Write of value 0x0 to an unimplemented register SYSCFG:EXTICR1 (0x40013808) generated from SVD. 09:46:45.3221 [WARNING] sysbus: Read from an unimplemented register SYSCFG:PMC (0x40013804), returning a value from SVD: 0x0. 09:46:45.3232 [WARNING] sysbus: Write of value 0x800000 to an unimplemented register SYSCFG:PMC (0x40013804) generated from SVD. 10:15:41.2883 [WARNING] ethernet: Access to unknown phy 0 (327681) 10:15:41.2883 [INFO] ethernet: Setting RDLA to 0x20003A6C.
03-29
<think>嗯,用户给了一段Renode的日志,想让我介绍一下或者解释这些内容。首先,我需要理解用户的需求。看起来用户可能在使用Renode进行嵌入式系统仿真,遇到了这些日志信息,想知道它们代表什么,或者有没有潜在的问题需要解决。 首先,我需要分析日志的结构。日志里有很多时间戳,然后是日志级别,比如[INFO]、[WARNING],接着是具体的消息。看起来是Renode在启动过程中加载各种脚本、外设配置,以及仿真STM32F4 Discovery板子的过程。 用户可能关心的是这些INFO和WARNING信息是否正常,特别是那些WARNING是否有问题。比如,有很多“Unhandled write”和“Read from an unimplemented register”的警告,这可能意味着仿真模型没有完全实现某些寄存器,或者配置有误。用户可能想知道这些警告是否需要处理,或者如何解决。 另外,用户可能对Renode的工作流程不太熟悉,比如加载monitor.py、resc脚本、SVD文件的作用是什么。需要解释这些步骤的意义,以及它们在仿真中的作用。 还有最后的关于ethernet的警告和INFO,可能涉及到网络配置的问题,用户可能需要了解这些信息对仿真结果的影响。 接下来,我需要按时间顺序逐步解释每个重要的日志条目。比如,加载monitor命令、执行resc脚本、加载SVD文件、加载固件到内存、设置初始PC和SP寄存器,这些都是启动仿真的标准步骤。然后,针对各个外设(如RCC、Flash控制器、UART4、SYSCFG等)的警告,说明这些外设的寄存器未完全实现,可能影响仿真准确性,但如果是测试简单功能,可能暂时不影响。 需要注意的是,用户可能没有提供上下文,比如他们正在运行的固件或测试的具体功能,所以需要给出一般性的建议,比如检查外设实现、确认固件是否正确,或者忽略无关警告。 最后,总结日志的整体情况,指出大部分是正常启动过程,部分警告需关注,特别是如果涉及用户正在使用的外设。同时,提供进一步排查的建议,比如查看文档或社区支持。</think>以下是Renode仿真平台启动STM32F4_Discovery开发板的日志分析,按关键步骤分层说明: $$timestamp格式:::.毫秒 [日志级别] 内容$$ $$示例: 09:46:37.1626 [INFO] ...$$ ### 一、初始化阶段 1. **加载监控命令** $09:46:37.1626$ 从`monitor.py`加载调试工具,提供交互式命令行操作功能 2. **执行RESC脚本** $09:46:42.1768$ 加载资源配置文件`stm32f4_discovery.resc`,定义机器配置、外设连接和内存映射 --- ### 二、硬件建模 1. **系统总线创建** $09:46:42.2197$ 构建虚拟SoC的总线架构,协调CPU与外围设备通信 2. **加载SVD文件** $09:46:44.2268$ 使用`STM32F40x.svd`描述芯片寄存器布局,实现寄存器级硬件模拟 3. **固件加载** - $09:46:44.9408$ 将二进制文件分段载入Flash: $$0x8000000 \rightarrow 78080B,\quad 0x8013100 \rightarrow 25952B$$ - $09:46:45.0530$ 设置初始程序计数器PC=0x8000CFD,栈指针SP=0x20020000 --- ### 三、警告解析 1. **RCC时钟控制** $09:46:45.1905$ 写入RCC_CFGR寄存器时未实现位[29],可能影响时钟配置 $$Value=0x7405408 \rightarrow Binary=0111\_0100\_0000\_0101\_0100\_0000\_1000$$ 2. **Flash控制器** $09:46:45.1915$ 未实现位[9-10],但启用了指令/数据缓存(ICEN/DCEN=1) 3. **UART4异常** $09:46:45.2371$ 访问未实现的0x14偏移量(可能对应状态寄存器USART_SR) 4. **SYSCFG外设** 多次关于EXTICR1/EXTICR3的警告,说明外部中断配置未完全建模: $$EXTICR\_寄存器地址: 0x40013808 \sim 0x40013810$$ 5. **以太网PHY** $10:15:41.2883$ 访问到未知PHY地址0,可能需检查MAC初始化代码 --- ### 四、应对建议 1. **必要处理** - 若涉及警告的外设功能(如UART通信),需检查Renode的STM32F4外设模型完整性 - 验证固件是否针对仿真环境做了适配 2. **可忽略场景** - 简单功能验证时,未使用的外设警告可暂时忽略 - 确保核心功能相关外设(如GPIO、定时器)已正确建模 3. **调试方法** ```python # 在Renode Monitor中查看寄存器状态 sysbus ReadDoubleWord 0x40013808 # 跟踪特定外设访问 sysbus SetHookAtAccess "SYSCFG:EXTICR1", { print "EXTI配置被修改" } ``` 此日志反映了一个典型STM32F4仿真环境的启动过程,警告多源于外设模型未100%实现硬件功能。建议对照[Renode官方文档](https://renode.readthedocs.io)确认具体外设支持状态。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

嵌云阁主

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值