linux下uboot kernel操作cpu寄存器

大多数的内核里面都有会对GPIO的操作,而且内核里面对GPIO进行配置也很方便,要什么功能就配置成什么就可以了。

还有一些寄存器是内核没有配置到的,但是我们要操作怎么办,内核里面也定义了相关的接口函数。

在u-boot中操作某个寄存器:

 

[cpp] view plain copy

 
 print?

  1. reg = readl(IOMUXC_BASE_ADDR + IOMUXC_REG_GPR1);  
  2. reg &= ~IOMUXC_REG_GPR1_ACTCS0_MASK;  
  3. writel(reg, IOMUXC_BASE_ADDR + IOMUXC_REG_GPR1);  

其中IOMUXC_BASE_ADDR是物理地址,跟踪代码发现writel操作如下:

 

#define writel(v,a) __arch_putl(v,a)

#define __arch_putl(v,a) (*(volatile unsigned int *)(a) = (v))

所以在uboot里面配置寄存相当于是给物理地址直接赋值,volatile的意思是提醒编译器需要存储或读取这个变量的时候,都会直接从变量地址中读取数据

 

而在内核中,上面的写法是无法运行的,会提示虚拟地址错误。在内核中通常是通过虚拟地址来给物理地址赋值,所以需要将物理地址转换成虚拟地址

 

[cpp] view plain copy

 
 print?

  1. reg = __raw_readl(ioremap(IOMUXC_BASE_ADDR + IOMUXC_REG_GPR1,4));  
  2. reg &= ~IOMUXC_REG_GPR1_ACTCS0_MASK;  
  3. reg &= ~IOMUXC_REG_GPR1_ADDRS0_MASK;  
  4. reg |= ((CS0_NORFLASH_SIZE | IOMUXC_REG_GPR1_ACTCS0));  
  5. __raw_writel(reg, ioremap(IOMUXC_BASE_ADDR + IOMUXC_REG_GPR1,4));  

这里的ioremap是将物理地址IOMUXC_BASE_ADDR转换得到对应的虚拟地址,4表示4个字节,即32位的地址。

 

u-boot下读写gpio:

与读写寄存器类似,u-boot下读写GPIO口是直接给GPIO赋值:

 

[cpp] view plain copy

 

 print?

  1. mxc_request_iomux(MX53_PIN_GPIO_8, IOMUX_CONFIG_ALT1);  
  2. mxc_iomux_set_pad(MX53_PIN_GPIO_8, 0x1E4);  
  3.   
  4. reg = readl(GPIO1_BASE_ADDR + 0x0);  
  5.    <span style="white-space:pre"> </span>reg |= 0x100;  
  6. writel(reg, GPIO1_BASE_ADDR + 0x0);  
  7.   
  8. // Set pin direction as output  
  9. reg = readl(GPIO1_BASE_ADDR + 0x4);  
  10. reg |= 0x100;  
  11. writel(reg, GPIO1_BASE_ADDR + 0x4);  

GPIO_8 是GPIO1_8,前面两个配置GPIO_8的功能。

 

查看datasheet可以看到GPIO1的地址配置

53F8_4000 GPIO data register (GPIO-1_DR) 32 R/W 0000_0000h 
53F8_4004 GPIO direction register (GPIO-1_GDIR) 32 R/W 0000_0000h 
53F8_4008 GPIO pad status register (GPIO-1_PSR) 32 R 0000_0000h 
53F8_400C GPIO interrupt configuration register1 (GPIO-1_ICR1) 32 R/W 0000_0000h 
53F8_4010 GPIO interrupt configuration register2 (GPIO-1_ICR2) 32 R/W 0000_0000h
53F8_4014 GPIO interrupt mask register (GPIO-1_IMR) 32 R/W 0000_0000h 
53F8_4018 GPIO interrupt status register (GPIO-1_ISR) 32 w1c 0000_0000h
53F8_401C GPIO edge select register (GPIO-1_EDGE_SEL) 32 R/W 0000_0000h 

 

可以看到它的数据寄存器的偏移地址是0x0,输入输出寄存器的偏移地址是0x4。而reg |= 0x100;是GPIO_8的所在的偏移,即(0x1 << 8)。

读取一个gpio的值,只需要读取它的状态寄存器就可以了,

reg = readl( GPIO1_BASE_ADDR + 0x08 );

if(reg & (0x1 << 8))

printf("it is high\n");

else

printf("it is low\n");

时间: 2024-12-21 20:44:18

linux下uboot kernel操作cpu寄存器的相关文章

Linux下读写芯片的I2C寄存器

