linux 驱动, struct file , struct node, private_data

首先是关于什么是 praviate_data :

来看看正点原子是怎么使用的。

网上找的一些资料:

总结一下:

1 私有数据 是 struct file特有的。

2private_data 可以自己随便设置。

3 一般是在 open 函数中设置好,然后在 read, write 函数中使用。

4 private_data 一般是设置的 cdev, 以及 dev_t 结构体。

然后是 struct file 与 strcut node 的联系。

网上的资料: 这个文章总结的非常好。可以看到 struct file 与 struct node 是两条线。

然后是 struct file

先来看看网上的截图:

然后是 关于char_dev 的描述。

主设备号最大是 255 就是这么来的。

然后是关于cdev 的介绍。

然后是 struct node

疑问: 那么问题来了,到底,什么是字符设备呢?是为了解决什么问题呢?又懵逼了。

关于inode 的内容。

复制代码
struct inode {  
  struct hlist_node i_hash;  
  struct list_head i_list;  
  struct list_head i_sb_list;  
  struct list_head i_dentry;  
  unsigned long  i_ino;  
  atomic_t  i_count;  
  unsigned int  i_nlink;  
  uid_t   i_uid;//inode拥有者id  
  gid_t   i_gid;//inode所属群组id  
  dev_t   i_rdev;//若是设备文件,表示记录设备的设备号  
  u64   i_version;  
  loff_t   i_size;//inode所代表大少  
#ifdef __NEED_I_SIZE_ORDERED  
  seqcount_t  i_size_seqcount;  
#endif  
  struct timespec  i_atime;//inode最近一次的存取时间  
  struct timespec  i_mtime;//inode最近一次修改时间  
  struct timespec  i_ctime;//inode的生成时间  
  unsigned int  i_blkbits;  
  blkcnt_t  i_blocks;  
  unsigned short          i_bytes;  
  umode_t   i_mode;  
  spinlock_t  i_lock;   
  struct mutex  i_mutex;  
  struct rw_semaphore i_alloc_sem;  
  const struct inode_operations *i_op;  
  const struct file_operations *i_fop;   
  struct super_block *i_sb;  
  struct file_lock *i_flock;  
  struct address_space *i_mapping;  
  struct address_space i_data;  
#ifdef CONFIG_QUOTA  
  struct dquot  *i_dquot[MAXQUOTAS];  
#endif  
  struct list_head i_devices;  
  union {  
    struct pipe_inode_info *i_pipe;  
    struct block_device *i_bdev;  
    struct cdev  *i_cdev;//若是字符设备,对应的为cdev结构  
  }; 
}; 

struct inode{...}

然后是是 文件系统对于 cdev 的访问, 这个我不是很理解,先复制过来。

相关推荐
如若12317 分钟前
WSL2安装Ubuntu完整教程:自定义安装目录到D盘(--location一键搞定)
linux·运维·服务器·pytorch·python·ubuntu·计算机视觉
Aaswk1 小时前
蓝桥杯2025年第十六届省赛真题(更新中)
c语言·数据结构·c++·算法·职场和发展·蓝桥杯
Yvonne爱编码1 小时前
JAVA数据结构 DAY7-二叉树
java·开发语言·数据结构
总斯霖2 小时前
P15445永远在一起!题解(月赛T2)
数据结构·c++·算法·深度优先
像污秽一样2 小时前
算法设计与分析-习题4.5
数据结构·算法·排序算法·剪枝
样例过了就是过了2 小时前
LeetCode热题100 全排列
数据结构·c++·算法·leetcode·dfs
papaofdoudou2 小时前
QEMU和KVMTOOL在GPA(IOVA)和HVA映射方面的异同
linux·运维·服务器
xh didida3 小时前
数据结构--实现链式结构二叉树
c语言·数据结构·算法
ab1515173 小时前
3.15二刷基础90、105、106、110
数据结构·c++·算法
白太岁3 小时前
算法:链表:指针变化与环
数据结构·算法·链表