当前位置:  技术问答>linux和unix

linux内核读文件出现的错误。。。。。。。。。。。。。。。。。。。

    来源: 互联网  发布时间:2016-12-25

    本文导语:  代码如下: int read_file(void) { char buf_read[1024]={0};     struct file *fp;     mm_segment_t fs;     loff_t pos;     printk("hello entern");     fp = filp_open("/mnt/btr-test/file2", O_RDWR , 0644);     if (IS_ERR(fp)) {         p...

代码如下:
int read_file(void)
{
char buf_read[1024]={0};
    struct file *fp;
    mm_segment_t fs;
    loff_t pos;
    printk("hello entern");
    fp = filp_open("/mnt/btr-test/file2", O_RDWR , 0644);
    if (IS_ERR(fp)) {
        printk("open flie faildn");
        return -1;
    }
printk("open successn");
    fs = get_fs();
    set_fs(KERNEL_DS);
    pos = 0;
    vfs_read(fp, buf_read, sizeof(buf_read), &pos);
    printk("read: %sn", buf_read);
    filp_close(fp, NULL);
    set_fs(fs);
    return 0;
}

该函数在vfs下层的文件系统中被调用,然后问题是当文件被成功打开后,vfs_read操作时便没响应了,从/var/log/message中看到的信息是:

Aug 24 16:02:53 ipshot kernel: INFO: task btrfsctl:5714 blocked for more than 120 seconds.
Aug 24 16:02:53 ipshot kernel: "echo 0 > /proc/sys/kernel/hung_task_timeout_secs" disables this message.
Aug 24 16:02:53 ipshot kernel: btrfsctl      D ffff88001500daf0     0  5714   3585 0x00000080
Aug 24 16:02:53 ipshot kernel: ffff88001387b328 0000000000000082 ffff88001387b298 0000000000000000
Aug 24 16:02:53 ipshot kernel: 0000000000014c80 ffff88001500d560 ffff88001500daf0 ffff88001387bfd8
Aug 24 16:02:53 ipshot kernel: ffff88001500daf8 0000000000014c80 ffff88001387a010 0000000000014c80
Aug 24 16:02:53 ipshot kernel: Call Trace:
Aug 24 16:02:53 ipshot kernel: [] btrfs_tree_lock+0x111/0x120 [btrfs]
Aug 24 16:02:53 ipshot kernel: [] ? btrfs_wake_function+0x0/0x20 [btrfs]
Aug 24 16:02:53 ipshot kernel: [] btrfs_search_slot+0x836/0x8a0 [btrfs]
Aug 24 16:02:53 ipshot kernel: [] btrfs_lookup_file_extent+0x3d/0x40 [btrfs]
Aug 24 16:02:53 ipshot kernel: [] btrfs_get_extent+0x147/0x9d0 [btrfs]
Aug 24 16:02:53 ipshot kernel: [] ? btrfs_lookup_ordered_extent+0x33/0x1e0 [btrfs]
Aug 24 16:02:53 ipshot kernel: [] __extent_read_full_page+0x190/0x670 [btrfs]
Aug 24 16:02:53 ipshot kernel: [] ? __mem_cgroup_commit_charge+0x5c/0xb0
Aug 24 16:02:53 ipshot kernel: [] ? mem_cgroup_charge_common+0x6d/0x90
Aug 24 16:02:53 ipshot kernel: [] ? btrfs_get_extent+0x0/0x9d0 [btrfs]
Aug 24 16:02:53 ipshot kernel: [] extent_read_full_page+0x2e/0x50 [btrfs]
Aug 24 16:02:53 ipshot kernel: [] btrfs_readpage+0x23/0x30 [btrfs]
Aug 24 16:02:53 ipshot kernel: [] generic_file_aio_read+0x1f1/0x6e0
Aug 24 16:02:53 ipshot kernel: [] do_sync_read+0xda/0x120
Aug 24 16:02:53 ipshot kernel: [] ? release_console_sem+0x1c1/0x200
Aug 24 16:02:53 ipshot kernel: [] ? security_file_permission+0x8b/0x90
Aug 24 16:02:53 ipshot kernel: [] vfs_read+0xc5/0x190

难道说不能在文件系统内部调用上层VFS的接口?

|
试试用.
fp->f_op->read


 

    
 
 

您可能感兴趣的文章:

  • Linux内核中影响tcp三次握手的一些协议配置
  • 我想学习linux桌面编程,那么有没有必要学习linux的内核以及内核的相关编程呢?
  • CSS属性参考手册 iis7站长之家
  • 现有linux内核中共享内存机制如何移植到linux0.11内核中
  • Linux进程的内核栈和用户栈概念,相互关系及切换过程
  • 读懂 Linux 内核代码不难,难的是读懂 Linux 内核代码背后的哲学!
  • linux内核中的likely宏和unlikely宏介绍及用法
  • Linux中内核线程不访问内核态地址空间?
  • Linux下c/c++开发之程序崩溃(Segment fault)时内核转储文件(core dump)生成设置方法
  • linux为什么要升级内核?升级内核有何作用?
  • 请问linux中如何判断内核是否已经启动。(在内核中写程序)
  • 《Linux内核情景分析》值得推荐的内核学习参考两用资料
  • *******是不是对内核模块编程然后再重新编译内核就可以把此模块整合到linux系统中
  • Linux 编译内核之后 没办法选择内核版本
  • 想看linux内核源代码,另外手头上有一本《unix环境高级编程》,需要先把《unix环境高级编程》看完之后再看内核吗?
  • 请问重新编译LINUX内核是否能将没有用的外设的驱动程序删除并减少内核占有内存的资源?请好心人仕指教!
  • Linux内核工具包 TOMOYO Linux
  • 请问:构建嵌入式linux环境时,“Linux内核的移植”是达到什么目的啊?
  • 求教,Linux下键盘输入的所有数据都会经过Linux内核吗???
  • 高深问题:有了linux内核源代码如何做成一个linux操作系统
  • linux内核编译一定要在linux环境下么?
  • linux/centos安装nginx常见错误及解决办法
  • linux安装codeblock 编译错误make: *** [all-recursive] 错误 1
  • Linux下怎样查c程序的错误号?程序出现错误:System error 32: Broken Pipe, 是什么原因?
  • 紧急求救:在LINUX下如何根据错误代码,查出对应的错误描述?
  • 在Linux系统上recv返回错误,通过errno得到的错误消息为"Interrupted system call"
  • FTP匿名登陆 LINUX 出现错误 linux FTP 550 permission
  • linux 编程获取错误信息有没相关资料?
  • windows下好使的函数到linux下怎么就段错误了呢?
  • linux中非正常关机,出现的错误如何解决?
  • 请问,我用turbo Linux,远程FTP报Password required, but none set错误
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 是否有人知道linux启动时最先出现的小企鹅图标在那儿出现的?
  • 新用linux的GDB, 版本是出现6.3.3.0,出现奇怪问题, 可能是环境设置的问题, 大人帮忙
  • 传utf-8的网页到linux出现乱码
  • XP下安装Linux10 ,启动后没有出现Linux的入口,而是直接进入了XP ...
  • 用虚拟机装完LINUX为什么总会出现如图那的提示?
  • 啊??Linux按章出现问题了啊
  • linux服务器,大磁盘挂载分区,不定期出现“只读”现象
  • 用putty登linux出现如下问题
  • 用Vmware虚拟linux出现乱码
  • 安装Linux出现的问题。。
  • 第一次装linux5.0,光盘启动后按enter就出现Uncompressing Linux... Ok, booting the kernel.谁知道阿
  • linux 下用gdb调试器出现问题
  • 在redhat linux下安装网卡驱动出现问题
  • 安装红旗linux之后出现的问题
  • windows下telnet到linux下出现乱码
  • 在redhat linux 8.0 中文板上 , 有些地方出现乱码问题!
  • linux at 命令出现警告
  • 求助:在Linux下安装mysql出现以下问题
  • linux安装jdk出现空间不足的问题
  • linux出现这种界面怎么办???
  • linux c/c++ IP字符串转换成可比较大小的数字
  • 在win分区上安装linux和独立分区安装linux有什么区别?可以同时安装吗?(两个linux系统)
  • linux哪个版本好?linux操作系统版本详细介绍及选择方案推荐
  • 在虚拟机上安装的linux上,能像真的linux系统一样开发linux程序么?
  • secureCRT下Linux终端汉字乱码解决方法
  • 我重装window后,把linux的引导区覆盖了,进不了linux怎么办?急啊,望热心的人帮助 (现在有linux的盘)
  • Linux c字符串中不可打印字符转换成16进制
  • 安装vmware软件,不用再安装linux系统,就可以模拟linux系统了,然后可以在其上学习一下LINUX下的基本操作 了?
  • Linux常用命令介绍:更改所属用户群组或档案属性
  • 红旗Linux主机可以通过127.0.0.1访问,但如何是连网的Win2000机器通过Linux的IP去访问Linux
  • linux命令大全详细分类介绍及常用linux命令文档手册下载


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3