MilkV Duo256M ARM核 HWTIMER驱动调试记录

devtools/2024/11/15 8:36:24/

MilkV Duo256M ARM核 HWTIMER 驱动调试记录

本文记录一个在对接 cv18xx_aarch64 的 hwtimer 设备驱动时遇到的问题。

问题描述

首先该 hwtimer 设备驱动是已经对接到 c906_little 和 cv18xx_risc-v 了的,并且测试正常通过。根据芯片数据手册描述,这几个核心的外设映射地址都是相同的,只是中断号各自不同需要区分。

但是在运行测试用例时,cv18xx_aarch64 报以下错误日志

exception info:      
esr.EC :0x25   
esr.IL :0x01
esr.ISS:0x00000045 
epc    :0x000000008020154c 
Data abort     
fault addr = 0x00000000030a0008                         abort caused by write instruction                       Translation fault, first level                           Execption:                                               X00:0x00000000030a0000 X01:0x0000000000000001 X02:0x0000000080201634 X03:0x0000000000000065           X04:0x0000000000000065 X05:0x0000000000656369 X06:0x0000656c706d6173 X07:0x0000000000000001           X08:0x00000000000848e2 X09:0xffffff7f7f7f7f7f X10:0x0000000000000728 X11:0x0101010101010101           X12:0x000000000000000d X13:0x0000000000000000 X14:0xffffffffffffffff X15:0x0000000000000000           X16:0xffffffffffffffff X17:0x0000000000000000 X18:0x000000008d5ffdf0 X19:0x0000000080252694           X20:0x00000000802604b0 X21:0x0000000000000000 X22:0x0000000000000016 X23:0x0000000000000017           X24:0x0000000000000018 X25:0x0000000000000019 X26:0x000000000000001a X27:0x000000000000001b           X28:0x000000000000001c X29:0x0000000080300cf0 X30:0x000000008020168c                                   SP_EL0:0x0000000000000000                               SPSR  :0x0000000020000005                               EPC   :0x000000008020154c      

粗略判断为是写入异常导致的错误,通过反汇编快速定位异常代码:

sudo apt-get install gcc-aarch64-linux-gnu
aarch64-linux-gnu-objdump -l -S rtthread.elf > out.c

去到 0x000000008020154c

hal_timer_reset_register():
/home/csc/Project/rt-thread/bsp/cvitek/drivers/drv_timer.c:289
void hal_timer_reset_register(dw_timer_regs_t *timer_base)
{80201540:	d10043ff 	sub	sp, sp, #0x1080201544:	f90007e0 	str	x0, [sp, #8]
/home/csc/Project/rt-thread/bsp/cvitek/drivers/drv_timer.c:290timer_base->TCR = 0U;80201548:	f94007e0 	ldr	x0, [sp, #8]8020154c:	b900081f 	str	wzr, [x0, #8]
/home/csc/Project/rt-thread/bsp/cvitek/drivers/drv_timer.c:291timer_base->TLC = 0U;80201550:	f94007e0 	ldr	x0, [sp, #8]80201554:	b900001f 	str	wzr, [x0]
/home/csc/Project/rt-thread/bsp/cvitek/drivers/drv_timer.c:292
}

hal_timer_reset_register 实在外设操作的第一步初始化就出现了写入异常,核对芯片数据手册外设地址是没有问题。

于是去查看其他同时支持了 cv18xx_aarch64 和 cv18xx_risc-v 并可以正常运行的外设驱动有没有进行特殊处理。

在 uart 驱动中发现针对 ARCH_ARM 对外设的基地址进行了重映射

    pinmux_config(BSP_UART0_RX_PINNAME, UART0_RX, pinname_whitelist_uart0_rx);pinmux_config(BSP_UART0_TX_PINNAME, UART0_TX, pinname_whitelist_uart0_tx);BSP_INSTALL_UART_DEVICE(0);
#if defined(ARCH_ARM)uart->hw_base = (rt_size_t)rt_ioremap((void*)uart->hw_base, 0x10000);
#endif /* defined(ARCH_ARM) */

于是在 hwtimer 也针对 ARCH_ARM 添加 rt_ioremap

#if defined(ARCH_ARM)_timer_obj[i].base = (dw_timer_regs_t *)rt_ioremap((void*)_timer_obj[i].base, 0x10000);
#endif /* defined(ARCH_ARM) */

重新编译并运行测试用例,顺利通过。

存在的困惑

目前还不清楚为什么针对 ARCH_ARM 需要对外设的基地址进行重映射,如果有了解的大佬,欢迎留言。


http://www.ppmy.cn/devtools/97340.html

相关文章

【Linux网络】select函数

欢迎来到 破晓的历程的 博客 ⛺️不负时光,不负己✈️ 文章目录 select函数介绍select函数参数介绍select函数返回值select的工作流程TCP服务器【多路复用版】 select函数介绍 在Linux网络编程中,select 函数是一种非常有用的IO多路复用技术&#xff0…

如何用3个月零基础入门网络安全?_网络安全零基础怎么学习

前 言 写这篇教程的初衷是很多朋友都想了解如何入门/转行网络安全,实现自己的“黑客梦”。文章的宗旨是: 1.指出一些自学的误区 2.提供客观可行的学习表 3.推荐我认为适合小白学习的资源.大佬绕道哈! →点击获取网络安全资料攻略← 一、自学…

函数递归那些事

什么是递归 递归就是函数自己调用自己,而递归的本质其实是一种解决问题的方法。 递归的思想 递归的思想是把复杂问题大事化小的过程。即把一个大型复杂的问题不断的拆分成与原问题相似,但规模较小的子问题,直到子问题不能被拆分&#xff0…

[Linux][OS][信号的保存和处理]

目录 信号的处理 1. 在内核中的表示 2. 相关概念 3. 信号集操作函数 4.sigprocmask 5.sigpending 信号的捕捉 重谈地址空间 信号的处理 1. 在内核中的表示 普通信号,多次产生只会记录一次 信号范围 [1,31],每一种信号都要有自己的一种处理方式…

【鸿蒙学习】HarmonyOS应用开发者基础 - 构建更加丰富的页面(一)

学完时间:2024年8月14日 一、前言叨叨 学习HarmonyOS的第六课,人数又成功的降了500名左右,到了3575人了。 二、ArkWeb 1、概念介绍 ArkWeb是用于应用程序中显示Web页面内容的Web组件,为开发者提供页面加载、页面交互、页面调…

Leetcode面试经典150题-155.最小栈

解法都在代码里,不懂就留言或者私信 我写了两种解法,建议选择双栈的,感觉这才是考察点 /**一般解法:过个笔试没问题,建议用双栈的方法 */ class MinStack2 {/**至少应该有一个栈用于保存数据 对于push和pop以及top的话…

在线学习考试设计与实现(源码+lw+部署文档+讲解等)

文章目录 前言具体实现截图详细视频演示技术栈系统测试为什么选择我官方认证玩家,服务很多代码文档,百分百好评,战绩可查!!入职于互联网大厂,可以交流,共同进步。有保障的售后 代码参考数据库参…

MySQL 安装与配置指南

MySQL 是一种广泛使用的关系型数据库管理系统,为各种应用程序提供高效的数据存储和管理解决方案。本文将介绍如何在不同的操作系统中安装 MySQL,以及如何进行基本的配置,以确保数据库系统的最佳性能和稳定性。 一、环境准备 1.1 系统要求 …