本文转载自:http://blog.csdn.net/u010871058/article/details/75637175

每个CPU,都有它固定的ID号,ID号就是这个CPU唯一的标识,它可能隐含着CPU的生产日期,版本号,型号等等,那么,在我们的这款友善之臂Tiny4412的板子上,我的这个CPU的ID又是多少呢?从我在光盘里拿到的Linux-3.5内核其实已经将ID相关的驱动开发好了,我们在内核启动的过程中就可以看到板子CPU的ID:

看下图,我们看到CPU EXYNOS4412 (Id 0xe4412011)。这个就是我板子上CPU的ID号。其它跟我相同的板子,虽然CPU也是相同的,但是板子的ID号会不一样,不信可以试试

那么,现在我不加载linux-3.5这个内核上的ID,我自己写一个驱动程序来将这个ID读出来,能否实现?

验证结果:如果我写的驱动程序读出来的ID和linux内核3.5启动过程中的ID:0xe4412011相同的话,那么就证明我读对了。

好,我们来看看具体如何来实现这个驱动程序。

还是一样的,和以前的步骤相同,但是这里的话就不用看电路图了,因为ID号是CPU内部的,我们只需要去看手册配置寄存器就可以得到相应的ID号了。

1、看手册

从手册上看到,大概的意思就是,如果要读出CPU的ID号,那么就需要先把PRO_ID的物理地址映射为虚拟地址,然后再读PRO_ID即可得到CPU的ID号。

接下来来看看驱动程序如何编写:

2、编写驱动程序

  1. #include <linux/init.h>
  2. #include <linux/module.h>
  3. #include <linux/kernel.h>
  4. #include <linux/fs.h>
  5. #include <linux/io.h>
  6. #include <asm/uaccess.h>
  7. #include <asm/irq.h>
  8. #include <asm/io.h>
  9. #define DEV_NAME    "test-dev"
  10. //板子ID的物理地址
  11. #define PRO_ID      0x10000000
  12. //定义一个虚拟地址变量
  13. unsigned int  *virtul = NULL ;
  14. //open方法,不需要实现
  15. int id_open(struct inode *inode, struct file *filp)
  16. {
  17. printk("id_open\n");
  18. return 0;
  19. }
  20. //read方法,实现虚拟地址的返回
  21. ssize_t id_read(struct file *file , char __user *buf ,size_t size ,loff_t *offset)
  22. {
  23. printk("id_read\n");
  24. if(size < 4){
  25. return -1 ;
  26. }
  27. //将虚拟地址转化为32位整型数
  28. return ioread32(virtul);
  29. }
  30. struct file_operations fops = {
  31. .owner = THIS_MODULE ,
  32. .open = id_open,
  33. .read = id_read,
  34. };
  35. int major ;
  36. int test_init(void)
  37. {
  38. printk("id_init\n");
  39. //注册设备
  40. major = register_chrdev(major, DEV_NAME, &fops);
  41. //虚拟地址映射
  42. virtul = ioremap(PRO_ID , 4);
  43. //判断是否为空或出现错误,如果出现返回-1
  44. if(IS_ERR_OR_NULL(virtul))
  45. {
  46. return -1 ;
  47. }
  48. return 0;
  49. }
  50. void test_exit(void)
  51. {
  52. printk("id_exit\n");
  53. //注销设备
  54. unregister_chrdev(major, DEV_NAME);
  55. //取消映射
  56. iounmap(virtul);
  57. }
  58. module_init(test_init);
  59. module_exit(test_exit);
  60. MODULE_LICENSE("GPL");
  61. MODULE_AUTHOR("Y.X.YANG");
  62. MODULE_VERSION("2016.1.16");

3、编写测试程序

  1. #include <stdio.h>
  2. #include <string.h>
  3. #include <stdlib.h>
  4. #include <sys/types.h>
  5. #include <sys/stat.h>
  6. #include <fcntl.h>
  7. int main(int argc, char **argv)
  8. {
  9. int fd;
  10. unsigned int id_val = 0 ;
  11. char id_buf[4] = {0};
  12. fd = open("/dev/test-dev",O_RDWR) ;
  13. if(-1 == fd)
  14. {
  15. printf("open fair!\n");
  16. return -1 ;
  17. }
  18. //获取ID的值
  19. id_val = read(fd , id_buf , 4);
  20. //以地址的形式打印
  21. printf("id_val = %p\n",id_val);
  22. return 0;
  23. }

4、makefile(略)

5、编译


6、插入模块,显示模块,查看主设备号,创建设备节点(略)

7、运行结果:

果然,读出来的ID号正是内核启动时的ID:CPU EXYNOS4412 (Id 0xe4412011) .

驱动验证成功!成功获取板子CPU_ID号!

关于Imx6ul的读取唯一的cpu的ID号

在使用IMX6板子的时候,有时会想着是否可以把板子搞一个唯一标识呢,最好是内部硬件的,而不是后来贴上去的。如果想这么做,IMX6已经帮你想好了,每个IMX6芯片内部都有唯一的标识ID,也就是UID,全球唯一的哦!。 
            那么怎么读取这个UID呢,下面介绍读取UID的办法:

