本文转载自: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. 访问变量的每个字节内容(c语言)

    #include <stdio.h> #define fun(x) for(int fun_i = 0; fun_i < sizeof(x); fun_i++){printf(&qu ...

  2. C语言 NULL 是什么鬼

    NULL , 0 , '\0'  之间的区别与联系 1.NULL 结构体的使用中,都可以用NULL表示空,那么NULL是什么 #ifndef __cplusplus #define NULL ((vo ...

  3. Using TCP keepalive under Linux

    Linux has built-in support for keepalive. You need to enable TCP/IP networking in order to use it. Y ...

  4. HDU 2243 考研路茫茫——单词情结

    考研路茫茫——单词情结 Time Limit: 1000ms Memory Limit: 32768KB This problem will be judged on HDU. Original ID ...

  5. (3)梯度下降法Gradient Descent

    梯度下降法 不是一个机器学习算法 是一种基于搜索的最优化方法 作用:最小化一个损失函数 梯度上升法:最大化一个效用函数 举个栗子 直线方程:导数代表斜率 曲线方程:导数代表切线斜率 导数可以代表方向, ...

  6. [Istio]流量管理API v1alpha3路由规则

    Istio提供一个API进行流量管理,该API允许用户将请求路由到特定版本的服务,为弹性测试注入延迟和失败,添加断路器等,所有这些功能都不必更改应用程序本身的代码.Istio 1.0中引入新的流量管理 ...

  7. JS替换回车换行符

    replace(/\r/ig, '<br>').replace(/\n/ig, '<br>')

  8. [luoguP1273] 有线电视网(DP)

    传送门 f[i][j]表示节点i选j个用户的最大收益 #include <cstdio> #include <cstring> #include <iostream> ...

  9. 洛谷P1021 邮票面值设计

    题目描述 给定一个信封,最多只允许粘贴N张邮票,计算在给定K(N+K≤15)种邮票的情况下(假定所有的邮票数量都足够),如何设计邮票的面值,能得到最大值MAX,使在1-MAX之间的每一个邮资值都能得到 ...

  10. hdu1588:Gauss Fibonacci

    对每个0<=i<n求f(g(i))的和,其中f(x)为斐波那契数列第x项,g(i)=k*i+b,k,b,n给定,模数给定. 斐波那契数有一种用矩阵乘法求的方法,这个矩阵A自己写,令F[i] ...