要想在Linux下读写芯片的I2C寄存器,一般需要在Linux编写一份该芯片的I2C驱动,关于Linux下如何编写I2C驱动,前一篇文章<手把手教你写Linux I2C设备驱动>已经做了初步的介绍,并且留下了两个疑问尚未解决,第一个是如何对Linux提供的I2C操作函数进行进一步封装,实现对芯片寄存器的读写:另一个是如何在用户空间调用该I2C驱动代码.本文将讨论前一个问题.      首先,我们要了解Linux系统提供的I2C操作函数怎么使用,上篇文章已经提到过,对I2C设备的读写,Linux

请问测试linux下某个jsp站点cpu和内存占用率代码怎么写?

问题描述 请问测试linux下某个jsp站点cpu和内存占用率代码怎么写?谢谢! 解决方案 解决方案二:up解决方案三:Up解决方案四:Up解决方案五:http://www.diybl.com/course/4_webprogram/jsp/jsp_js/20090212/155296_3.html看看这个~·解决方案六:思路就是调用linux下的命令然后分析输出的结果.解决方案七:继续问解决方案八:Runtimerun=Runtime.getRuntime();Processpro=run.e

Linux下如何查看高CPU占用率线程 专题

Java 系统性能分析 命令 1. cpu分析 top , pidstat(sysstat) pid -p PID -t 1 10 vmstat 1 CPU上下文切换.运行队列.利用率 ps Hh -eo tid pcpu 查看具体线程的CPU消耗 sar 来查看一定世界范围内以及历史的cpu消耗情况信息 查看java线程信息 jstack pid | grep 'nid=0x9999' 2. cs sy消耗比较高 上下文切换性能偏高, jstack -l pid, 查看on object mo

Linux下如何查看高CPU占用率线程 LINUX CPU利用率计算

目录(?)[-] proc文件系统 proccpuinfo文件 procstat文件 procpidstat文件                                           procpidtasktidstat文件 系统中有关进程cpu使用率的常用命令 ps 命令 top命令 单核情况下Cpu使用率的计算 基本思想 总的Cpu使用率计算 计算方法 某一进程Cpu使用率的计算 计算方法   实验数据 某一线程Cpu使用率的计算 计算方法   实验数据 多核情况下cpu使用率

Linux下如何查看高CPU占用率线程

在 Linux 下 top 工具可以显示 cpu 的平均利用率(user,nice,system,idle,iowait,irq,softirq,etc.) ,可以显示每个 cpu 的利用率.但是无法显示每个线程的 cpu 利用率情况,这时就可能出现这种情况,总的 cpu 利用率中 user 或 system 很高,但是用进程的 cpu 占用率进行排序时,没有进程的 user 或 system 与之对应. 可以用下面的命令将 cpu 占用率高的线程找出来: $ ps H -eo user,pid

linux下常用网络操作汇总 专题

centos 更改主机名,需要更改的几个地方: (1) /etc/sysconfig/network  //更改主机名(2)/etc/hostname  //更改主机名(3) /etc/hosts  //更改本机ip和主机名的映射关系   IP: ifconfig gateway: [root@localhost ~]# netstat -rn Kernel IP routing table Destination Gateway Genmask Flags MSS Window irtt If

Linux下查看内核、CPU、内存及各组件版本的命令和方法

查看内核版本: uname -a                          more /etc/*release                           more /etc/redhat-release                          more /proc/version  查看CPU信息:grep "model name" /proc/cpuinfo                          more /proc/cpuinfo 查看CP

Linux下mongodb服务操作shell脚本

前些天,一位开发同事找到我,说他测试环境的 mongodb 经常挂掉,要我写一个监控或复活的脚本.我觉得很奇怪,测试环境又没啥负载,经常挂掉肯定有非常规原因.跑过去看了一下日志,发现存在stop记录,我就纳闷了,没人操作他还会自己stop.这明显不是挂掉了,于是到history中看了下同事的启动命令: /usr/local/mongodb/bin/mongod --dbpath=/usr/local/mongodb/data/ --logpath=/data/mongodb.log --loga

Linux下区分物理CPU、逻辑CPU和CPU核数

判断依据:  一个物理封装的CPU(通过physical id区分判断)可以有多个核(通过core id区分判断). 而每个核可以有多个逻辑cpu(通过processor区分判断). 一个核通过多个逻辑cpu实现这个核自己的超线程技术. cpu cores 条目包含位于相同物理封装中的内核数量. siblings 条目列出了位于相同物理封装中的逻辑处理器的数量. // proc文件用processor做索引,是因为processor是拥有其下所列所有信息的最小单位.方便查看细化信息. //例如如