root@linaro-ubuntu-desktop:~#cat /sys/fsl_otp/HW_OCOTP_CFG0            0xd72d7394 (发现这个多数为重复)

 root@linaro-ubuntu-desktop:~#cat /sys/fsl_otp/HW_OCOTP_CFG1            0xf1361d4 
           以上为在linux下读取UID的办法,Android上也是一样的,UID分为两部分,所以需要读取两次,分别读取不同的部分。            以下为UID的这两部分标识的英文解释,就不翻译了:             OTP Bank0 Word1 - containsthe first word of the UID.              OTP Bank0 Word2 - contains the second word of the UID.            继续以下,关于这个UID,你还可以查阅imx6系列芯片的datasheet,如下为英文解释,具体继续不翻译了: 
            Please look at sections 46.5.10[Value of OTP Bank0 Word1 (Configuration and 
           Manufacturing Info.)(OCOTP_CFG0)] and 46.5.11 Value of OTP Bank0 Word2  
           (Configuration and Manufacturing Info.) (OCOTP_CFG1) of the i.MX6 DQ Reference  
           Manual (IMX6DQRM, Rev 2, 06/2014). 
 
          知道UID可以做什么,可以作为唯一板子标识,可以作为以太网唯一MAC地址等,世界唯一的。以上都是在珠海鼎芯的IMX6开发板上进行测试。

如何获取板子上独有的ID号EXYNOS4412/Imx6ul【转】的更多相关文章

  1. 基于ARM-contexA9-Linux驱动开发:如何获取板子上独有的ID号

    每个CPU,都有它固定的ID号,ID号就是这个CPU唯一的标识,它可能隐含着CPU的生产日期,版本号,型号等等,那么,在我们的这款友善之臂Tiny4412的板子上,我的这个CPU的ID又是多少呢?从我 ...

  2. js如何获取地址栏上的参数id

    直接上js代码   方法1: 父页面跳转地址栏带id>>>>window.location.href='${ctxAdmin}/study/checkForm?id='+id+ ...

  3. 织梦dedecms获取当前内容页栏目id号的方法

    一,可在内容模板中直接这样写{dede:field.typeid/} 可显示本栏目的id 二,也可这样写 {dede:type}[field:ID /]{/dede:type}  . 三, 如果是在{ ...

  4. A20板子上的触摸屏设备号变化后解决

  5. 使用IO映射的方式获取tiny4412板子上的ID号

    在以前的文章中,有一篇 基于ARM-contexA9-Linux驱动开发:如何获取板子上独有的ID号 在那篇文章中,具体可以参考.那时候我使用了简单的字符设备驱动框架,最终的ID号通过read方法可将 ...

  6. 获取地址上的ID(页面与服务器的交互)

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  7. objectARX 获取指定图层上所有实体ID

    2015-12-17 //获取指定图层上所有实体ID AcDbObjectIdArray GetAllEntityId(const TCHAR* layername) { AcDbObjectIdAr ...

  8. 黄聪:WordPress 多站点建站教程(五):获取子站点用户信息(通过输入站点ID号来获取该站点的所有用户)

    得到站点ID为1的用户 <ul> <?php $blogusers = get_users('blog_id=1'); foreach ($blogusers as $user) { ...

  9. 现代浏览器原生js获取id号方法

    <div id="tests" class="a b c" style="color:#f00">123</div> ...

随机推荐

  1. Struts2的线程安全性

    [什么是线程安全性?] 在多线程并发访问的情况下,如果一个对象中的变量的值不会随访问的线程而变化则是线程安全的.反之则称为非线程安全的. [Servlet是线程安全的吗?] [非线程安全的] publ ...

  2. 【Codeforces 1051D】Bicolorings

    [链接] 我是链接,点我呀:) [题意] 题意 [题解] dp[i][j][k]表示前i列,有j个联通块下,最后一列的状态为k的方案数 k如果为1的话,表示最后一列两个块不一样,k如果为0表示一样 枚 ...

  3. vs2015 添加行件

    VS自定义项目模板:[2]创建VSIX项目模板扩展 http://jingyan.baidu.com/article/bad08e1e9b08ee09c851210d.html

  4. pip安装requests库失败

    pip install 安装第三方插件是出现Could not fetch URL https://pypi.python.org/simple/pool/: There was a problem ...

  5. Python模块学习 - openpyxl读写excel

    openpyxl模块介绍 openpyxl模块是一个读写Excel 2010文档的Python库,如果要处理更早格式的Excel文档,需要用到额外的库,openpyxl是一个比较综合的工具,能够同时读 ...

  6. [luoguP1266] 速度限制(spfa)

    传送门 因为到某一没有限速的路径速度会有不同的可能,所以直接用 dis[i][j] 表示到第 i 个点速度为 j 时的最短时间,然后跑spfa. ——代码 #include <queue> ...

  7. poj 1163 数塔

    #include<stdio.h> #include<string.h> #define N 110 int dp[N][N]; int a[N][N]; int Max(in ...

  8. 2016 Multi-University Training Contest 2 solutions BY zimpha

    Acperience 展开式子, \(\left\| W-\alpha B \right\|^2=\displaystyle\alpha^2\sum_{i=1}^{n}b_i^2-2\alpha\su ...

  9. hdu2157:How many ways??

    n<=20个点m<=100条边有向图不带权,t个询问问Ai到Bi的经过k<=20条边方案数多少. f[i][j]--i到j的方案数,,初始化成初邻接矩阵,这样做一次就得到2条路最短路 ...

  10. msp430项目编程15

    msp430中项目---简易红外遥控系统 1.红外工作原理 2.电路原理说明 3.代码(显示部分) 4.代码(功能实现) 5.项目总结 msp430项目编程 msp430入门学习