Linux内核读取spi-nor flash sn

简介: Linux内核读取spi-nor flash sn

设备量产时,需要自动设置一个mac地址和sn,如果使用随机数生成的话,可能会有重复的,这里读取spi-nor的sn,参考sn来生成设备的mac和sn;


添加如下部分:


代码如下:

#include <linux/proc_fs.h>
static ssize_t unique_read(struct file *file, char __user *buf, size_t count, loff_t *ppos)
{
  struct spi_nor *nor = PDE_DATA(file_inode(file));
  u8      unique[12];
  u64         unique_id = 0;
  int     i, tmp;

  tmp = nor->read_reg(nor, 0x4b, unique, 12);
  if (tmp < 0) {
    dev_dbg(nor->dev, " error %d reading unique ID\n", tmp);
    return 0;
  }

  for (i=4; i<11; i++) {
    unique_id |= unique[i];
    unique_id = unique_id << 8;
  }
  unique_id |= unique[i];

  return sprintf(buf, "%llx\n", unique_id);
}

static const struct file_operations spi_nor_proc_fops = {
  .read   = unique_read,
  .llseek = default_llseek,
};


static const struct spi_device_id *spi_nor_read_id(struct spi_nor *nor)
{
  int     tmp;
  u8      id[5];
  u32     jedec;
  u16                     ext_jedec;
  struct flash_info *info;

  //调用
  proc_create_data("unique_id", 0666, NULL, &spi_nor_proc_fops, nor);


  tmp = nor->read_reg(nor, SPINOR_OP_RDID, id, 5);
  if (tmp < 0) {
    dev_dbg(nor->dev, " error %d reading JEDEC ID\n", tmp);
    return ERR_PTR(tmp);
  }
  jedec = id[0];
  jedec = jedec << 8;
  jedec |= id[1];
  jedec = jedec << 8;
  jedec |= id[2];

  ext_jedec = id[3] << 8 | id[4];

  for (tmp = 0; tmp < ARRAY_SIZE(spi_nor_ids) - 1; tmp++) {
    info = (void *)spi_nor_ids[tmp].driver_data;
    if (info->jedec_id == jedec) {
      if (info->ext_id == 0 || info->ext_id == ext_jedec)
        return &spi_nor_ids[tmp];
    }
  }
  dev_err(nor->dev, "unrecognized JEDEC id %06x\n", jedec);
  return ERR_PTR(-ENODEV);
}


然后应用层读取/proc/unique_id即可,应用层读取示例:

#include <stdint.h>
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <getopt.h>
#include <fcntl.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <string.h>

#include <algorithm>
#include <string>

using namespace std;

int main(void)
{
    int fd;
    
    char  uid[32] = {0};
    int size;

  fd = open("/proc/unique_id", O_RDONLY);
  if (fd < 0)
    return 1;

  size = read(fd, uid, sizeof(uid));
  close(fd);
  
  uid[strlen(uid)-1] = '\0';
  
  //转为大写
  std::string str = uid;
  std::transform(str.begin(), str.end(),str.begin(), ::toupper);
  printf("%s", str.c_str());

  return 0;
}

目录
相关文章
|
6天前
|
安全 Linux 编译器
探索Linux内核的奥秘:从零构建操作系统####
本文旨在通过深入浅出的方式,带领读者踏上一段从零开始构建简化版Linux操作系统的旅程。我们将避开复杂的技术细节,以通俗易懂的语言,逐步揭开Linux内核的神秘面纱,探讨其工作原理、核心组件及如何通过实践加深理解。这既是一次对操作系统原理的深刻洞察,也是一场激发创新思维与实践能力的冒险。 ####
|
9天前
|
网络协议 Linux 调度
深入探索Linux操作系统的心脏:内核与系统调用####
本文旨在揭开Linux操作系统中最为核心的部分——内核与系统调用的神秘面纱,通过生动形象的语言和比喻,让读者仿佛踏上了一段奇妙的旅程,从宏观到微观,逐步深入了解这两个关键组件如何协同工作,支撑起整个操作系统的运行。不同于传统的技术解析,本文将以故事化的方式,带领读者领略Linux内核的精妙设计与系统调用的魅力所在,即便是对技术细节不甚了解的读者也能轻松享受这次知识之旅。 ####
|
5天前
|
缓存 算法 安全
深入理解Linux操作系统的心脏:内核与系统调用####
【10月更文挑战第20天】 本文将带你探索Linux操作系统的核心——其强大的内核和高效的系统调用机制。通过深入浅出的解释,我们将揭示这些技术是如何协同工作以支撑起整个系统的运行,同时也会触及一些常见的误解和背后的哲学思想。无论你是开发者、系统管理员还是普通用户,了解这些基础知识都将有助于你更好地利用Linux的强大功能。 ####
13 1
|
6天前
|
缓存 编解码 监控
深入探索Linux内核调度机制的奥秘###
【10月更文挑战第19天】 本文旨在以通俗易懂的语言,深入浅出地剖析Linux操作系统内核中的进程调度机制,揭示其背后的设计哲学与实现策略。我们将从基础概念入手,逐步揭开Linux调度策略的神秘面纱,探讨其如何高效、公平地管理系统资源,以及这些机制对系统性能和用户体验的影响。通过本文,您将获得关于Linux调度机制的全新视角,理解其在日常计算中扮演的关键角色。 ###
26 1
|
14天前
|
网络协议 Linux 芯片
Linux 内核 6.11 RC6 发布!
【10月更文挑战第12天】
77 0
Linux 内核 6.11 RC6 发布!
|
2月前
|
存储 安全 Linux
探索Linux操作系统的心脏:内核
在这篇文章中,我们将深入探讨Linux操作系统的核心—内核。通过简单易懂的语言和比喻,我们会发现内核是如何像心脏一样为系统提供动力,处理数据,并保持一切顺畅运行。从文件系统的管理到进程调度,再到设备驱动,我们将一探究竟,看看内核是怎样支撑起整个操作系统的大厦。无论你是计算机新手还是资深用户,这篇文章都将带你领略Linux内核的魅力,让你对这台复杂机器的内部运作有一个清晰的认识。
71 3
|
2月前
|
缓存 安全 Unix
Linux 内核黑客不可靠指南【ChatGPT】
Linux 内核黑客不可靠指南【ChatGPT】
|
2月前
|
Linux 开发者
Linux内核贡献成熟度模型 【ChatGPT】
Linux内核贡献成熟度模型 【ChatGPT】
|
2月前
|
网络协议 Ubuntu Linux
用Qemu模拟vexpress-a9 (三)--- 实现用u-boot引导Linux内核
用Qemu模拟vexpress-a9 (三)--- 实现用u-boot引导Linux内核
|
2月前
|
Linux
用clang编译Linux内核
用clang编译Linux内核