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

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

640.jpg

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

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

0.jpg

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

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

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

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

    1、看手册

640.png

640.jpg640.png

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

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

2、编写驱动程序

[cpp] view plain copy print?

#include <linux/init.h>  
#include <linux/module.h>  
#include <linux/kernel.h>  
#include <linux/fs.h>  
#include <linux/io.h>  
#include <asm/uaccess.h>  
#include <asm/irq.h>  
#include <asm/io.h>  
#define DEV_NAME    "test-dev"  
//板子ID的物理地址   
#define PRO_ID      0x10000000  
//定义一个虚拟地址变量   
unsigned int  *virtul = NULL ;   
//open方法,不需要实现   
int id_open(struct inode *inode, struct file *filp)  
{  
    printk("id_open\n");  
    return 0;  
}  
//read方法,实现虚拟地址的返回   
ssize_t id_read(struct file *file , char __user *buf ,size_t size ,loff_t *offset)  
{  
    printk("id_read\n");  
    if(size < 4){  
        return -1 ;   
    }  
    //将虚拟地址转化为32位整型数   
    return ioread32(virtul);  
}  
struct file_operations fops = {  
    .owner = THIS_MODULE ,  
    .open = id_open,  
    .read = id_read,  
};  
int major ;  
int test_init(void)  
{  
    printk("id_init\n");  
    //注册设备   
    major = register_chrdev(major, DEV_NAME, &fops);  
    //虚拟地址映射   
    virtul = ioremap(PRO_ID , 4);   
    //判断是否为空或出现错误,如果出现返回-1   
    if(IS_ERR_OR_NULL(virtul))  
    {  
        return -1 ;  
    }  
    return 0;  
}  
void test_exit(void)  
{  
    printk("id_exit\n");  
    //注销设备   
    unregister_chrdev(major, DEV_NAME);  
    //取消映射   
    iounmap(virtul);  
}  
module_init(test_init);  
module_exit(test_exit);  
MODULE_LICENSE("GPL");  
MODULE_AUTHOR("Y.X.YANG");  
MODULE_VERSION("2016.1.16");  

3、编写测试程序

[cpp] view plain copy print?

#include <stdio.h>  
#include <string.h>  
#include <stdlib.h>  
#include <sys/types.h>  
#include <sys/stat.h>  
#include <fcntl.h>  
int main(int argc, char **argv)  
{  
    int fd;  
    unsigned int id_val = 0 ;  
    char id_buf[4] = {0};  
    fd = open("/dev/test-dev",O_RDWR) ;  
    if(-1 == fd)  
    {  
        printf("open fair!\n");  
        return -1 ;  
    }  
    //获取ID的值   
    id_val = read(fd , id_buf , 4);  
    //以地址的形式打印   
    printf("id_val = %p\n",id_val);  
    return 0;  
}  

4、makefile(略)


5、编译

640.jpg

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

7、运行结果:

640.jpg

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

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

目录
相关文章
|
13天前
|
Linux API 开发工具
FFmpeg开发笔记(五十九)Linux编译ijkplayer的Android平台so库
ijkplayer是由B站研发的移动端播放器,基于FFmpeg 3.4,支持Android和iOS。其源码托管于GitHub,截至2024年9月15日,获得了3.24万星标和0.81万分支,尽管已停止更新6年。本文档介绍了如何在Linux环境下编译ijkplayer的so库,以便在较新的开发环境中使用。首先需安装编译工具并调整/tmp分区大小,接着下载并安装Android SDK和NDK,最后下载ijkplayer源码并编译。详细步骤包括环境准备、工具安装及库编译等。更多FFmpeg开发知识可参考相关书籍。
53 0
FFmpeg开发笔记(五十九)Linux编译ijkplayer的Android平台so库
|
2月前
|
存储 Linux 开发工具
如何进行Linux内核开发【ChatGPT】
如何进行Linux内核开发【ChatGPT】
|
3月前
|
Java Linux API
Linux设备驱动开发详解2
Linux设备驱动开发详解
41 6
|
3月前
|
消息中间件 算法 Unix
Linux设备驱动开发详解1
Linux设备驱动开发详解
46 5
|
3月前
|
Ubuntu NoSQL Linux
Linux内核和驱动
Linux内核和驱动
25 2
|
3月前
|
数据采集 Linux
Linux源码阅读笔记20-PCI设备驱动详解
Linux源码阅读笔记20-PCI设备驱动详解
|
3月前
|
编解码 安全 Linux
基于arm64架构国产操作系统|Linux下的RTMP|RTSP低延时直播播放器开发探究
这段内容讲述了国产操作系统背景下,大牛直播SDK针对国产操作系统与Linux平台发布的RTMP/RTSP直播播放SDK。此SDK支持arm64架构,基于X协议输出视频,采用PulseAudio和Alsa Lib处理音频,具备实时静音、快照、缓冲时间设定等功能,并支持H.265编码格式。此外,提供了示例代码展示如何实现多实例播放器的创建与管理,包括窗口布局调整、事件监听、视频分辨率变化和实时快照回调等关键功能。这一技术实现有助于提高直播服务的稳定性和响应速度,适应国产操作系统在各行业中的应用需求。
|
2月前
|
Linux API
Linux里的高精度时间计时器(HPET)驱动 【ChatGPT】
Linux里的高精度时间计时器(HPET)驱动 【ChatGPT】
|
2月前
|
Linux API
Linux内核中的两种ID分配方式
Linux内核中的两种ID分配方式
|
3月前
|
Linux
【linux】【驱动】<specifier>-map-pass-thru讲解
【linux】【驱动】<specifier>-map-pass-thru讲解
20 0