【MTK】一个寄存器读写的例子

本文通过分析一个reset fe函数,展示了MTK7628XN芯片中如何进行寄存器读写操作,特别是针对RALINK_FE_RST和RALINK_ESW_RST标志位的设置。寄存器地址0xb0000034及其在内核头文件中的定义被详细讨论,说明了MTK芯片在MIPS架构下的内存映射和寄存器访问方式。
摘要由CSDN通过智能技术生成

从一个reset fe(frame engine)函数看MTK7628XN寄存器的配置
函数实现如下:
void fe_reset(void)
{
\#if defined (CONFIG_RALINK_RT6855A)
/* FIXME */
\#else
u32 val;
val = sysRegRead(RSTCTRL);
printk("%s %d: Read register from 0x%x, value = 0x%x.\n", __FUNCTION__, __LINE__, RSTCTRL, val);
// RT5350 need to reset ESW and FE at the same to avoid PDMA panic //
\#if defined (CONFIG_RALINK_RT5350) || defined (CONFIG_RALINK_MT7628)
val = val | RALINK_FE_RST | RALINK_ESW_RST ;
printk("%s %d: RALINK_FE_RST = 0x%x, RALINK_ESW_RST = 0x%x.\n", __FUNCTION__, __LINE__, RALINK_FE_RST, RALINK_ESW_RST);
\#else
val = val | RALINK_FE_RST;
\#endif
printk("%s %d: Write register 0x%x, value = 0x%x.\n", __FUNCTION__, __LINE__, RSTCTRL, val);
sysRegWrite(RSTCTRL, val);
\#if defined (CONFIG_RALINK_RT5350) || defined (CONFIG_RALINK_MT7620)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值